issue fixes

This commit is contained in:
Kapil Gupta 2012-08-15 13:31:31 -04:00
parent 9ef68f1b91
commit 85dfa04240
3 changed files with 36 additions and 32 deletions

View File

@ -413,6 +413,7 @@ switch_status_t megaco_context_is_term_present(mg_context_t *ctx, mg_termination
switch_status_t megaco_context_add_termination(mg_context_t *ctx, mg_termination_t *term) switch_status_t megaco_context_add_termination(mg_context_t *ctx, mg_termination_t *term)
{ {
switch_status_t status = SWITCH_STATUS_SUCCESS;
switch_assert(ctx != NULL); switch_assert(ctx != NULL);
switch_assert(term != NULL); switch_assert(term != NULL);
@ -434,12 +435,14 @@ switch_status_t megaco_context_add_termination(mg_context_t *ctx, mg_termination
if (ctx->terminations[0] && ctx->terminations[1]) { if (ctx->terminations[0] && ctx->terminations[1]) {
if (zstr(ctx->terminations[0]->uuid)) { if (zstr(ctx->terminations[0]->uuid)) {
megaco_activate_termination(ctx->terminations[0]); status = megaco_activate_termination(ctx->terminations[0]);
} }
if (zstr(ctx->terminations[1]->uuid)) { if (zstr(ctx->terminations[1]->uuid)) {
megaco_activate_termination(ctx->terminations[1]); status = megaco_activate_termination(ctx->terminations[1]);
} }
if(SWITCH_STATUS_SUCCESS != status) return status;
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "Bridging: %s (%s) <> %s (%s)\n", switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "Bridging: %s (%s) <> %s (%s)\n",
ctx->terminations[0]->name, ctx->terminations[0]->uuid, ctx->terminations[0]->name, ctx->terminations[0]->uuid,
ctx->terminations[1]->name, ctx->terminations[1]->uuid); ctx->terminations[1]->name, ctx->terminations[1]->uuid);

View File

@ -729,20 +729,9 @@ switch_status_t handle_mg_add_cmd(megaco_profile_t* mg_profile, MgMgcoCommand *i
mg_print_t38_attributes(term); mg_print_t38_attributes(term);
/* TODO - locally assigned SDP must be the part of termination...which we can use to fill responses*/
/********************************************************************/ /********************************************************************/
/* Matt - to provide the response SDP structure which needs to fill in ADD command response */ /* resp code -- begin */
/* Matt - to indicate if there is any failure while processing add message */
/* Kapil - to return error if there is any failure based on Matt's indication */
/* Kapil - to fill the response structure and call the response API to send ADD response */
/*************************************************************************************************************************/
/* sample resp code -- begin */
{ {
MgMgcoCommand rsp; MgMgcoCommand rsp;
int ret = 0x00; int ret = 0x00;
@ -1050,6 +1039,13 @@ error:
sng_mgco_send_err(mg_profile->idx, mgErr); sng_mgco_send_err(mg_profile->idx, mgErr);
} }
mg_free_cmd(inc_cmd); mg_free_cmd(inc_cmd);
switch_log_printf(SWITCH_CHANNEL_LOG_CLEAN, SWITCH_LOG_ERROR," ADD Request failed..releasing context/termination(if allocated) \n");
if(mg_ctxt){
megaco_release_context(mg_ctxt);
}
if(term){
megaco_termination_destroy(term);
}
return SWITCH_STATUS_FALSE; return SWITCH_STATUS_FALSE;
} }
@ -1127,8 +1123,6 @@ switch_status_t handle_mg_modify_cmd(megaco_profile_t* mg_profile, MgMgcoCommand
/* check if we have ito packg request */ /* check if we have ito packg request */
mg_is_ito_pkg_req(mg_profile, inc_cmd); mg_is_ito_pkg_req(mg_profile, inc_cmd);
/* TODO */
/********************************************************************/ /********************************************************************/
} else if(MGT_TERMID_OTHER == termId->type.val){ } else if(MGT_TERMID_OTHER == termId->type.val){
/********************************************************************/ /********************************************************************/
@ -1194,7 +1188,6 @@ switch_status_t handle_mg_modify_cmd(megaco_profile_t* mg_profile, MgMgcoCommand
if(term->mg_error_code && (*term->mg_error_code == MGT_MGCP_RSP_CODE_INCONSISTENT_LCL_OPT)){ if(term->mg_error_code && (*term->mg_error_code == MGT_MGCP_RSP_CODE_INCONSISTENT_LCL_OPT)){
mg_util_set_err_string(&errTxt, " Unsupported Codec "); mg_util_set_err_string(&errTxt, " Unsupported Codec ");
err_code = MGT_MGCP_RSP_CODE_INCONSISTENT_LCL_OPT; err_code = MGT_MGCP_RSP_CODE_INCONSISTENT_LCL_OPT;
/* TODO delete RTP termination */
goto error; goto error;
} }
@ -1219,21 +1212,15 @@ switch_status_t handle_mg_modify_cmd(megaco_profile_t* mg_profile, MgMgcoCommand
/* SDP updated to termination */ /* SDP updated to termination */
megaco_activate_termination(term); if(SWITCH_STATUS_SUCCESS != megaco_activate_termination(term)) {
mg_util_set_err_string(&errTxt, " Resource Failure ");
err_code = MGT_MGCO_RSP_CODE_RSRC_ERROR;
goto error;
}
} }
/* TODO - copy inc descriptor...not sure if we need to do this.. */
/********************************************************************/ /********************************************************************/
/* Matt - to provide the response SDP structure which needs to fill in Modify command response */
/* Matt - to indicate if there is any failure while processing add message */
/* Kapil - to return error if there is any failure based on Matt's indication */
/* Kapil - to fill the response structure and call the response API to send Modify response */
response: response:
{ /* send response */ { /* send response */
@ -1272,9 +1259,10 @@ response:
#endif #endif
/*mg_fill_mgco_termid(termId, (char*)"term1",&req->u.mgCmdRsp[0]->memCp);*/ /*mg_fill_mgco_termid(termId, (char*)"term1",&req->u.mgCmdRsp[0]->memCp);*/
if((MG_TERM_RTP == term->type) && if((MGT_TERMID_ROOT != termId->type.val) &&
(term && (MG_TERM_RTP == term->type) &&
((NOTPRSNT != inc_cmd->u.mgCmdInd[0]->cmd.u.mod.dl.num.pres) && ((NOTPRSNT != inc_cmd->u.mgCmdInd[0]->cmd.u.mod.dl.num.pres) &&
(0 != inc_cmd->u.mgCmdInd[0]->cmd.u.mod.dl.num.val))) { (0 != inc_cmd->u.mgCmdInd[0]->cmd.u.mod.dl.num.val)))) {
/* Whatever Media descriptor we have received, we can copy that and then /* Whatever Media descriptor we have received, we can copy that and then
* whatever we want we can modify the fields */ * whatever we want we can modify the fields */
/* Kapil - TODO - will see if there is any problem of coping the /* Kapil - TODO - will see if there is any problem of coping the
@ -1335,6 +1323,14 @@ error:
sng_mgco_send_err(mg_profile->idx, mgErr); sng_mgco_send_err(mg_profile->idx, mgErr);
} }
mg_free_cmd(inc_cmd); mg_free_cmd(inc_cmd);
switch_log_printf(SWITCH_CHANNEL_LOG_CLEAN, SWITCH_LOG_ERROR," Modify Request failed..releasing context/termination \n");
if(mg_ctxt){
megaco_release_context(mg_ctxt);
}
if(term){
megaco_termination_destroy(term);
}
return SWITCH_STATUS_FALSE; return SWITCH_STATUS_FALSE;
} }
@ -3030,7 +3026,7 @@ switch_status_t mg_send_notify(megaco_profile_t* mg_profile, const char* term_n
request.transId.val = get_txn_id(); request.transId.val = get_txn_id();
request.contextId.type.pres = PRSNT_NODEF; request.contextId.type.pres = PRSNT_NODEF;
if(term->context){ if(term && term->context){
printf("Temrination is in context, adding context-id[%d]\n",term->context->context_id); printf("Temrination is in context, adding context-id[%d]\n",term->context->context_id);
request.contextId.type.val = MGT_CXTID_OTHER; request.contextId.type.val = MGT_CXTID_OTHER;
request.contextId.val.pres = PRSNT_NODEF; request.contextId.val.pres = PRSNT_NODEF;

View File

@ -138,6 +138,11 @@ MgPackage_t mg_pkg_list [] =
1, /* Version 1 */ 1, /* Version 1 */
"ipfax", /* Package name */ "ipfax", /* Package name */
}, },
{ /* INDEX : 26 */
MGT_PKG_FAX,
1, /* Version 1 */
"fax", /* Package name */
},
/* Add more packages */ /* Add more packages */
}; };