diff options
Diffstat (limited to 'tinyDEMO/message.c')
-rwxr-xr-x | tinyDEMO/message.c | 404 |
1 files changed, 201 insertions, 203 deletions
diff --git a/tinyDEMO/message.c b/tinyDEMO/message.c index b0a97aa..fe826db 100755 --- a/tinyDEMO/message.c +++ b/tinyDEMO/message.c @@ -2,19 +2,19 @@ * Copyright (C) 2009 Mamadou Diop. * * Contact: Mamadou Diop <diopmamadou(at)doubango.org> -* +* * This file is part of Open Source Doubango Framework. * * DOUBANGO 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 3 of the License, or * (at your option) any later version. -* +* * DOUBANGO 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 DOUBANGO. * @@ -33,238 +33,236 @@ tsk_buffer_t* sms_submit(const tsip_uri_t* smsc, const tsip_uri_t* dest, const c int message_handle_event(const tsip_event_t *_event) { - const tsip_message_event_t* msg_event = TSIP_MESSAGE_EVENT(_event); - const session_t* session = tsk_null; - tsip_ssession_id_t sid; - int ret = 0; + const tsip_message_event_t* msg_event = TSIP_MESSAGE_EVENT(_event); + const session_t* session = tsk_null; + tsip_ssession_id_t sid; + int ret = 0; + + /* Find associated session */ + sid = tsip_ssession_get_id(_event->ss); + if(!(session = session_get_by_sid(ctx->sessions, sid))) { + if(tsip_ssession_have_ownership(_event->ss)) { + /* it's or own session and we fail to match it ==> should never happen */ + TSK_DEBUG_ERROR("Failed to match session event."); + ret = -2; + goto bail; + } + else { + /* it's a "server-side-session" (incoming MESSAGE) */ + session_t* _session; + if((_session = session_server_create(st_message, _event->ss)) && (session = _session)) { + tsk_list_push_back_data(ctx->sessions, (void**)&_session); + } + else { + TSK_DEBUG_ERROR("Failed to create \"sever-side-session\"."); + ret = -3; + goto bail; + } + } + } - /* Find associated session */ - sid = tsip_ssession_get_id(_event->ss); - if(!(session = session_get_by_sid(ctx->sessions, sid))){ - if(tsip_ssession_have_ownership(_event->ss)){ - /* it's or own session and we fail to match it ==> should never happen */ - TSK_DEBUG_ERROR("Failed to match session event."); - ret = -2; - goto bail; - } - else{ - /* it's a "server-side-session" (incoming MESSAGE) */ - session_t* _session; - if((_session = session_server_create(st_message, _event->ss)) && (session = _session)){ - tsk_list_push_back_data(ctx->sessions, (void**)&_session); - } - else{ - TSK_DEBUG_ERROR("Failed to create \"sever-side-session\"."); - ret = -3; - goto bail; - } - } - } - - switch(msg_event->type){ - case tsip_ao_message: /* Answer to outgoing MESSAGE */ - { - TSK_DEBUG_INFO("Event: Answer to outgoing MESSAGE. Code=%d", TSIP_RESPONSE_CODE(_event->sipmessage)); - if(TSIP_RESPONSE_IS_2XX(_event->sipmessage)){ - TSK_DEBUG_INFO("Message successfully sent."); - } - break; - } + switch(msg_event->type) { + case tsip_ao_message: { /* Answer to outgoing MESSAGE */ + TSK_DEBUG_INFO("Event: Answer to outgoing MESSAGE. Code=%d", TSIP_RESPONSE_CODE(_event->sipmessage)); + if(TSIP_RESPONSE_IS_2XX(_event->sipmessage)) { + TSK_DEBUG_INFO("Message successfully sent."); + } + break; + } - case tsip_i_message: /* Incoming MESSAGE */ - { - const char* content_type = TSIP_MESSAGE_CONTENT_TYPE(_event->sipmessage); + case tsip_i_message: { /* Incoming MESSAGE */ + const char* content_type = TSIP_MESSAGE_CONTENT_TYPE(_event->sipmessage); - TSK_DEBUG_INFO("Event: Incoming MESSAGE."); - if(TSIP_MESSAGE_HAS_CONTENT(_event->sipmessage)){ - const tsk_buffer_t* content = TSIP_MESSAGE_CONTENT(_event->sipmessage); - TSK_DEBUG_INFO("MESSAGE Content-Type: %s", content_type); - TSK_DEBUG_INFO("MESSAGE Content: %s", content->data); - } - /* accept() the MESSAGE to terminate the dialog */ - if(tsk_striequals("plain/text", content_type) || tsk_striequals("text/html", content_type)){ - tsip_api_common_accept(session->handle, - TSIP_ACTION_SET_HEADER("Info", "I've accept()ed your message"),// just for test - TSIP_ACTION_SET_NULL()); - } - /* reject() the MESSAGE to terminate the dialog */ - else{ - tsip_api_common_reject(session->handle, - TSIP_ACTION_SET_HEADER("Info", "I've reject()ed your message"),// just for test - TSIP_ACTION_SET_HEADER("In-Reply-To", "apb03a0s09dkjdfglkj49112"),// just for test - TSIP_ACTION_SET_NULL()); - } - break; - } + TSK_DEBUG_INFO("Event: Incoming MESSAGE."); + if(TSIP_MESSAGE_HAS_CONTENT(_event->sipmessage)) { + const tsk_buffer_t* content = TSIP_MESSAGE_CONTENT(_event->sipmessage); + TSK_DEBUG_INFO("MESSAGE Content-Type: %s", content_type); + TSK_DEBUG_INFO("MESSAGE Content: %s", content->data); + } + /* accept() the MESSAGE to terminate the dialog */ + if(tsk_striequals("plain/text", content_type) || tsk_striequals("text/html", content_type)) { + tsip_api_common_accept(session->handle, + TSIP_ACTION_SET_HEADER("Info", "I've accept()ed your message"),// just for test + TSIP_ACTION_SET_NULL()); + } + /* reject() the MESSAGE to terminate the dialog */ + else { + tsip_api_common_reject(session->handle, + TSIP_ACTION_SET_HEADER("Info", "I've reject()ed your message"),// just for test + TSIP_ACTION_SET_HEADER("In-Reply-To", "apb03a0s09dkjdfglkj49112"),// just for test + TSIP_ACTION_SET_NULL()); + } + break; + } - default: - { /* Any other event */ - TSK_DEBUG_WARN("%d not a valid SIP Messaging event.", msg_event->type); - break; - } - } + default: { + /* Any other event */ + TSK_DEBUG_WARN("%d not a valid SIP Messaging event.", msg_event->type); + break; + } + } bail: - return ret; + return ret; } tsip_ssession_id_t message_handle_cmd(cmd_type_t cmd, const opts_L_t* opts) { - const session_t* session = tsk_null; - const opt_t* opt; - tsip_ssession_id_t id = TSIP_SSESSION_INVALID_ID; + const session_t* session = tsk_null; + const opt_t* opt; + tsip_ssession_id_t id = TSIP_SSESSION_INVALID_ID; - if(!(session = session_handle_cmd(cmd, opts))){ - goto bail; - } - else{ - id = tsip_ssession_get_id(session->handle); - } - - switch(cmd){ - case cmd_message: - { /* Send SIP MESSAGE */ - tsip_action_handle_t* action_config = action_get_config(opts); - tsip_api_message_send_message(session->handle, - TSIP_ACTION_SET_CONFIG(action_config), - /* Any other TSIP_ACTION_SET_*() macros */ - TSIP_ACTION_SET_NULL()); - TSK_OBJECT_SAFE_FREE(action_config); - break; - } - case cmd_sms: - { /* Binary SMS (RP-DATA) */ - const char* ascii_pay = tsk_null; - tsk_buffer_t* binary_pay = tsk_null; - if((opt = opt_get_by_type(opts, opt_smsc)) && !tsk_strnullORempty(opt->value)){ - tsip_uri_t* smsc = tsip_uri_parse(opt->value, tsk_strlen(opt->value)); - tsip_uri_t* dest = tsk_null; - if(smsc){ - /* Valid phone number for the SMSC address? */ - if(!is_valid_telnum(smsc)){ - TSK_DEBUG_ERROR("[%s] contains invalid telephone number", opt->value); - goto done; - } - tsip_ssession_set(session->handle, - TSIP_SSESSION_SET_TO(opt->value), - TSIP_SSESSION_SET_NULL()); + if(!(session = session_handle_cmd(cmd, opts))) { + goto bail; + } + else { + id = tsip_ssession_get_id(session->handle); + } - /* Destination URI */ - if((opt = opt_get_by_type(opts, opt_to)) && !tsk_strnullORempty(opt->value)){ - if((dest = tsip_uri_parse(opt->value, tsk_strlen(opt->value)))){ - if(!is_valid_telnum(dest)){ - TSK_DEBUG_ERROR("[%s] contains invalid telephone number", opt->value); - goto done; - } - } - else{ - TSK_DEBUG_ERROR("[%s] is an invalid SIP/tel uri", opt->value); - goto done; - } - } - else{ - TSK_DEBUG_ERROR("++sms command need --to"); - goto done; - } + switch(cmd) { + case cmd_message: { + /* Send SIP MESSAGE */ + tsip_action_handle_t* action_config = action_get_config(opts); + tsip_api_message_send_message(session->handle, + TSIP_ACTION_SET_CONFIG(action_config), + /* Any other TSIP_ACTION_SET_*() macros */ + TSIP_ACTION_SET_NULL()); + TSK_OBJECT_SAFE_FREE(action_config); + break; + } + case cmd_sms: { + /* Binary SMS (RP-DATA) */ + const char* ascii_pay = tsk_null; + tsk_buffer_t* binary_pay = tsk_null; + if((opt = opt_get_by_type(opts, opt_smsc)) && !tsk_strnullORempty(opt->value)) { + tsip_uri_t* smsc = tsip_uri_parse(opt->value, tsk_strlen(opt->value)); + tsip_uri_t* dest = tsk_null; + if(smsc) { + /* Valid phone number for the SMSC address? */ + if(!is_valid_telnum(smsc)) { + TSK_DEBUG_ERROR("[%s] contains invalid telephone number", opt->value); + goto done; + } + tsip_ssession_set(session->handle, + TSIP_SSESSION_SET_TO(opt->value), + TSIP_SSESSION_SET_NULL()); - /* Payload? */ - if((opt = opt_get_by_type(opts, opt_payload)) && !tsk_strnullORempty(opt->value)){ - ascii_pay = opt->value; - } - else{ - TSK_DEBUG_ERROR("++sms command need --to"); - goto done; - } + /* Destination URI */ + if((opt = opt_get_by_type(opts, opt_to)) && !tsk_strnullORempty(opt->value)) { + if((dest = tsip_uri_parse(opt->value, tsk_strlen(opt->value)))) { + if(!is_valid_telnum(dest)) { + TSK_DEBUG_ERROR("[%s] contains invalid telephone number", opt->value); + goto done; + } + } + else { + TSK_DEBUG_ERROR("[%s] is an invalid SIP/tel uri", opt->value); + goto done; + } + } + else { + TSK_DEBUG_ERROR("++sms command need --to"); + goto done; + } - /* Create the binary content */ - if(!(binary_pay = sms_submit(smsc, dest, ascii_pay))){ - TSK_DEBUG_ERROR("Failed to encode RP-DATA(SMS-SUBMIT) message."); - goto done; - } + /* Payload? */ + if((opt = opt_get_by_type(opts, opt_payload)) && !tsk_strnullORempty(opt->value)) { + ascii_pay = opt->value; + } + else { + TSK_DEBUG_ERROR("++sms command need --to"); + goto done; + } + + /* Create the binary content */ + if(!(binary_pay = sms_submit(smsc, dest, ascii_pay))) { + TSK_DEBUG_ERROR("Failed to encode RP-DATA(SMS-SUBMIT) message."); + goto done; + } + + /* Send the message */ + tsip_api_message_send_message(session->handle, + /* TSIP_ACTION_SET_HEADER("Content-Type", "application/vnd.3gpp.sms"), */ + /* TSIP_ACTION_SET_HEADER("Transfer-Encoding", "binary"),*/ + TSIP_ACTION_SET_PAYLOAD(binary_pay->data, binary_pay->size), + TSIP_ACTION_SET_NULL()); - /* Send the message */ - tsip_api_message_send_message(session->handle, - /* TSIP_ACTION_SET_HEADER("Content-Type", "application/vnd.3gpp.sms"), */ - /* TSIP_ACTION_SET_HEADER("Transfer-Encoding", "binary"),*/ - TSIP_ACTION_SET_PAYLOAD(binary_pay->data, binary_pay->size), - TSIP_ACTION_SET_NULL()); - done: - TSK_OBJECT_SAFE_FREE(binary_pay); - TSK_OBJECT_SAFE_FREE(dest); - TSK_OBJECT_SAFE_FREE(smsc); - } - else{ - TSK_DEBUG_ERROR("[%s] is an invalid SIP/tel uri", opt->value); - break; - } - } - else{ - TSK_DEBUG_ERROR("++sms command need --smsc"); - break; - } - break; - } - default: - /* already handled by session_handle_cmd() */ - break; - } - + TSK_OBJECT_SAFE_FREE(binary_pay); + TSK_OBJECT_SAFE_FREE(dest); + TSK_OBJECT_SAFE_FREE(smsc); + } + else { + TSK_DEBUG_ERROR("[%s] is an invalid SIP/tel uri", opt->value); + break; + } + } + else { + TSK_DEBUG_ERROR("++sms command need --smsc"); + break; + } + break; + } + default: + /* already handled by session_handle_cmd() */ + break; + } + bail: - return id; + return id; } tsk_bool_t is_valid_telnum(const tsip_uri_t* uri) { - tsk_size_t i; - tsk_size_t len; + tsk_size_t i; + tsk_size_t len; - if(!uri || tsk_strnullORempty(uri->user_name)){ - return tsk_false; - } + if(!uri || tsk_strnullORempty(uri->user_name)) { + return tsk_false; + } - for(i = 0, len = tsk_strlen(uri->user_name); i<len; i++){ - if(uri->user_name[i] != '+' && !isdigit(uri->user_name[i])){ - return tsk_false; - } - } - return tsk_true; + for(i = 0, len = tsk_strlen(uri->user_name); i<len; i++) { + if(uri->user_name[i] != '+' && !isdigit(uri->user_name[i])) { + return tsk_false; + } + } + return tsk_true; } tsk_buffer_t* sms_submit(const tsip_uri_t* smsc, const tsip_uri_t* dest, const char* ascii_pay) { - static uint8_t mr = 0x00; + static uint8_t mr = 0x00; - int ret; - tsk_buffer_t* buffer = tsk_null; - tsms_tpdu_submit_t* sms_submit = tsk_null; - tsms_rpdu_data_t* rp_data = tsk_null; + int ret; + tsk_buffer_t* buffer = tsk_null; + tsms_tpdu_submit_t* sms_submit = tsk_null; + tsms_rpdu_data_t* rp_data = tsk_null; - // create SMS-SUBMIT message - sms_submit = tsms_tpdu_submit_create(++mr, (const uint8_t*)smsc->user_name, (const uint8_t*)dest->user_name); - // Set content for SMS-SUBMIT - if((buffer = tsms_pack_to_7bit(ascii_pay))){ - if((ret = tsms_tpdu_submit_set_userdata(sms_submit, buffer, tsms_alpha_7bit))){ - goto bail; - } - TSK_OBJECT_SAFE_FREE(buffer); - } - // create Mobile Originated (MO) RP-DATA message - if((rp_data = tsms_rpdu_data_create_mo(mr, (const uint8_t*)smsc->user_name, TSMS_TPDU_MESSAGE(sms_submit)))){ - // serialize into a buffer - if((buffer = tsk_buffer_create_null())){ - ret = tsms_rpdu_data_serialize(rp_data, buffer); - } - } + // create SMS-SUBMIT message + sms_submit = tsms_tpdu_submit_create(++mr, (const uint8_t*)smsc->user_name, (const uint8_t*)dest->user_name); + // Set content for SMS-SUBMIT + if((buffer = tsms_pack_to_7bit(ascii_pay))) { + if((ret = tsms_tpdu_submit_set_userdata(sms_submit, buffer, tsms_alpha_7bit))) { + goto bail; + } + TSK_OBJECT_SAFE_FREE(buffer); + } + // create Mobile Originated (MO) RP-DATA message + if((rp_data = tsms_rpdu_data_create_mo(mr, (const uint8_t*)smsc->user_name, TSMS_TPDU_MESSAGE(sms_submit)))) { + // serialize into a buffer + if((buffer = tsk_buffer_create_null())) { + ret = tsms_rpdu_data_serialize(rp_data, buffer); + } + } bail: - if(ret){ /* Failed? */ - TSK_OBJECT_SAFE_FREE(buffer); - } - TSK_OBJECT_SAFE_FREE(sms_submit); - TSK_OBJECT_SAFE_FREE(rp_data); + if(ret) { /* Failed? */ + TSK_OBJECT_SAFE_FREE(buffer); + } + TSK_OBJECT_SAFE_FREE(sms_submit); + TSK_OBJECT_SAFE_FREE(rp_data); - return buffer; + return buffer; } |