adding mg term license validation code

This commit is contained in:
Kapil Gupta 2012-08-29 16:19:46 -04:00
parent d5ea03d693
commit 5f02dd8b36
3 changed files with 30 additions and 7 deletions

View File

@ -647,6 +647,7 @@ switch_status_t megaco_profile_start(const char *profilename)
profile->name = switch_core_strdup(pool, profilename); profile->name = switch_core_strdup(pool, profilename);
profile->next_context_id++; profile->next_context_id++;
profile->inact_tmr = 0x00; profile->inact_tmr = 0x00;
profile->total_cfg_term = 0x00;
profile->peer_active = 0x00; profile->peer_active = 0x00;
profile->mg_stats = switch_core_alloc(pool, sizeof(mg_stats_t)); profile->mg_stats = switch_core_alloc(pool, sizeof(mg_stats_t));
profile->inact_tmr_task_id = 0x00; profile->inact_tmr_task_id = 0x00;

View File

@ -25,10 +25,14 @@ switch_status_t config_profile(megaco_profile_t *profile, switch_bool_t reload)
switch_xml_config_item_t *instructions = (profile ? get_instructions(profile) : NULL); switch_xml_config_item_t *instructions = (profile ? get_instructions(profile) : NULL);
int count; int count;
int idx; int idx;
int ret=0;
char *var, *val; char *var, *val;
mg_peer_profile_t* peer_profile = NULL; mg_peer_profile_t* peer_profile = NULL;
switch_xml_config_item_t *instructions1 = NULL; switch_xml_config_item_t *instructions1 = NULL;
switch_memory_pool_t *pool; switch_memory_pool_t *pool;
char lic_sig_file[4096];
memset(&lic_sig_file[0],0,sizeof(lic_sig_file));
if (!(xml = switch_xml_open_cfg(file, &cfg, NULL))) { if (!(xml = switch_xml_open_cfg(file, &cfg, NULL))) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Could not open %s\n", file); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Could not open %s\n", file);
@ -64,10 +68,8 @@ switch_status_t config_profile(megaco_profile_t *profile, switch_bool_t reload)
goto done; goto done;
} }
profile->idx = ++mg_sap_id; profile->idx = ++mg_sap_id;
if ((mg_phys_terms = switch_xml_child(mg_interface, "physical_terminations"))) { if ((mg_phys_terms = switch_xml_child(mg_interface, "physical_terminations"))) {
for (mg_term = switch_xml_child(mg_phys_terms, "map"); mg_term; mg_term = mg_term->next) { for (mg_term = switch_xml_child(mg_phys_terms, "map"); mg_term; mg_term = mg_term->next) {
// <map termination-id-prefix="Term1/" termination-id-base="1" tech="freetdm" channel-prefix="wp2" channel-map"1-15,17-31"/> // <map termination-id-prefix="Term1/" termination-id-base="1" tech="freetdm" channel-prefix="wp2" channel-map"1-15,17-31"/>
@ -148,11 +150,28 @@ else
if (!mg_interface) { if (!mg_interface) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error profile %s not found\n", profile->name); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error profile %s not found\n", profile->name);
return SWITCH_STATUS_FALSE; status = SWITCH_STATUS_FALSE;
}
if((profile->license) && ('\0' != profile->license[0])){
sprintf(lic_sig_file, "%s.sig", profile->license);
}else{
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Failed to get License file \n");
status = SWITCH_STATUS_FALSE;
goto done;
}
MG_CHECK_LICENSE(profile->total_cfg_term,profile->license, &lic_sig_file[0], ret);
if(ret){
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "License validation failed \n");
status = SWITCH_STATUS_FALSE;
goto done;
} }
/* go through the peer configuration and get the mg profile associated peers only */ /* go through the peer configuration and get the mg profile associated peers only */
if (!(mg_peers = switch_xml_child(cfg, "mg_peers"))) { if (!(mg_peers = switch_xml_child(cfg, "mg_peers"))) {
status = SWITCH_STATUS_FALSE;
goto done; goto done;
} }
@ -232,6 +251,8 @@ void mg_create_tdm_term(megaco_profile_t *profile, const char *tech, const char
"Mapped termination [%s] to freetdm span: %s chan: %d\n", "Mapped termination [%s] to freetdm span: %s chan: %d\n",
term->name, term->u.tdm.span_name, term->u.tdm.channel); term->name, term->u.tdm.span_name, term->u.tdm.channel);
megaco_prepare_tdm_termination(term); megaco_prepare_tdm_termination(term);
profile->total_cfg_term++;
} }
/****************************************************************************************************************************/ /****************************************************************************************************************************/
switch_status_t mg_config_cleanup(megaco_profile_t* profile) switch_status_t mg_config_cleanup(megaco_profile_t* profile)
@ -291,7 +312,6 @@ static switch_xml_config_item_t *get_instructions(megaco_profile_t *profile) {
SWITCH_TRUE, /* enforce Max */ SWITCH_TRUE, /* enforce Max */
9 9
}; };
#endif
static switch_xml_config_int_options_t pre_buffer_len = { static switch_xml_config_int_options_t pre_buffer_len = {
SWITCH_TRUE, /* enforce min */ SWITCH_TRUE, /* enforce min */
@ -300,7 +320,6 @@ static switch_xml_config_item_t *get_instructions(megaco_profile_t *profile) {
10000 10000
}; };
#if 0
static switch_xml_config_enum_item_t opt_default_codec_enum[] = { static switch_xml_config_enum_item_t opt_default_codec_enum[] = {
{ "PCMA", MEGACO_CODEC_PCMA}, { "PCMA", MEGACO_CODEC_PCMA},
{ "PCMU", MEGACO_CODEC_PCMU}, { "PCMU", MEGACO_CODEC_PCMU},
@ -323,8 +342,9 @@ static switch_xml_config_item_t *get_instructions(megaco_profile_t *profile) {
//SWITCH_CONFIG_ITEM("rtp-port-range", SWITCH_CONFIG_STRING, CONFIG_REQUIRED, &profile->rtp_port_range, "1-65535", &switch_config_string_strdup, "", "rtp port range"), //SWITCH_CONFIG_ITEM("rtp-port-range", SWITCH_CONFIG_STRING, CONFIG_REQUIRED, &profile->rtp_port_range, "1-65535", &switch_config_string_strdup, "", "rtp port range"),
SWITCH_CONFIG_ITEM("rtp-termination-id-prefix", SWITCH_CONFIG_STRING, CONFIG_RELOADABLE, &profile->rtp_termination_id_prefix, "", &switch_config_string_strdup, "", "rtp termination prefix"), SWITCH_CONFIG_ITEM("rtp-termination-id-prefix", SWITCH_CONFIG_STRING, CONFIG_RELOADABLE, &profile->rtp_termination_id_prefix, "", &switch_config_string_strdup, "", "rtp termination prefix"),
//SWITCH_CONFIG_ITEM("rtp-termination-id-length", SWITCH_CONFIG_INT, CONFIG_RELOADABLE, &profile->rtp_termination_id_len, "", &opt_termination_id_len, "", "rtp termination id"), //SWITCH_CONFIG_ITEM("rtp-termination-id-length", SWITCH_CONFIG_INT, CONFIG_RELOADABLE, &profile->rtp_termination_id_len, "", &opt_termination_id_len, "", "rtp termination id"),
SWITCH_CONFIG_ITEM("tdm-pre-buffer-size", SWITCH_CONFIG_INT, CONFIG_RELOADABLE, &profile->tdm_pre_buffer_size, 0, &pre_buffer_len, "", "freetdm pre buffer size"), //SWITCH_CONFIG_ITEM("tdm-pre-buffer-size", SWITCH_CONFIG_INT, CONFIG_RELOADABLE, &profile->tdm_pre_buffer_size, 0, &pre_buffer_len, "", "freetdm pre buffer size"),
SWITCH_CONFIG_ITEM("codec-prefs", SWITCH_CONFIG_STRING, 0, &profile->codec_prefs, "", &switch_config_string_strdup, "", "codec preferences, coma-separated"), SWITCH_CONFIG_ITEM("codec-prefs", SWITCH_CONFIG_STRING, 0, &profile->codec_prefs, "", &switch_config_string_strdup, "", "codec preferences, coma-separated"),
SWITCH_CONFIG_ITEM("license", SWITCH_CONFIG_STRING, 0, &profile->license, "/usr/local/nsg/conf/license.txt", &switch_config_string_strdup, "", "License file"),
SWITCH_CONFIG_ITEM_END() SWITCH_CONFIG_ITEM_END()
}; };

View File

@ -217,8 +217,10 @@ struct megaco_profile_s {
char* my_ipaddr; /* local domain name */ char* my_ipaddr; /* local domain name */
char* port; /* port */ char* port; /* port */
char* protocol_type; /* MEGACO/MGCP */ char* protocol_type; /* MEGACO/MGCP */
char* license; /* License file location/name */
int protocol_version; /* Protocol supported version */ int protocol_version; /* Protocol supported version */
int total_peers; int total_peers;
int total_cfg_term;
megaco_codec_t default_codec; megaco_codec_t default_codec;
char* rtp_port_range; char* rtp_port_range;
char* rtp_termination_id_prefix; char* rtp_termination_id_prefix;