2004-12-11 01:00:17 +00:00
|
|
|
/* mate_setup.c
|
|
|
|
* MATE -- Meta Analysis Tracing Engine
|
|
|
|
*
|
|
|
|
* Copyright 2004, Luis E. Garcia Ontanon <luis.ontanon@gmail.com>
|
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Ethereal - Network traffic analyzer
|
|
|
|
* By Gerald Combs <gerald@ethereal.com>
|
|
|
|
* Copyright 1998 Gerald Combs
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "mate.h"
|
|
|
|
|
|
|
|
static int* dbg;
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
static int dbg_cfg_lvl = 0;
|
2004-12-11 01:00:17 +00:00
|
|
|
static int* dbg_cfg = &dbg_cfg_lvl;
|
|
|
|
|
|
|
|
FILE* dbg_facility;
|
|
|
|
|
|
|
|
typedef gboolean config_action(AVPL* avpl);
|
|
|
|
|
|
|
|
/* the current mate_config */
|
|
|
|
static mate_config* matecfg = NULL;
|
|
|
|
|
|
|
|
/* key: the name of the action
|
|
|
|
value: a pointer to an config_action */
|
|
|
|
static GHashTable* actions = NULL;
|
|
|
|
|
|
|
|
/* aestetics: I like keywords separated from user attributes */
|
|
|
|
static AVPL* all_keywords = NULL;
|
|
|
|
|
2005-01-10 02:37:19 +00:00
|
|
|
/* configuration error */
|
|
|
|
GString* config_error;
|
|
|
|
|
|
|
|
static void report_error(guint8* fmt, ...) {
|
|
|
|
static guint8 error_buffer[DEBUG_BUFFER_SIZE];
|
|
|
|
|
|
|
|
va_list list;
|
|
|
|
|
|
|
|
va_start( list, fmt );
|
|
|
|
g_vsnprintf(error_buffer,DEBUG_BUFFER_SIZE,fmt,list);
|
|
|
|
va_end( list );
|
|
|
|
|
|
|
|
g_string_append(config_error,error_buffer);
|
|
|
|
g_string_append_c(config_error,'\n');
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
/* use as: setting = extract_named_xxx(avpl,keyword,default_value); */
|
|
|
|
static int extract_named_int(AVPL* avpl, guint8* keyword, int value) {
|
|
|
|
AVP* avp = NULL;
|
|
|
|
|
|
|
|
if(( avp = extract_avp_by_name(avpl,keyword) )) {
|
|
|
|
value = strtol(avp->v,NULL,10);
|
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static float extract_named_float(AVPL* avpl, guint8* keyword, float value) {
|
|
|
|
AVP* avp = NULL;
|
|
|
|
|
|
|
|
if(( avp = extract_avp_by_name(avpl,keyword) )) {
|
|
|
|
value = (float) strtod(avp->v,NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean extract_named_bool(AVPL* avpl, guint8* keyword, gboolean value) {
|
|
|
|
AVP* avp = NULL;
|
|
|
|
if(( avp = extract_avp_by_name(avpl,keyword) )) {
|
|
|
|
value = ((g_strcasecmp(avp->v,"TRUE") == 0) ? TRUE : FALSE);
|
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
static guint8* extract_named_str(AVPL* avpl, guint8* keyword, guint8* value) {
|
|
|
|
AVP* avp = NULL;
|
|
|
|
|
|
|
|
if(( avp = extract_avp_by_name(avpl,keyword) )) {
|
|
|
|
value = avp->v;
|
|
|
|
}
|
|
|
|
|
|
|
|
return value;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* lookups for the string value of the given named attribute from a given hash */
|
|
|
|
static gpointer lookup_using_index_avp(AVPL* avpl, guint8* keyword, GHashTable* table, guint8** avp_value) {
|
|
|
|
AVP* avp = extract_avp_by_name(avpl,keyword);
|
|
|
|
|
|
|
|
if (avp) {
|
|
|
|
*avp_value = avp->v;
|
|
|
|
return g_hash_table_lookup(table,avp->v);
|
|
|
|
} else {
|
|
|
|
*avp_value = NULL;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* creates and initializes a mate_cfg_item */
|
|
|
|
static mate_cfg_item* new_mate_cfg_item(guint8* name) {
|
|
|
|
mate_cfg_pdu* new = g_malloc(sizeof(mate_cfg_item));
|
|
|
|
|
|
|
|
new->name = g_strdup(name);
|
|
|
|
new->type = MATE_UNK_TYPE;
|
|
|
|
new->transforms = g_ptr_array_new();
|
|
|
|
new->extra = new_avpl(name);
|
2005-02-06 20:37:02 +00:00
|
|
|
new->last_id = 0;
|
|
|
|
new->hfid = -1;
|
|
|
|
new->my_hfids = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
new->items = g_hash_table_new(g_direct_hash,g_direct_equal);
|
|
|
|
new->ett = -1;
|
|
|
|
new->ett_attr = -1;
|
|
|
|
new->ett_times = -1;
|
|
|
|
new->ett_children = -1;
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
new->discard_pdu_attributes = matecfg->discard_pdu_attributes;
|
|
|
|
new->last_to_be_created = matecfg->last_to_be_created;
|
2005-02-06 20:37:02 +00:00
|
|
|
new->hfid_proto = -1;
|
2005-02-18 22:33:16 +00:00
|
|
|
new->transport_ranges = NULL;
|
|
|
|
new->payload_ranges = NULL;
|
2004-12-11 01:00:17 +00:00
|
|
|
new->hfids_attr = NULL;
|
2005-02-06 20:37:02 +00:00
|
|
|
new->drop_pdu = matecfg->drop_pdu;
|
|
|
|
new->criterium_match_mode = AVPL_NO_MATCH;
|
2004-12-11 01:00:17 +00:00
|
|
|
new->criterium = NULL;
|
|
|
|
new->hfid_pdu_rel_time = -1;
|
2004-12-23 08:27:30 +00:00
|
|
|
new->hfid_pdu_time_in_gop = -1;
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2005-02-06 20:37:02 +00:00
|
|
|
new->expiration = -1.0;
|
2004-12-31 14:27:38 +00:00
|
|
|
new->hfid_start_time = -1;
|
|
|
|
new->hfid_stop_time = -1;
|
|
|
|
new->hfid_last_time = -1;
|
2005-02-06 20:37:02 +00:00
|
|
|
|
|
|
|
new->start = NULL;
|
|
|
|
new->stop = NULL;
|
|
|
|
new->key = NULL;
|
|
|
|
new->show_pdu_tree = matecfg->show_pdu_tree;
|
|
|
|
new->show_times = matecfg->show_times;
|
|
|
|
new->drop_gop = matecfg->drop_gop;
|
|
|
|
new->idle_timeout = -1.0;
|
|
|
|
new->lifetime = -1.0;
|
|
|
|
new->hfid_gop_pdu = -1;
|
2004-12-11 01:00:17 +00:00
|
|
|
new->hfid_gop_num_pdus = -1;
|
2005-02-18 20:02:40 +00:00
|
|
|
new->ett_gog_gop = -1;
|
|
|
|
new->hfid_gog_gopstart = -1;
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
new->gop_index = NULL;
|
|
|
|
new->gog_index = NULL;
|
2005-02-06 20:37:02 +00:00
|
|
|
|
2005-02-20 02:21:04 +00:00
|
|
|
new->gop_as_subtree = NULL;
|
2005-02-06 20:37:02 +00:00
|
|
|
new->keys = NULL;
|
|
|
|
new->hfid_gog_num_of_gops = -1;
|
|
|
|
new->hfid_gog_gop = -1;
|
2004-12-31 14:27:38 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
return new;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* for cleaning hashes */
|
|
|
|
static gboolean free_both(gpointer k, gpointer v, gpointer p) {
|
|
|
|
g_free(k);
|
|
|
|
if (p) g_free(v);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void delete_mate_cfg_item(mate_cfg_item* cfg, gboolean avp_items_too) {
|
|
|
|
|
|
|
|
g_free(cfg->name);
|
|
|
|
|
|
|
|
if (avp_items_too) {
|
|
|
|
if (cfg->extra) delete_avpl(cfg->extra,TRUE);
|
|
|
|
if (cfg->start) delete_avpl(cfg->start,TRUE);
|
|
|
|
if (cfg->stop) delete_avpl(cfg->stop,TRUE);
|
|
|
|
if (cfg->key) delete_avpl(cfg->key,TRUE);
|
|
|
|
if (cfg->criterium) delete_avpl(cfg->criterium,TRUE);
|
|
|
|
if (cfg->keys) delete_loal(cfg->keys,TRUE,TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cfg->transforms) g_ptr_array_free(cfg->transforms,TRUE);
|
|
|
|
|
2005-02-18 22:33:16 +00:00
|
|
|
if (cfg->transport_ranges)
|
|
|
|
g_ptr_array_free(cfg->transport_ranges,TRUE);
|
|
|
|
|
|
|
|
if (cfg->payload_ranges)
|
|
|
|
g_ptr_array_free(cfg->payload_ranges,TRUE);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
if (cfg->hfids_attr)
|
|
|
|
g_hash_table_foreach_remove(cfg->hfids_attr,free_both, VALUE_TOO );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static mate_cfg_pdu* new_pducfg(guint8* name) {
|
|
|
|
mate_cfg_pdu* new = new_mate_cfg_item(name);
|
|
|
|
|
|
|
|
new->type = MATE_PDU_TYPE;
|
2005-02-18 22:33:16 +00:00
|
|
|
new->transport_ranges = g_ptr_array_new();
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
new->hfids_attr = g_hash_table_new(g_int_hash,g_int_equal);
|
|
|
|
|
|
|
|
g_ptr_array_add(matecfg->pducfglist,(gpointer) new);
|
|
|
|
|
|
|
|
g_hash_table_insert(matecfg->pducfgs,(gpointer) new->name,(gpointer) new);
|
|
|
|
|
|
|
|
return new;
|
|
|
|
}
|
|
|
|
|
|
|
|
static mate_cfg_gop* new_gopcfg(guint8* name) {
|
|
|
|
mate_cfg_gop* new = new_mate_cfg_item(name);
|
2005-02-06 20:37:02 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
new->type = MATE_GOP_TYPE;
|
2005-02-06 20:37:02 +00:00
|
|
|
new->expiration = matecfg->gop_expiration;
|
|
|
|
new->idle_timeout = matecfg->gop_idle_timeout;
|
|
|
|
new->lifetime = matecfg->gop_lifetime;
|
|
|
|
new->show_pdu_tree = matecfg->show_pdu_tree;
|
|
|
|
new->show_times = matecfg->show_times;
|
|
|
|
new->drop_gop = matecfg->drop_gop;
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
g_hash_table_insert(matecfg->gopcfgs,(gpointer) new->name, (gpointer) new);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
new->gop_index = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
new->gog_index = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
return new;
|
|
|
|
}
|
|
|
|
|
|
|
|
static mate_cfg_gog* new_gogcfg(guint8* name) {
|
|
|
|
mate_cfg_gog* new = new_mate_cfg_item(name);
|
|
|
|
new->type = MATE_GOG_TYPE;
|
|
|
|
|
|
|
|
new->keys = new_loal(name);
|
|
|
|
new->expiration = matecfg->gog_expiration;
|
2005-02-06 20:37:02 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
g_hash_table_insert(matecfg->gogcfgs,new->name,new);
|
|
|
|
|
|
|
|
return new;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean free_cfgs(gpointer k _U_, gpointer v, gpointer p) {
|
|
|
|
delete_mate_cfg_item((mate_cfg_item*)v,(gboolean) p);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
extern void destroy_mate_config(mate_config* mc , gboolean avplib_too) {
|
|
|
|
if (mc->dbg_facility) fclose(mc->dbg_facility);
|
|
|
|
if (mc->mate_lib_path) g_free(mc->mate_lib_path);
|
|
|
|
if (mc->mate_config_file) g_free(mc->mate_config_file);
|
|
|
|
if (mc->mate_attrs_filter) g_string_free(mc->mate_attrs_filter,TRUE);
|
|
|
|
if (mc->mate_protos_filter) g_string_free(mc->mate_protos_filter,TRUE);
|
|
|
|
if (mc->pducfglist) g_ptr_array_free(mc->pducfglist,FALSE);
|
|
|
|
|
|
|
|
if (mc->gogs_by_gopname) {
|
|
|
|
g_hash_table_destroy(mc->gogs_by_gopname);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mc->pducfgs) {
|
|
|
|
g_hash_table_foreach_remove(mc->pducfgs,free_cfgs,(gpointer) avplib_too);
|
|
|
|
g_hash_table_destroy(mc->pducfgs);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mc->gopcfgs) {
|
|
|
|
g_hash_table_foreach_remove(mc->gopcfgs,free_cfgs,(gpointer) avplib_too);
|
|
|
|
g_hash_table_destroy(mc->gopcfgs);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mc->gogcfgs) {
|
|
|
|
g_hash_table_foreach_remove(mc->gogcfgs,free_cfgs,(gpointer) avplib_too);
|
|
|
|
g_hash_table_destroy(mc->gogcfgs);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (mc->tap_filter) g_free(mc->tap_filter);
|
|
|
|
|
|
|
|
if (mc->hfrs) g_array_free(mc->hfrs,TRUE);
|
|
|
|
g_free(mc);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean mate_load_config(guint8* filename) {
|
|
|
|
LoAL* loal = loal_from_file(filename);
|
|
|
|
AVPL* avpl;
|
|
|
|
config_action* action;
|
|
|
|
guint8* name;
|
2005-01-07 18:07:18 +00:00
|
|
|
|
|
|
|
/* FIXME: we are leaking the config avpls to avoid unsubscribed strings left arround */
|
|
|
|
|
|
|
|
if (loal->len) {
|
|
|
|
while(( avpl = extract_first_avpl(loal) )) {
|
|
|
|
dbg_print (dbg_cfg,3,dbg_facility,"mate_make_config: current line: %s",avpl->name);
|
|
|
|
|
|
|
|
action = lookup_using_index_avp(avpl, KEYWORD_ACTION, actions,&name);
|
|
|
|
|
|
|
|
if (action) {
|
|
|
|
if ( ! action(avpl) ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Error on: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: action '%s' unknown in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
2005-01-07 18:07:18 +00:00
|
|
|
|
|
|
|
return TRUE;
|
2004-12-11 01:00:17 +00:00
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: error reading config file: %s",loal->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean add_hfid(guint8* what, guint8* how, GHashTable* where) {
|
|
|
|
header_field_info* hfi = NULL;
|
|
|
|
header_field_info* first_hfi = NULL;
|
|
|
|
gboolean exists = FALSE;
|
|
|
|
guint8* as;
|
|
|
|
guint8* h;
|
|
|
|
int* ip;
|
|
|
|
|
|
|
|
hfi = proto_registrar_get_byname(what);
|
|
|
|
|
|
|
|
while(hfi) {
|
|
|
|
first_hfi = hfi;
|
|
|
|
hfi = hfi->same_name_prev;
|
|
|
|
}
|
|
|
|
|
|
|
|
hfi = first_hfi;
|
|
|
|
|
|
|
|
while (hfi) {
|
|
|
|
exists = TRUE;
|
|
|
|
ip = g_malloc(sizeof(int));
|
|
|
|
|
|
|
|
*ip = hfi->id;
|
|
|
|
|
|
|
|
if (( as = g_hash_table_lookup(where,ip) )) {
|
|
|
|
g_free(ip);
|
|
|
|
if (! g_str_equal(as,how)) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE Error: add field to Pdu: attempt to add %s(%i) as %s"
|
2005-01-07 18:07:18 +00:00
|
|
|
" failed: field already added as '%s'",what,hfi->id,how,as);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
h = g_strdup(how);
|
|
|
|
g_hash_table_insert(where,ip,h);
|
|
|
|
|
|
|
|
|
|
|
|
dbg_print (dbg,5,dbg_facility,"add_hfid: added hfid %s(%i) as %s",what,*ip,how);
|
|
|
|
}
|
|
|
|
|
|
|
|
hfi = hfi->same_name_next;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! exists) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE Error: cannot find field %s",what);
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return exists;
|
|
|
|
}
|
|
|
|
|
2005-02-18 22:33:16 +00:00
|
|
|
static guint8* add_ranges(guint8* range,GPtrArray* range_ptr_arr) {
|
|
|
|
gchar** ranges;
|
|
|
|
guint i;
|
|
|
|
header_field_info* hfi;
|
|
|
|
int* hfidp;
|
|
|
|
|
|
|
|
ranges = g_strsplit(range,"/",0);
|
|
|
|
|
|
|
|
if (ranges) {
|
|
|
|
for (i=0; ranges[i]; i++) {
|
|
|
|
hfi = proto_registrar_get_byname(ranges[i]);
|
|
|
|
if (hfi) {
|
|
|
|
hfidp = g_malloc(sizeof(int));
|
|
|
|
*hfidp = hfi->id;
|
|
|
|
g_ptr_array_add(range_ptr_arr,(gpointer)hfidp);
|
|
|
|
g_string_sprintfa(matecfg->mate_attrs_filter, "||%s",ranges[i]);
|
|
|
|
} else {
|
|
|
|
g_strfreev(ranges);
|
|
|
|
return g_strdup_printf("no such proto: '%s'",ranges[i]);;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
g_strfreev(ranges);
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
static gboolean config_pdu(AVPL* avpl) {
|
|
|
|
guint8* name = NULL;
|
|
|
|
guint8* transport = extract_named_str(avpl,KEYWORD_TRANSPORT,NULL);
|
2005-02-18 22:33:16 +00:00
|
|
|
guint8* payload = extract_named_str(avpl,KEYWORD_PAYLOAD,NULL);
|
2004-12-11 01:00:17 +00:00
|
|
|
guint8* proto = extract_named_str(avpl,KEYWORD_PROTO,"no_protocol");
|
|
|
|
mate_cfg_pdu* cfg = lookup_using_index_avp(avpl,KEYWORD_NAME,matecfg->pducfgs,&name);
|
|
|
|
header_field_info* hfi;
|
2005-02-18 22:33:16 +00:00
|
|
|
guint8* range_err;
|
2004-12-11 01:00:17 +00:00
|
|
|
AVP* attr_avp;
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduDef: No Name in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (! cfg) {
|
|
|
|
cfg = new_pducfg(name);
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduDef: No such PDU: '%s' in: %s",cfg->name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->last_to_be_created = extract_named_bool(avpl,KEYWORD_STOP,matecfg->last_to_be_created);
|
|
|
|
cfg->discard_pdu_attributes = extract_named_bool(avpl,KEYWORD_DISCARDPDU,matecfg->discard_pdu_attributes);
|
|
|
|
cfg->drop_pdu = extract_named_bool(avpl,KEYWORD_DROPPDU,matecfg->drop_pdu);
|
|
|
|
|
|
|
|
hfi = proto_registrar_get_byname(proto);
|
|
|
|
|
|
|
|
if (hfi) {
|
|
|
|
cfg->hfid_proto = hfi->id;
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduDef: no such proto: '%s' in: %s",proto,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_string_sprintfa(matecfg->mate_protos_filter,"||%s",proto);
|
|
|
|
|
|
|
|
if ( transport ) {
|
2005-02-18 22:33:16 +00:00
|
|
|
if (( range_err = add_ranges(transport,cfg->transport_ranges) )) {
|
|
|
|
report_error("MATE: PduDef: %s in Transport for '%s' in: %s",range_err, cfg->name,avpl->name);
|
|
|
|
g_free(range_err);
|
|
|
|
return FALSE;
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduDef: no Transport for '%s' in: %s",cfg->name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2005-02-18 22:33:16 +00:00
|
|
|
if ( payload ) {
|
|
|
|
cfg->payload_ranges = g_ptr_array_new();
|
|
|
|
if (( range_err = add_ranges(payload,cfg->payload_ranges) )) {
|
|
|
|
report_error("MATE: PduDef: %s in Payload for '%s' in: %s",range_err, cfg->name,avpl->name);
|
|
|
|
g_free(range_err);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
while (( attr_avp = extract_first_avp(avpl) )) {
|
|
|
|
if ( ! add_hfid(attr_avp->v,attr_avp->n,cfg->hfids_attr) ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduDef: failed to set PDU attribute '%s' in: %s",attr_avp->n,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
g_string_sprintfa(matecfg->mate_attrs_filter, "||%s",attr_avp->v);
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_pduextra(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
AVP* attr_avp;
|
|
|
|
mate_cfg_pdu* cfg = lookup_using_index_avp(avpl,KEYWORD_FOR,matecfg->pducfgs,&name);
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduExtra: No For in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (! cfg) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduExtra: no such Pdu '%s' in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->last_to_be_created = extract_named_bool(avpl,KEYWORD_STOP,cfg->last_to_be_created);
|
|
|
|
cfg->discard_pdu_attributes = extract_named_bool(avpl,KEYWORD_DISCARDPDU,cfg->discard_pdu_attributes);
|
|
|
|
cfg->drop_pdu = extract_named_bool(avpl,KEYWORD_DROPPDU,cfg->drop_pdu);
|
|
|
|
|
|
|
|
while (( attr_avp = extract_first_avp(avpl) )) {
|
|
|
|
if ( ! add_hfid(attr_avp->v,attr_avp->n,cfg->hfids_attr) ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduExtra: failed to set attr '%s' in: %s",attr_avp->n,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
delete_avp(attr_avp);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
g_string_sprintfa(matecfg->mate_attrs_filter, "||%s",attr_avp->v);
|
|
|
|
}
|
|
|
|
|
|
|
|
delete_avpl(avpl,TRUE);
|
|
|
|
return TRUE;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-12-12 23:40:44 +00:00
|
|
|
static gboolean config_pducriteria(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
mate_cfg_gop* cfg = lookup_using_index_avp(avpl, KEYWORD_FOR,matecfg->pducfgs,&name);
|
|
|
|
guint8* match = extract_named_str(avpl, KEYWORD_MATCH, NULL);
|
|
|
|
avpl_match_mode match_mode = AVPL_STRICT;
|
|
|
|
guint8* mode = extract_named_str(avpl, KEYWORD_MODE, NULL);
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduCriteria: No For in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-12 23:40:44 +00:00
|
|
|
if (!cfg) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduCriteria: Pdu '%s' does not exist in: %s",name,avpl->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( mode ) {
|
|
|
|
if ( g_strcasecmp(mode,KEYWORD_ACCEPT) == 0 ) {
|
|
|
|
mode = matecfg->accept;
|
|
|
|
} else if ( g_strcasecmp(mode,KEYWORD_REJECT) == 0 ) {
|
|
|
|
mode = matecfg->reject;
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduCriteria: no such criteria mode: '%s' in %s",mode,avpl->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
mode = matecfg->accept;
|
|
|
|
}
|
|
|
|
|
|
|
|
rename_avpl(avpl,mode);
|
|
|
|
|
|
|
|
if ( match ) {
|
|
|
|
if ( g_strcasecmp(match,KEYWORD_LOOSE) == 0 ) {
|
|
|
|
match_mode = AVPL_LOOSE;
|
|
|
|
} else if ( g_strcasecmp(match,KEYWORD_EVERY) == 0 ) {
|
|
|
|
match_mode = AVPL_EVERY;
|
|
|
|
} else if ( g_strcasecmp(match,KEYWORD_STRICT) == 0 ) {
|
|
|
|
match_mode = AVPL_STRICT;
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduCriteria: Config error: no such match mode '%s' in: %s",match,avpl->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->criterium_match_mode = match_mode;
|
|
|
|
|
|
|
|
if (cfg->criterium) {
|
|
|
|
/* FEATURE: more criteria */
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: PduCriteria: PduCriteria alredy exists for '%s' in: %s",name,avpl->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
cfg->criterium = avpl;
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
static gboolean config_include(AVPL* avpl) {
|
|
|
|
guint8* filename = extract_named_str(avpl,KEYWORD_FILENAME,NULL);
|
2004-12-12 16:58:59 +00:00
|
|
|
guint8* lib = extract_named_str(avpl,KEYWORD_LIB,NULL);
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2004-12-12 16:58:59 +00:00
|
|
|
if ( ! filename && ! lib ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Include: no Filename or Lib given in: %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-12 16:58:59 +00:00
|
|
|
if ( filename && lib ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Include: use either Filename or Lib, not both. in: %s",avpl->name);
|
2004-12-12 16:58:59 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2004-12-12 16:58:59 +00:00
|
|
|
if (lib) {
|
|
|
|
filename = g_strdup_printf("%s%s.mate",matecfg->mate_lib_path,lib);
|
|
|
|
}
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
/* FIXME: stop recursion */
|
|
|
|
if ( ! mate_load_config(filename) ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Include: Error Loading '%s' in: %s",filename,avpl->name);
|
2004-12-12 16:58:59 +00:00
|
|
|
if (lib) g_free(filename);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2004-12-12 16:58:59 +00:00
|
|
|
if (lib) g_free(filename);
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static gboolean config_settings(AVPL*avpl) {
|
|
|
|
AVP* avp;
|
|
|
|
|
|
|
|
#ifdef _AVP_DEBUGGING
|
|
|
|
int debug_avp = 0;
|
|
|
|
int dbg_avp = 0;
|
|
|
|
int dbg_avp_op = 0;
|
|
|
|
int dbg_avpl = 0;
|
|
|
|
int dbg_avpl_op = 0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2005-01-06 23:21:10 +00:00
|
|
|
matecfg->gog_expiration = extract_named_float(avpl, KEYWORD_GOGEXPIRE,matecfg->gog_expiration);
|
2005-01-21 19:11:59 +00:00
|
|
|
matecfg->gop_expiration = extract_named_float(avpl, KEYWORD_GOPEXPIRATION,matecfg->gop_expiration);
|
|
|
|
matecfg->gop_idle_timeout = extract_named_float(avpl, KEYWORD_GOPIDLETIMEOUT,matecfg->gop_idle_timeout);
|
|
|
|
matecfg->gop_lifetime = extract_named_float(avpl, KEYWORD_GOPLIFETIME,matecfg->gop_lifetime);
|
2004-12-11 01:00:17 +00:00
|
|
|
matecfg->discard_pdu_attributes = extract_named_bool(avpl, KEYWORD_DISCARDPDU,matecfg->discard_pdu_attributes);
|
|
|
|
matecfg->drop_pdu = extract_named_bool(avpl, KEYWORD_DROPPDU,matecfg->drop_pdu);
|
|
|
|
matecfg->drop_gop = extract_named_bool(avpl, KEYWORD_DROPGOP,matecfg->drop_gop);
|
2005-01-06 12:39:54 +00:00
|
|
|
matecfg->show_pdu_tree = extract_named_str(avpl, KEYWORD_SHOWPDUTREE,matecfg->show_pdu_tree);
|
2004-12-31 14:27:38 +00:00
|
|
|
matecfg->show_times = extract_named_bool(avpl, KEYWORD_SHOWGOPTIMES,matecfg->show_times);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
if(( avp = extract_avp_by_name(avpl,KEYWORD_DEBUGFILENAME) )) {
|
|
|
|
matecfg->dbg_facility = dbg_facility = fopen(avp->v,"w");
|
|
|
|
delete_avp(avp);
|
|
|
|
avp = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
matecfg->dbg_lvl = extract_named_int(avpl, KEYWORD_DBG_GENERAL,0);
|
|
|
|
matecfg->dbg_cfg_lvl = extract_named_int(avpl, KEYWORD_DBG_CFG,0);
|
2005-02-18 22:33:16 +00:00
|
|
|
matecfg->dbg_pdu_lvl = extract_named_int(avpl, KEYWORD_DBG_PDU,0);
|
2004-12-11 01:00:17 +00:00
|
|
|
matecfg->dbg_gop_lvl = extract_named_int(avpl, KEYWORD_DBG_GOP,0);
|
|
|
|
matecfg->dbg_gog_lvl = extract_named_int(avpl, KEYWORD_DBG_GOG,0);
|
|
|
|
|
|
|
|
#ifdef _AVP_DEBUGGING
|
|
|
|
setup_avp_debug(dbg_facility,
|
|
|
|
extract_named_int(avpl, KEYWORD_DBG_AVPLIB,0),
|
|
|
|
extract_named_int(avpl, KEYWORD_DBG_AVP,0),
|
|
|
|
extract_named_int(avpl, KEYWORD_DBG_AVP_OP,0),
|
|
|
|
extract_named_int(avpl, KEYWORD_DBG_AVPL,0),
|
|
|
|
extract_named_int(avpl, KEYWORD_DBG_AVPL_OP,0));
|
|
|
|
#endif
|
|
|
|
|
|
|
|
dbg_cfg_lvl = matecfg->dbg_cfg_lvl;
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_transform(AVPL* avpl) {
|
|
|
|
guint8* name = extract_named_str(avpl, KEYWORD_NAME, NULL);
|
|
|
|
guint8* match = extract_named_str(avpl, KEYWORD_MATCH, NULL);
|
|
|
|
guint8* mode = extract_named_str(avpl, KEYWORD_MODE, NULL);
|
|
|
|
avpl_match_mode match_mode;
|
|
|
|
avpl_replace_mode replace_mode;
|
|
|
|
AVPL_Transf* t;
|
|
|
|
AVPL_Transf* last;
|
|
|
|
|
|
|
|
if ( match ) {
|
|
|
|
if ( g_strcasecmp(match,KEYWORD_LOOSE) == 0 ) {
|
|
|
|
match_mode = AVPL_LOOSE;
|
|
|
|
} else if ( g_strcasecmp(match,KEYWORD_EVERY) == 0 ) {
|
|
|
|
match_mode = AVPL_EVERY;
|
|
|
|
} else if ( g_strcasecmp(match,KEYWORD_STRICT) == 0 ) {
|
|
|
|
match_mode = AVPL_STRICT;
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Transform: no such match mode: '%s' in: %s",match,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
match_mode = matecfg->match_mode;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( mode ) {
|
|
|
|
if ( g_strcasecmp(mode,KEYWORD_INSERT) == 0 ) {
|
|
|
|
replace_mode = AVPL_INSERT;
|
|
|
|
} else if ( g_strcasecmp(mode,KEYWORD_REPLACE) == 0 ) {
|
|
|
|
replace_mode = AVPL_REPLACE;
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Transform: no such replace mode: '%s' in: %s",mode,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
replace_mode = matecfg->replace_mode;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! name) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: Transform: no Name in: %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
t = new_avpl_transform(name,avpl, match_mode, replace_mode);
|
|
|
|
|
|
|
|
if (( last = g_hash_table_lookup(matecfg->transfs,name) )) {
|
|
|
|
while (last->next) last = last->next;
|
|
|
|
last->next = t;
|
|
|
|
} else {
|
|
|
|
g_hash_table_insert(matecfg->transfs,t->name,t);
|
|
|
|
}
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_xxx_transform(AVPL* avpl, GHashTable* hash, guint8* keyword) {
|
2005-01-07 18:07:18 +00:00
|
|
|
guint8* cfg_name;
|
2004-12-11 01:00:17 +00:00
|
|
|
guint8* name;
|
|
|
|
AVPL_Transf* transf = lookup_using_index_avp(avpl,KEYWORD_NAME,matecfg->transfs,&name);
|
2005-01-07 18:07:18 +00:00
|
|
|
mate_cfg_pdu* cfg = lookup_using_index_avp(avpl,KEYWORD_FOR,hash,&cfg_name);;
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: %s: no Name in: %s",keyword,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! cfg_name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: %s: no For in: %s",keyword,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! cfg ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: %s: '%s' doesn't exist in: %s",keyword,cfg_name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!transf) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: %s: Transform '%s' doesn't exist in: %s",keyword,name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
g_ptr_array_add(cfg->transforms,transf);
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_pdu_transform(AVPL* avpl) {
|
|
|
|
return config_xxx_transform(avpl, matecfg->pducfgs, KEYWORD_PDUTRANSFORM);
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gop_transform(AVPL* avpl) {
|
|
|
|
return config_xxx_transform(avpl, matecfg->gopcfgs, KEYWORD_GOPTRANSFORM);
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gog_transform(AVPL* avpl) {
|
|
|
|
return config_xxx_transform(avpl, matecfg->gogcfgs, KEYWORD_GOPTRANSFORM);
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gop(AVPL* avpl) {
|
|
|
|
guint8* name = NULL;
|
|
|
|
mate_cfg_gop* cfg = lookup_using_index_avp(avpl, KEYWORD_NAME,matecfg->gopcfgs,&name);
|
|
|
|
guint8* on = extract_named_str(avpl,KEYWORD_ON,NULL);
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopDef: no Name in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (!cfg) {
|
|
|
|
cfg = new_gopcfg(name);
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopDef: Gop '%s' exists already in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! on ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopDef: no On in: %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
2005-02-18 18:40:25 +00:00
|
|
|
|
|
|
|
if (g_hash_table_lookup(matecfg->pducfgs,on) == NULL ) {
|
|
|
|
report_error("MATE: GopDef: Pdu '%s' does not exist in: %s",on,avpl->name);
|
|
|
|
return FALSE;
|
|
|
|
}
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
if (g_hash_table_lookup(matecfg->gops_by_pduname,on) ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopDef: Gop for Pdu '%s' exists already in: %s",on,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
} else {
|
|
|
|
g_hash_table_insert(matecfg->gops_by_pduname,on,cfg);
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->drop_gop = extract_named_bool(avpl, KEYWORD_DROPGOP,matecfg->drop_gop);
|
2005-01-06 12:39:54 +00:00
|
|
|
cfg->show_pdu_tree = extract_named_str(avpl, KEYWORD_SHOWPDUTREE, matecfg->show_pdu_tree);
|
2004-12-31 14:27:38 +00:00
|
|
|
cfg->show_times = extract_named_bool(avpl, KEYWORD_SHOWGOPTIMES,matecfg->show_times);
|
2005-01-21 19:11:59 +00:00
|
|
|
cfg->expiration = extract_named_float(avpl, KEYWORD_GOPEXPIRATION,matecfg->gop_expiration);
|
|
|
|
cfg->idle_timeout = extract_named_float(avpl, KEYWORD_GOPIDLETIMEOUT,matecfg->gop_idle_timeout);
|
|
|
|
cfg->lifetime = extract_named_float(avpl, KEYWORD_GOPLIFETIME,matecfg->gop_lifetime);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
cfg->key = avpl;
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_start(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
mate_cfg_gop* cfg = lookup_using_index_avp(avpl, KEYWORD_FOR,matecfg->gopcfgs,&name);;
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopStart: no For in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (!cfg) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopStart: Gop '%s' doesn't exist in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cfg->start) {
|
|
|
|
/* FEATURE: more start conditions */
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopStart: GopStart for '%s' exists already in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->start = avpl;
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_stop(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
mate_cfg_gop* cfg = lookup_using_index_avp(avpl, KEYWORD_FOR,matecfg->gopcfgs,&name);;
|
2005-01-07 18:07:18 +00:00
|
|
|
|
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopStop: no For in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (!cfg) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopStop: Gop '%s' doesn't exist in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cfg->stop) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopStop: GopStop alredy exists for '%s' in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->stop = avpl;
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gopextra(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
mate_cfg_gop* cfg = lookup_using_index_avp(avpl, KEYWORD_FOR,matecfg->gopcfgs,&name);;
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopExtra: no For in: %s",avpl->name);
|
2005-01-07 18:07:18 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (!cfg) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GopExtra: Gop '%s' does not exist in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->drop_gop = extract_named_bool(avpl, KEYWORD_DROPGOP,cfg->drop_gop);
|
2005-01-06 12:39:54 +00:00
|
|
|
cfg->show_pdu_tree = extract_named_str(avpl, KEYWORD_SHOWPDUTREE, cfg->show_pdu_tree);
|
2004-12-31 14:27:38 +00:00
|
|
|
cfg->show_times = extract_named_bool(avpl, KEYWORD_SHOWGOPTIMES,cfg->show_times);
|
2005-01-21 19:11:59 +00:00
|
|
|
cfg->expiration = extract_named_float(avpl, KEYWORD_GOPEXPIRATION,cfg->expiration);
|
|
|
|
cfg->idle_timeout = extract_named_float(avpl, KEYWORD_GOPIDLETIMEOUT,cfg->idle_timeout);
|
|
|
|
cfg->lifetime = extract_named_float(avpl, KEYWORD_GOPLIFETIME,cfg->lifetime);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
merge_avpl(cfg->extra,avpl,TRUE);
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gog(AVPL* avpl) {
|
|
|
|
guint8* name = extract_named_str(avpl, KEYWORD_NAME,NULL);
|
|
|
|
mate_cfg_gog* cfg = NULL;
|
|
|
|
|
2005-01-07 18:07:18 +00:00
|
|
|
if (! name ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GogDef: no Name in: %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
2005-01-07 18:07:18 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if ( g_hash_table_lookup(matecfg->gogcfgs,name) ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GogDef: Gog '%s' exists already in: %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg = new_gogcfg(name);
|
|
|
|
|
|
|
|
cfg->expiration = extract_named_float(avpl, KEYWORD_GOGEXPIRE,matecfg->gog_expiration);
|
2005-02-20 02:21:04 +00:00
|
|
|
cfg->gop_as_subtree = extract_named_str(avpl, KEYWORD_GOPTREE,matecfg->gop_as_subtree);
|
2005-01-06 12:39:54 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gogkey(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
mate_cfg_gog* cfg = lookup_using_index_avp(avpl, KEYWORD_FOR,matecfg->gogcfgs,&name);
|
|
|
|
AVPL* reverse_avpl;
|
|
|
|
LoAL* gogkeys;
|
|
|
|
guint8* on = extract_named_str(avpl,KEYWORD_ON,NULL);
|
|
|
|
|
|
|
|
if ( ! name || ! cfg ) {
|
|
|
|
if ( ! name )
|
2005-02-18 18:40:25 +00:00
|
|
|
report_error("MATE: GogKey: no For in %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
else
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GogKey: no such Gop '%s' in %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (! on ) {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GogKey: no On in %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2005-02-19 03:10:50 +00:00
|
|
|
if (! g_hash_table_lookup(matecfg->gopcfgs,on) ) {
|
|
|
|
report_error("MATE: GogKey: no such Gop %s in On",on);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
rename_avpl(avpl,name);
|
|
|
|
|
|
|
|
gogkeys = (LoAL*) g_hash_table_lookup(matecfg->gogs_by_gopname,on);
|
|
|
|
|
|
|
|
if (! gogkeys) {
|
|
|
|
gogkeys = new_loal("straight");
|
|
|
|
g_hash_table_insert(matecfg->gogs_by_gopname,g_strdup(on),gogkeys);
|
|
|
|
}
|
|
|
|
|
|
|
|
loal_append(gogkeys,avpl);
|
|
|
|
|
|
|
|
reverse_avpl = new_avpl_from_avpl(on,avpl,TRUE);
|
|
|
|
|
|
|
|
loal_append(cfg->keys,reverse_avpl);
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
static gboolean config_gogextra(AVPL* avpl) {
|
|
|
|
guint8* name;
|
|
|
|
mate_cfg_gop* cfg = lookup_using_index_avp(avpl, KEYWORD_FOR,matecfg->gogcfgs,&name);
|
|
|
|
|
|
|
|
if ( ! name || ! cfg ) {
|
|
|
|
if ( ! name )
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GogExtra: no Name in %s",avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
else
|
2005-01-10 02:37:19 +00:00
|
|
|
report_error("MATE: GogExtra: no such Gop '%s' in %s",name,avpl->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
cfg->expiration = extract_named_float(avpl, KEYWORD_GOGEXPIRE,cfg->expiration);
|
2005-02-20 02:21:04 +00:00
|
|
|
cfg->gop_as_subtree = extract_named_str(avpl, KEYWORD_GOPTREE,cfg->gop_as_subtree);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
merge_avpl(cfg->extra,avpl,TRUE);
|
|
|
|
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2005-01-21 19:11:59 +00:00
|
|
|
#define true_false_str(v) ((v) ? "TRUE" : "FALSE")
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
static void print_xxx_transforms(mate_cfg_item* cfg) {
|
|
|
|
guint8* tr_name;
|
|
|
|
guint8* cfg_name;
|
|
|
|
guint i;
|
|
|
|
|
|
|
|
switch (cfg->type) {
|
|
|
|
case MATE_PDU_TYPE:
|
|
|
|
cfg_name = "PduTransform";
|
|
|
|
break;
|
|
|
|
case MATE_GOP_TYPE:
|
|
|
|
cfg_name = "GopTransform";
|
|
|
|
break;
|
|
|
|
case MATE_GOG_TYPE:
|
|
|
|
cfg_name = "GogTransform";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
cfg_name = "UnknownTransform";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i=0; i < cfg->transforms->len; i++) {
|
|
|
|
tr_name = ((AVPL_Transf*) g_ptr_array_index(cfg->transforms,i))->name;
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=%s; For=%s; Name=%s;",cfg_name,cfg->name,tr_name);
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void print_gog_config(gpointer k _U_, gpointer v, gpointer p _U_) {
|
|
|
|
mate_cfg_gop* cfg = (mate_cfg_gop*) v;
|
|
|
|
guint8* avplstr = NULL;
|
|
|
|
void* cookie = NULL;
|
|
|
|
AVPL* avpl;
|
|
|
|
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=GogDef; Name=%s; Expiration=%f;",cfg->name,cfg->expiration);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
if (cfg->keys) {
|
|
|
|
while (( avpl = get_next_avpl(cfg->keys,&cookie) )) {
|
|
|
|
avplstr = avpl_to_str(avpl);
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=GogKey; For=%s; On=%s; %s",cfg->name,avpl->name,avplstr);
|
2004-12-11 01:00:17 +00:00
|
|
|
g_free(avplstr);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cfg->extra) {
|
|
|
|
avplstr = avpl_to_str(cfg->extra);
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=GogExtra; For=%s; %s",cfg->name,avplstr);
|
2004-12-11 01:00:17 +00:00
|
|
|
g_free(avplstr);
|
|
|
|
}
|
|
|
|
|
|
|
|
print_xxx_transforms(cfg);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void print_gop_config(gpointer k _U_ , gpointer v, gpointer p _U_) {
|
|
|
|
mate_cfg_gop* cfg = (mate_cfg_gop*) v;
|
|
|
|
guint8* avplstr = NULL;
|
|
|
|
guint8* show_pdu_tree;
|
|
|
|
GString* gopdef;
|
|
|
|
|
|
|
|
gopdef = g_string_new("Action=GopDef; ");
|
|
|
|
|
|
|
|
show_pdu_tree = cfg->show_pdu_tree ? "TRUE" : "FALSE";
|
2005-01-21 19:11:59 +00:00
|
|
|
g_string_sprintfa(gopdef,"Name=%s; ShowPduTree=%s; ShowGopTimes=%s; "
|
|
|
|
"GopExpiration=%f; GopIdleTimeout=%f GopLifetime=%f;",
|
|
|
|
cfg->name,show_pdu_tree,true_false_str(cfg->show_times),
|
|
|
|
cfg->expiration,cfg->idle_timeout,cfg->lifetime);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
if (cfg->key) {
|
|
|
|
avplstr = avpl_to_str(cfg->key);
|
|
|
|
g_string_sprintfa(gopdef," %s",avplstr);
|
|
|
|
g_free(avplstr);
|
|
|
|
}
|
|
|
|
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"%s",gopdef->str);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
|
|
|
|
if (cfg->start) {
|
|
|
|
avplstr = avpl_to_str(cfg->start);
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=GopStart; For=%s; %s",cfg->name,avplstr);
|
2004-12-11 01:00:17 +00:00
|
|
|
g_free(avplstr);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cfg->stop) {
|
|
|
|
avplstr = avpl_to_str(cfg->stop);
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=GopStop; For=%s; %s",cfg->name,avplstr);
|
2004-12-11 01:00:17 +00:00
|
|
|
g_free(avplstr);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cfg->extra) {
|
|
|
|
avplstr = avpl_to_str(cfg->extra);
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg_cfg,0,dbg_facility,"Action=GopExtra; For=%s; %s",cfg->name,avplstr);
|
2004-12-11 01:00:17 +00:00
|
|
|
g_free(avplstr);
|
|
|
|
}
|
|
|
|
|
|
|
|
print_xxx_transforms(cfg);
|
|
|
|
|
|
|
|
g_string_free(gopdef,TRUE);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static guint8* my_protoname(int proto_id) {
|
|
|
|
if (proto_id) {
|
|
|
|
return proto_registrar_get_abbrev(proto_id);
|
|
|
|
} else {
|
|
|
|
return "*";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void print_hfid_hash(gpointer k, gpointer v, gpointer p _U_) {
|
|
|
|
g_string_sprintfa((GString*)p," %s=%s;",(guint8*)v,my_protoname(*(int*)k));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void print_transforms(gpointer k, gpointer v, gpointer p _U_) {
|
|
|
|
AVPL_Transf* t = NULL;
|
|
|
|
guint8* match;
|
|
|
|
guint8* mode;
|
|
|
|
guint8* match_s;
|
|
|
|
guint8* replace_s;
|
|
|
|
|
|
|
|
for (t = v; t; t = t->next) {
|
|
|
|
match_s = avpl_to_str(t->match);
|
|
|
|
replace_s = avpl_to_dotstr(t->replace);
|
|
|
|
|
|
|
|
switch (t->match_mode) {
|
|
|
|
case AVPL_STRICT:
|
|
|
|
match = "Strict";
|
|
|
|
break;
|
|
|
|
case AVPL_LOOSE:
|
|
|
|
match = "Loose";
|
|
|
|
break;
|
|
|
|
case AVPL_EVERY:
|
|
|
|
match = "Every";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
match = "None";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
switch (t->replace_mode) {
|
|
|
|
case AVPL_INSERT:
|
|
|
|
mode = "Insert";
|
|
|
|
break;
|
|
|
|
case AVPL_REPLACE:
|
|
|
|
mode = "Replace";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
mode = "None";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print (dbg,0,dbg_facility,"\tAction=Transform; Name=%s; Match=%s; Mode=%s; %s %s",(guint8*) k,match,mode,match_s,replace_s);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
g_free(match_s);
|
|
|
|
g_free(replace_s);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void print_pdu_config(mate_cfg_pdu* cfg) {
|
|
|
|
guint i;
|
|
|
|
int hfid;
|
|
|
|
guint8* discard;
|
|
|
|
guint8* stop;
|
2004-12-12 23:40:44 +00:00
|
|
|
guint8* criterium_match = NULL;
|
|
|
|
guint8* criterium;
|
2004-12-11 01:00:17 +00:00
|
|
|
GString* s = g_string_new("Action=PduDef; ");
|
|
|
|
|
|
|
|
discard = cfg->discard_pdu_attributes ? "TRUE": "FALSE";
|
|
|
|
stop = cfg->last_to_be_created ? "TRUE" : "FALSE";
|
|
|
|
|
|
|
|
g_string_sprintfa(s, "Name=%s; Proto=%s; DiscartAttribs=%s; Stop=%s; Transport=",
|
|
|
|
cfg->name,my_protoname(cfg->hfid_proto),discard,stop);
|
|
|
|
|
2005-02-18 22:33:16 +00:00
|
|
|
for (i = 0; i < cfg->transport_ranges->len; i++) {
|
|
|
|
hfid = *((int*) g_ptr_array_index(cfg->transport_ranges,i));
|
2004-12-11 01:00:17 +00:00
|
|
|
g_string_sprintfa(s,"%s/",my_protoname(hfid));
|
|
|
|
}
|
|
|
|
|
|
|
|
*(s->str + s->len - 1) = ';';
|
|
|
|
|
2005-02-22 02:16:35 +00:00
|
|
|
if (cfg->payload_ranges) {
|
2005-02-18 22:33:16 +00:00
|
|
|
g_string_sprintfa(s, " Payload=");
|
|
|
|
|
|
|
|
for (i = 0; i < cfg->payload_ranges->len; i++) {
|
|
|
|
hfid = *((int*) g_ptr_array_index(cfg->payload_ranges,i));
|
|
|
|
g_string_sprintfa(s,"%s/",my_protoname(hfid));
|
|
|
|
}
|
|
|
|
|
|
|
|
*(s->str + s->len - 1) = ';';
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
g_hash_table_foreach(cfg->hfids_attr,print_hfid_hash,s);
|
|
|
|
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"%s",s->str);
|
|
|
|
|
2004-12-12 23:40:44 +00:00
|
|
|
if (cfg->criterium) {
|
|
|
|
switch(cfg->criterium_match_mode) {
|
|
|
|
case AVPL_NO_MATCH:
|
|
|
|
criterium_match = "None";
|
|
|
|
break;
|
|
|
|
case AVPL_STRICT:
|
|
|
|
criterium_match = "Strict";
|
|
|
|
break;
|
|
|
|
case AVPL_LOOSE:
|
|
|
|
criterium_match = "Loose";
|
|
|
|
break;
|
|
|
|
case AVPL_EVERY:
|
|
|
|
criterium_match = "Every";
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
criterium = avpl_to_str(cfg->criterium);
|
|
|
|
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,
|
|
|
|
"Action=PduCriteria; For=%s; Match=%s; Mode=%s; %s",
|
|
|
|
cfg->name,criterium_match,cfg->criterium->name,criterium);
|
|
|
|
|
|
|
|
g_free(criterium);
|
|
|
|
}
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
print_xxx_transforms(cfg);
|
|
|
|
|
|
|
|
g_string_free(s,TRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
static void print_gogs_by_gopname(gpointer k, gpointer v, gpointer p _U_) {
|
|
|
|
void* cookie = NULL;
|
|
|
|
guint8* str = NULL;
|
|
|
|
AVPL* avpl;
|
|
|
|
|
|
|
|
while(( avpl = get_next_avpl((LoAL*)v,&cookie) )) {
|
|
|
|
str = avpl_to_str(avpl);
|
2005-02-06 20:37:02 +00:00
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"Gop=%s; Gog=%s; --> %s",(guint8*)k,avpl->name,str);
|
2004-12-11 01:00:17 +00:00
|
|
|
g_free(str);
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void print_gops_by_pduname(gpointer k, gpointer v, gpointer p _U_) {
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,
|
2005-02-06 20:37:02 +00:00
|
|
|
"PduName=%s; GopName=%s;", (guint8*)k,((mate_cfg_gop*)v)->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
|
2005-02-04 00:22:00 +00:00
|
|
|
static void print_config(void) {
|
2004-12-11 01:00:17 +00:00
|
|
|
guint i;
|
|
|
|
|
|
|
|
/* FIXME: print the settings */
|
|
|
|
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"###########################"
|
|
|
|
" CURRENT CONFIGURATION " "###########################");
|
|
|
|
|
|
|
|
g_hash_table_foreach(matecfg->transfs,print_transforms,NULL);
|
|
|
|
|
|
|
|
for (i=0; i<matecfg->pducfglist->len; i++) {
|
|
|
|
print_pdu_config((mate_cfg_pdu*) g_ptr_array_index(matecfg->pducfglist,i));
|
|
|
|
}
|
|
|
|
|
|
|
|
g_hash_table_foreach(matecfg->gopcfgs,print_gop_config,NULL);
|
|
|
|
g_hash_table_foreach(matecfg->gogcfgs,print_gog_config,NULL);
|
|
|
|
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"###########################"
|
|
|
|
" END OF CURRENT CONFIGURATION " "###########################");
|
|
|
|
|
|
|
|
if (*dbg_cfg > 1) {
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"******* Config Hashes");
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"*** Gops by PduName");
|
|
|
|
g_hash_table_foreach(matecfg->gops_by_pduname,print_gops_by_pduname,NULL);
|
|
|
|
dbg_print(dbg_cfg,0,dbg_facility,"*** GogKeys by GopName");
|
|
|
|
g_hash_table_foreach(matecfg->gogs_by_gopname,print_gogs_by_gopname,NULL);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void new_attr_hfri(mate_cfg_item* cfg, guint8* name) {
|
|
|
|
int* p_id = g_malloc(sizeof(int));
|
|
|
|
|
2005-02-04 00:22:00 +00:00
|
|
|
hf_register_info hfri;
|
|
|
|
|
2005-02-04 10:32:28 +00:00
|
|
|
memset(&hfri, 0, sizeof hfri);
|
2005-02-04 00:22:00 +00:00
|
|
|
hfri.p_id = p_id;
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s",name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.%s",cfg->name,name);
|
|
|
|
hfri.hfinfo.type = FT_STRING;
|
|
|
|
hfri.hfinfo.display = BASE_NONE;
|
|
|
|
hfri.hfinfo.strings = NULL;
|
|
|
|
hfri.hfinfo.bitmask = 0;
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("%s attribute of %s",name,cfg->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
*p_id = -1;
|
|
|
|
g_hash_table_insert(cfg->my_hfids,name,p_id);
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2004-12-12 16:58:59 +00:00
|
|
|
static void analyze_pdu_hfids(gpointer k _U_, gpointer v, gpointer p) {
|
2004-12-11 01:00:17 +00:00
|
|
|
new_attr_hfri((mate_cfg_pdu*) p,(guint8*) v);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void analyze_transform_hfrs(mate_cfg_item* cfg) {
|
|
|
|
guint i;
|
|
|
|
void* cookie = NULL;
|
|
|
|
AVPL_Transf* t;
|
|
|
|
AVP* avp;
|
|
|
|
|
|
|
|
for (i=0; i < cfg->transforms->len;i++) {
|
|
|
|
for (t = g_ptr_array_index(cfg->transforms,i); t; t=t->next ) {
|
|
|
|
cookie = NULL;
|
|
|
|
while(( avp = get_next_avp(t->replace,&cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void analyze_pdu_config(mate_cfg_pdu* cfg) {
|
|
|
|
hf_register_info hfri = { NULL, {NULL, NULL, FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL}};
|
2004-12-16 19:36:23 +00:00
|
|
|
gint* ett;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s",cfg->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s",cfg->name);
|
2004-12-12 16:58:59 +00:00
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("%s id",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_UINT32;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
2004-12-23 08:27:30 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_pdu_rel_time);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s time",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.RelativeTime",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_FLOAT;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
2004-12-23 08:27:30 +00:00
|
|
|
hfri.hfinfo.blurb = "Seconds passed since the start of capture";
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
2004-12-23 08:27:30 +00:00
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid_pdu_time_in_gop);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s time since begining of Gop",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.TimeInGop",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_FLOAT;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
|
|
|
hfri.hfinfo.blurb = "Seconds passed since the start of the GOP";
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
g_hash_table_foreach(cfg->hfids_attr,analyze_pdu_hfids,cfg);
|
|
|
|
|
2004-12-16 19:36:23 +00:00
|
|
|
ett = &cfg->ett;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
|
|
|
ett = &cfg->ett_attr;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
analyze_transform_hfrs(cfg);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void analyze_gop_config(gpointer k _U_, gpointer v, gpointer p _U_) {
|
|
|
|
mate_cfg_gop* cfg = v;
|
|
|
|
void* cookie = NULL;
|
|
|
|
AVP* avp;
|
2004-12-16 19:36:23 +00:00
|
|
|
gint* ett;
|
2004-12-11 01:00:17 +00:00
|
|
|
hf_register_info hfri = { NULL, {NULL, NULL, FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL}};
|
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s",cfg->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s",cfg->name);
|
2004-12-12 16:58:59 +00:00
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("%s id",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_UINT32;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_start_time);
|
2004-12-11 01:00:17 +00:00
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s start time",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.StartTime",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_FLOAT;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Seconds passed since the begining of caputre to the start of this %s",cfg->name);
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_stop_time);
|
2004-12-11 01:00:17 +00:00
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s hold time",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.Time",cfg->name);
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Duration in seconds from start to stop of this %s",cfg->name);
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_last_time);
|
2004-12-23 08:27:30 +00:00
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s duration",cfg->name);
|
2004-12-11 01:00:17 +00:00
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.Duration",cfg->name);
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Time passed between the start of this %s and the last pdu assigned to it",cfg->name);
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid_gop_num_pdus);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s number of PDUs",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.NumOfPdus",cfg->name);
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Number of PDUs assigned to this %s",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_UINT32;
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid_gop_pdu);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("A PDU of %s",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.Pdu",cfg->name);
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("A PDU assigned to this %s",cfg->name);
|
|
|
|
|
2005-01-06 12:39:54 +00:00
|
|
|
if (cfg->show_pdu_tree == matecfg->frame_tree) {
|
|
|
|
hfri.hfinfo.type = FT_FRAMENUM;
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
} else if (cfg->show_pdu_tree == matecfg->pdu_tree) {
|
|
|
|
hfri.hfinfo.type = FT_UINT32;
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
} else {
|
|
|
|
cfg->show_pdu_tree = matecfg->no_tree;
|
|
|
|
}
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
while(( avp = get_next_avp(cfg->key,&cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-02-06 20:37:02 +00:00
|
|
|
if(cfg->start) {
|
|
|
|
cookie = NULL;
|
|
|
|
while(( avp = get_next_avp(cfg->start,&cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
|
|
|
}
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
}
|
2005-02-06 20:37:02 +00:00
|
|
|
|
2005-01-06 12:39:54 +00:00
|
|
|
if (cfg->stop) {
|
|
|
|
cookie = NULL;
|
|
|
|
while(( avp = get_next_avp(cfg->stop,&cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
|
|
|
}
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
}
|
2005-01-06 12:39:54 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
cookie = NULL;
|
|
|
|
while(( avp = get_next_avp(cfg->extra,&cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
analyze_transform_hfrs(cfg);
|
2004-12-16 19:36:23 +00:00
|
|
|
|
|
|
|
ett = &cfg->ett;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
|
|
|
ett = &cfg->ett_attr;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
|
|
|
ett = &cfg->ett_times;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
|
|
|
ett = &cfg->ett_children;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void analyze_gog_config(gpointer k _U_, gpointer v, gpointer p _U_) {
|
|
|
|
mate_cfg_gop* cfg = v;
|
|
|
|
void* avp_cookie;
|
|
|
|
void* avpl_cookie;
|
|
|
|
AVP* avp;
|
|
|
|
AVPL* avpl;
|
2004-12-31 14:27:38 +00:00
|
|
|
AVPL* key_avps;
|
2004-12-11 01:00:17 +00:00
|
|
|
hf_register_info hfri = { NULL, {NULL, NULL, FT_STRING, BASE_NONE, NULL, 0, NULL, HFILL}};
|
2004-12-16 19:36:23 +00:00
|
|
|
gint* ett;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s",cfg->name);
|
2004-12-12 23:40:44 +00:00
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s",cfg->name);
|
2004-12-12 16:58:59 +00:00
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("%s Id",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_UINT32;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
2004-12-31 14:27:38 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_gog_num_of_gops);
|
|
|
|
hfri.hfinfo.name = "number of GOPs";
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.NumOfGops",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_UINT32;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Number of GOPs assigned to this %s",cfg->name);
|
2004-12-31 14:27:38 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
2004-12-31 14:27:38 +00:00
|
|
|
|
2005-02-18 20:02:40 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_gog_gopstart);
|
|
|
|
hfri.hfinfo.name = "GopStart frame";
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.GopStart",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_FRAMENUM;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
|
|
|
hfri.hfinfo.blurb = g_strdup("The start frame of a GOP");
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2005-02-20 02:21:04 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_gog_gopstop);
|
|
|
|
hfri.hfinfo.name = "GopStop frame";
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.GopStop",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_FRAMENUM;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
|
|
|
hfri.hfinfo.blurb = g_strdup("The stop frame of a GOP");
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_start_time);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s start time",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.StartTime",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_FLOAT;
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Seconds passed since the begining of caputre to the start of this %s",cfg->name);
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
|
|
|
hfri.p_id = &(cfg->hfid_last_time);
|
|
|
|
hfri.hfinfo.name = g_strdup_printf("%s duration",cfg->name);
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.Duration",cfg->name);
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("Time passed between the start of this %s and the last pdu assigned to it",cfg->name);
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
|
|
|
/* this might become mate.gogname.gopname */
|
2004-12-11 01:00:17 +00:00
|
|
|
hfri.p_id = &(cfg->hfid_gog_gop);
|
|
|
|
hfri.hfinfo.name = "a GOP";
|
|
|
|
hfri.hfinfo.abbrev = g_strdup_printf("mate.%s.Gop",cfg->name);
|
|
|
|
hfri.hfinfo.type = FT_STRING;
|
|
|
|
hfri.hfinfo.display = BASE_DEC;
|
|
|
|
hfri.hfinfo.blurb = g_strdup_printf("a GOPs assigned to this %s",cfg->name);
|
|
|
|
|
|
|
|
g_array_append_val(matecfg->hfrs,hfri);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
key_avps = new_avpl("");
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
avpl_cookie = NULL;
|
|
|
|
while (( avpl = get_next_avpl(cfg->keys,&avpl_cookie) )) {
|
|
|
|
avp_cookie = NULL;
|
|
|
|
while (( avp = get_next_avp(avpl,&avp_cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
2004-12-31 14:27:38 +00:00
|
|
|
insert_avp(key_avps,avp);
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
avp_cookie = NULL;
|
|
|
|
while (( avp = get_next_avp(cfg->extra,&avp_cookie) )) {
|
|
|
|
if (! g_hash_table_lookup(cfg->my_hfids,avp->n)) {
|
|
|
|
new_attr_hfri(cfg,avp->n);
|
|
|
|
}
|
|
|
|
}
|
2004-12-31 14:27:38 +00:00
|
|
|
|
|
|
|
merge_avpl(cfg->extra,key_avps,TRUE);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
analyze_transform_hfrs(cfg);
|
2004-12-16 19:36:23 +00:00
|
|
|
|
|
|
|
ett = &cfg->ett;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
|
|
|
ett = &cfg->ett_attr;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
|
|
|
ett = &cfg->ett_children;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
2004-12-31 14:27:38 +00:00
|
|
|
ett = &cfg->ett_times;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
2005-02-18 20:02:40 +00:00
|
|
|
ett = &cfg->ett_gog_gop;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
}
|
|
|
|
|
2005-02-04 00:22:00 +00:00
|
|
|
static void analyze_config(void) {
|
2004-12-11 01:00:17 +00:00
|
|
|
guint i;
|
|
|
|
|
|
|
|
for (i=0; i<matecfg->pducfglist->len; i++) {
|
|
|
|
analyze_pdu_config((mate_cfg_pdu*) g_ptr_array_index(matecfg->pducfglist,i));
|
|
|
|
}
|
|
|
|
|
|
|
|
g_hash_table_foreach(matecfg->gopcfgs,analyze_gop_config,matecfg);
|
|
|
|
g_hash_table_foreach(matecfg->gogcfgs,analyze_gog_config,matecfg);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
static void new_action(guint8* name, config_action* action) {
|
|
|
|
g_hash_table_insert(actions,name,action);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2005-02-04 00:22:00 +00:00
|
|
|
static void init_actions(void) {
|
2004-12-12 23:40:44 +00:00
|
|
|
AVP* avp;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
all_keywords = new_avpl("all_keywords");
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_ACTION,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_SETTINGS,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_INCLUDE,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_TRANSFORM,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_PDU,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_PDUCRITERIA,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_PDUEXTRA,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_PDUTRANSFORM,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOPSTART,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOPSTOP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOPEXTRA,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOPTRANSFORM,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOGDEF,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOGKEY,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOGEXTRA,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOGTRANSFORM,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_NAME,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_ON,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_FOR,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_FROM,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_TO,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_MATCH,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_MODE,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_FILENAME,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_PROTO,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_METHOD,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_TRANSPORT,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_METHOD,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_STRICT,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_LOOSE,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_EVERY,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_REPLACE,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_INSERT,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_MAP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_GOGEXPIRE,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DISCARDPDU,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_LIBPATH,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_SHOWPDUTREE,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_SHOWGOPTIMES,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_STOP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DROPPDU,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DROPGOP,"",'='));
|
2004-12-12 16:58:59 +00:00
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_LIB,"",'='));
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_GENERAL,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_CFG,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_PDU,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_GOP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_GOG,"",'='));
|
|
|
|
|
|
|
|
#ifdef _AVP_DEBUGGING
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_AVPLIB,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_AVP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_AVP_OP,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_AVPL,"",'='));
|
|
|
|
insert_avp(all_keywords,new_avp(KEYWORD_DBG_AVPL_OP,"",'='));
|
|
|
|
#endif
|
|
|
|
|
2004-12-12 23:40:44 +00:00
|
|
|
avp = new_avp(KEYWORD_ACCEPT,"",'=');
|
|
|
|
matecfg->accept = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
|
|
|
|
|
|
|
avp = new_avp(KEYWORD_REJECT,"",'=');
|
|
|
|
matecfg->reject = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
|
|
|
|
2005-01-06 12:39:54 +00:00
|
|
|
avp = new_avp(KEYWORD_NOTREE,"",'=');
|
|
|
|
matecfg->no_tree = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
2004-12-12 23:40:44 +00:00
|
|
|
|
2005-01-06 12:39:54 +00:00
|
|
|
avp = new_avp(KEYWORD_FRAMETREE,"",'=');
|
|
|
|
matecfg->frame_tree = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
|
|
|
|
|
|
|
avp = new_avp(KEYWORD_PDUTREE,"",'=');
|
|
|
|
matecfg->pdu_tree = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
|
|
|
|
2005-02-20 02:21:04 +00:00
|
|
|
avp = new_avp(KEYWORD_BASICTREE,"",'=');
|
|
|
|
matecfg->basic_tree = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
|
|
|
|
|
|
|
avp = new_avp(KEYWORD_FULLTREE,"",'=');
|
|
|
|
matecfg->full_tree = avp->n;
|
|
|
|
insert_avp(all_keywords,avp);
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if (actions) {
|
|
|
|
g_hash_table_destroy(actions);
|
|
|
|
}
|
|
|
|
|
|
|
|
actions = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
|
|
|
|
new_action(KEYWORD_SETTINGS,config_settings);
|
|
|
|
new_action(KEYWORD_PDU,config_pdu);
|
|
|
|
new_action(KEYWORD_PDUEXTRA,config_pduextra);
|
2004-12-12 23:40:44 +00:00
|
|
|
new_action(KEYWORD_PDUCRITERIA,config_pducriteria);
|
2004-12-11 01:00:17 +00:00
|
|
|
new_action(KEYWORD_GOP,config_gop);
|
|
|
|
new_action(KEYWORD_GOGDEF,config_gog);
|
|
|
|
new_action(KEYWORD_GOGKEY,config_gogkey);
|
|
|
|
new_action(KEYWORD_GOPSTART,config_start);
|
|
|
|
new_action(KEYWORD_GOPSTOP,config_stop);
|
|
|
|
new_action(KEYWORD_GOPEXTRA,config_gopextra);
|
|
|
|
new_action(KEYWORD_GOGEXTRA,config_gogextra);
|
|
|
|
new_action(KEYWORD_INCLUDE,config_include);
|
|
|
|
new_action(KEYWORD_TRANSFORM,config_transform);
|
|
|
|
new_action(KEYWORD_PDUTRANSFORM,config_pdu_transform);
|
|
|
|
new_action(KEYWORD_GOPTRANSFORM,config_gop_transform);
|
|
|
|
new_action(KEYWORD_GOGTRANSFORM,config_gog_transform);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
extern mate_config* mate_cfg() {
|
|
|
|
return matecfg;
|
|
|
|
}
|
|
|
|
|
2005-02-10 16:55:08 +00:00
|
|
|
extern mate_config* mate_make_config(guint8* filename, int mate_hfid) {
|
2004-12-16 19:36:23 +00:00
|
|
|
gint* ett;
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
avp_init();
|
|
|
|
|
|
|
|
matecfg = g_malloc(sizeof(mate_config));
|
|
|
|
|
|
|
|
matecfg->gog_expiration = DEFAULT_GOG_EXPIRATION;
|
|
|
|
matecfg->discard_pdu_attributes = FALSE;
|
|
|
|
matecfg->drop_pdu = FALSE;
|
|
|
|
matecfg->drop_gop = FALSE;
|
2004-12-31 14:27:38 +00:00
|
|
|
matecfg->show_times = TRUE;
|
2004-12-11 01:00:17 +00:00
|
|
|
matecfg->last_to_be_created = FALSE;
|
|
|
|
matecfg->match_mode = AVPL_STRICT;
|
|
|
|
matecfg->replace_mode = AVPL_INSERT;
|
2004-12-12 16:58:59 +00:00
|
|
|
matecfg->mate_lib_path = g_strdup_printf("%s%c%s%c",get_datafile_dir(),DIR_SEP,DEFAULT_MATE_LIB_PATH,DIR_SEP);
|
2004-12-11 01:00:17 +00:00
|
|
|
matecfg->mate_config_file = g_strdup(filename);
|
|
|
|
matecfg->mate_attrs_filter = g_string_new("");
|
|
|
|
matecfg->mate_protos_filter = g_string_new("");
|
|
|
|
matecfg->dbg_facility = NULL;
|
|
|
|
matecfg->dbg_lvl = 0;
|
|
|
|
matecfg->dbg_cfg_lvl = 0;
|
|
|
|
matecfg->dbg_pdu_lvl = 0;
|
|
|
|
matecfg->dbg_gop_lvl = 0;
|
|
|
|
matecfg->dbg_gog_lvl = 0;
|
|
|
|
matecfg->pducfglist = g_ptr_array_new();
|
|
|
|
matecfg->pducfgs = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
matecfg->gopcfgs = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
matecfg->gogcfgs = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
matecfg->transfs = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
matecfg->gops_by_pduname = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
matecfg->gogs_by_gopname = g_hash_table_new(g_str_hash,g_str_equal);
|
|
|
|
|
|
|
|
matecfg->hfrs = g_array_new(FALSE,TRUE,sizeof(hf_register_info));
|
2004-12-16 19:36:23 +00:00
|
|
|
matecfg->ett = g_array_new(FALSE,TRUE,sizeof(gint*));
|
|
|
|
matecfg->ett_root = -1;
|
2005-02-10 16:55:08 +00:00
|
|
|
matecfg->hfid_mate = mate_hfid;
|
|
|
|
|
2004-12-16 19:36:23 +00:00
|
|
|
ett = &matecfg->ett_root;
|
|
|
|
g_array_append_val(matecfg->ett,ett);
|
2004-12-11 01:00:17 +00:00
|
|
|
|
|
|
|
dbg = &matecfg->dbg_lvl;
|
|
|
|
|
2004-12-12 23:40:44 +00:00
|
|
|
init_actions();
|
|
|
|
|
2005-01-06 23:21:10 +00:00
|
|
|
matecfg->show_pdu_tree = matecfg->frame_tree;
|
2005-02-20 02:21:04 +00:00
|
|
|
matecfg->gop_as_subtree = matecfg->basic_tree;
|
|
|
|
|
2005-01-10 02:37:19 +00:00
|
|
|
config_error = g_string_new("");
|
|
|
|
|
2004-12-11 01:00:17 +00:00
|
|
|
if ( mate_load_config(filename) ) {
|
|
|
|
analyze_config();
|
|
|
|
dbg_print (dbg_cfg,3,dbg_facility,"mate_make_config: OK");
|
|
|
|
if (dbg_cfg_lvl > 0) print_config();
|
|
|
|
} else {
|
2005-01-10 02:37:19 +00:00
|
|
|
report_failure("%s",config_error->str);
|
|
|
|
g_string_free(config_error,TRUE);
|
2004-12-11 01:00:17 +00:00
|
|
|
if (matecfg) destroy_mate_config(matecfg,FALSE);
|
|
|
|
matecfg = NULL;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (matecfg->mate_attrs_filter->len > 1) {
|
|
|
|
g_string_erase(matecfg->mate_attrs_filter,0,2);
|
|
|
|
g_string_erase(matecfg->mate_protos_filter,0,2);
|
|
|
|
} else {
|
2004-12-12 16:58:59 +00:00
|
|
|
destroy_mate_config(matecfg,FALSE);
|
2004-12-11 01:00:17 +00:00
|
|
|
matecfg = NULL;
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
matecfg->tap_filter = g_strdup_printf("(%s) && (%s)",matecfg->mate_protos_filter->str,matecfg->mate_attrs_filter->str);
|
|
|
|
|
|
|
|
return matecfg;
|
|
|
|
}
|
|
|
|
|