123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505 |
- /*
- * Copyright (C) 2009 Mamadou Diop.
- *
- * Contact: Mamadou Diop <diopmamadou(at)doubango[dot]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.
- *
- */
- #ifndef _TEST_STACK_H
- #define _TEST_STACK_H
- #ifndef LOCAL_IP
- # ifdef ANDROID
- # define LOCAL_IP "10.0.2.15"
- # else
- # define LOCAL_IP TNET_SOCKET_HOST_ANY
- # endif
- #endif
- #define TEST_STACK_SDP \
- "v=0\r\n" \
- "o=bob 2890844730 2890844731 IN IP4 host.example.com\r\n" \
- "s=\r\n" \
- "c=IN IP4 192.168.0.12\r\n" \
- "t=0 0\r\n" \
- "m=audio 54344 RTP/AVP 0\r\n" \
- "a=rtpmap:0 PCMU/8000\r\n"
- #define TEST_STACK_PIDF \
- "<?xml version=\"1.0\" encoding=\"utf-8\"?>"\
- "<presence xmlns:cp=\"urn:ietf:params:xml:ns:pidf:cipid\" xmlns:caps=\"urn:ietf:params:xml:ns:pidf:caps\" xmlns:rpid=\"urn:ietf:params:xml:ns:pidf:rpid\" xmlns:pdm=\"urn:ietf:params:xml:ns:pidf:data-model\" xmlns:p=\"urn:ietf:params:xml:ns:pidf-diff\" xmlns:op=\"urn:oma:xml:prs:pidf:oma-pres\" entity=\"sip:mamadou@"DOMAIN"\" xmlns=\"urn:ietf:params:xml:ns:pidf\">"\
- " <pdm:person id=\"CRUVREZS\">"\
- " <op:overriding-willingness>"\
- " <op:basic>open</op:basic>"\
- " </op:overriding-willingness>"\
- " <rpid:activities>"\
- " <rpid:unknown />"\
- " </rpid:activities>"\
- " <rpid:mood>"\
- " <rpid:neutral />"\
- " </rpid:mood>"\
- " <pdm:note>Hello world</pdm:note>"\
- " </pdm:person>"\
- " <pdm:device id=\"d0001\">"\
- " <status>"\
- " <basic>open</basic>"\
- " </status>"\
- " <caps:devcaps>"\
- " <caps:mobility>"\
- " <caps:supported>"\
- " <caps:fixed />"\
- " </caps:supported>"\
- " </caps:mobility>"\
- " </caps:devcaps>"\
- " <op:network-availability>"\
- " <op:network id=\"IMS\">"\
- " <op:active />"\
- " </op:network>"\
- " </op:network-availability>"\
- " <pdm:deviceID>urn:uuid:dd1289fa-c3d7-47bd-a40d-f1f1b2cc5ffc</pdm:deviceID>"\
- " </pdm:device>"\
- "</presence>"
- int test_stack_callback(const tsip_event_t *sipevent)
- {
- TSK_DEBUG_INFO("\n====\nSTACK event: %d [%s] with opid=%lld\n=====",
- sipevent->code, sipevent->phrase, tsip_ssession_get_id(sipevent->ss));
- // For ssessions created by the stack ==> call tsk_object_ref(sipevent->ssession);
- // to take ownership.
- switch(sipevent->type) {
- //
- // REGISTER
- //
- case tsip_event_register: {
- const tsip_register_event_t* _event;
- TSK_DEBUG_INFO("SIP event(REGISTER)");
- _event = TSIP_REGISTER_EVENT(sipevent);
- switch(_event->type) {
- case tsip_ao_register: { /* Answer to Outgoing REGISTER */
- if(TSIP_RESPONSE_IS_2XX(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("Registration succeed.");
- }
- else {
- TSK_DEBUG_INFO("Registration failed.");
- }
- break;
- }
- case tsip_ao_unregister: { /* Answer to Outgoing UNREGISTER */
- if(TSIP_RESPONSE_IS_2XX(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("UnRegistration succeed.");
- }
- else {
- TSK_DEBUG_INFO("UnRegistration failed.");
- }
- break;
- }
- default:
- break;
- }
- break;
- }
- //
- // INVITE
- //
- case tsip_event_invite: {
- TSK_DEBUG_INFO("SIP event(INVITE)");
- break;
- }
- //
- // MESSAGE
- //
- case tsip_event_message: {
- const tsip_message_event_t* _event;
- TSK_DEBUG_INFO("SIP event(MESSAGE)");
- _event = TSIP_MESSAGE_EVENT(sipevent);
- switch(_event->type) {
- case tsip_i_message: { /* Incoming MESSAGE */
- if(TSIP_MESSAGE_HAS_CONTENT(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("MESSAGE Content: %s", TSIP_MESSAGE_CONTENT(sipevent->sipmessage));
- }
- break;
- }
- case tsip_ao_message: { /* Answer to Outgoing MESSAGE */
- if(TSIP_RESPONSE_IS_2XX(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("MESSAGE successfully sent.");
- }
- else {
- TSK_DEBUG_INFO("Failed to send MESSAGE (sip code:%d).", TSIP_RESPONSE_CODE(sipevent->sipmessage));
- }
- }
- default:
- break;
- }
- break;
- }
- //
- // PUBLISH
- //
- case tsip_event_publish: {
- TSK_DEBUG_INFO("SIP event(PUBLISH)");
- break;
- }
- //
- // SUBSCRIBE
- //
- case tsip_event_subscribe: {
- const tsip_subscribe_event_t* _event;
- TSK_DEBUG_INFO("SIP event(SUBSCRIBE)");
- _event = TSIP_SUBSCRIBE_EVENT(sipevent);
- switch(_event->type) {
- case tsip_i_notify: { /* Incoming NOTIFY */
- if(TSIP_MESSAGE_CONTENT_DATA(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("NOTIFY Content: %s", TSIP_MESSAGE_CONTENT(sipevent->sipmessage));
- }
- break;
- }
- case tsip_ao_subscribe: { /* Answer to Outgoing SUBSCRIBE */
- if(TSIP_RESPONSE_IS_2XX(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("Subscription succeed.");
- }
- else {
- TSK_DEBUG_INFO("Subscription failed.");
- }
- break;
- }
- case tsip_ao_unsubscribe: { /* Answer to Outgoing UNSUBSCRIBE */
- if(TSIP_RESPONSE_IS_2XX(sipevent->sipmessage)) {
- TSK_DEBUG_INFO("UnSubscription succeed.");
- }
- else {
- TSK_DEBUG_INFO("UnSubscription failed.");
- }
- break;
- }
- default:
- break;
- }
- break;
- }
- default: {
- TSK_DEBUG_INFO("SIP event(UNKNOWN)");
- break;
- }
- }
- //tsk_thread_sleep(1000000);
- return 0;
- }
- void test_stack()
- {
- #define DOMAIN "ericsson.com"
- //#define DOMAIN "micromethod.com"
- //#define DOMAIN "ims.inexbee.com"
- //#define DOMAIN "sip2sip.info"
- const void* usr_context = tsk_null;
- int ret;
- uint16_t AMF = 0x0001;
- /*
- tsip_stack_handle_t *stack = tsip_stack_create(test_stack_callback,
- TSIP_STACK_SET_DISPLAY_NAME("2233392625"),
- TSIP_STACK_SET_PUBLIC_IDENTITY("sip:2233392625@"DOMAIN),
- TSIP_STACK_SET_PRIVATE_IDENTITY("2233392625"),
- TSIP_STACK_SET_PASSWORD("d3sb7j4fb8"),
- TSIP_STACK_SET_REALM("sip:"DOMAIN), // FIXME: without sip:
- TSIP_STACK_SET_LOCAL_IP(LOCAL_IP),
- //TSIP_STACK_SET_DISCOVERY_NAPTR(1),
- //TSIP_STACK_SET_PROXY_CSCF("proxy.sipthor.net", "udp", 0),
- //TSIP_STACK_SET_PROXY_CSCF("192.168.0.15", "udp", 0),
- TSIP_STACK_SET_PROXY_CSCF_PORT(5060),
- TSIP_STACK_SET_MOBILITY("fixed"),
- TSIP_STACK_SET_DEVICE_ID("dd1289fa-c3d7-47bd-a40d-f1f1b2cc5ffc"),
- TSIP_STACK_SET_NETINFO("ADSL;utran-cell-id-3gpp=00000000"),
- TSIP_STACK_SET_PRIVACY("header;id"),
- */
- /*
- tsip_stack_handle_t *stack = tsip_stack_create(test_stack_callback,
- TSIP_STACK_SET_DISPLAY_NAME("Mamadou"),
- TSIP_STACK_SET_PUBLIC_IDENTITY("sip:mamadou@"DOMAIN),
- TSIP_STACK_SET_PRIVATE_IDENTITY("mamadou@"DOMAIN),
- TSIP_STACK_SET_PASSWORD("mamadou"),
- TSIP_STACK_SET_REALM("sip:"DOMAIN), // FIXME: without sip:
- TSIP_STACK_SET_LOCAL_IP(LOCAL_IP),
- //TSIP_STACK_SET_DISCOVERY_NAPTR(1),
- TSIP_STACK_SET_PROXY_CSCF("192.168.0.15", "udp", 0),
- //TSIP_STACK_SET_PROXY_CSCF_PORT(5081),
- TSIP_STACK_SET_PROXY_CSCF_PORT(5060),
- //TSIP_STACK_SET_SECAGREE_IPSEC("hmac-md5-96", "null", "trans", "esp"),
- TSIP_STACK_SET_MOBILITY("fixed"),
- TSIP_STACK_SET_DEVICE_ID("dd1289fa-c3d7-47bd-a40d-f1f1b2cc5ffc"),
- TSIP_STACK_SET_NETINFO("ADSL;utran-cell-id-3gpp=00000000"),
- TSIP_STACK_SET_PRIVACY("header;id"),
- */
- int32_t port = 4060;
- /*
- tsip_stack_handle_t *stack = tsip_stack_create(test_stack_callback, "sip:"DOMAIN, "mamadou@"DOMAIN, "sip:mamadou@"DOMAIN,
- TSIP_STACK_SET_DISPLAY_NAME("Mamadou"),
- TSIP_STACK_SET_PASSWORD("mamadou"),
- TSIP_STACK_SET_IMS_AKA_AMF(AMF),
- TSIP_STACK_SET_IMS_AKA_OPERATOR_ID("0xff08"),
- TSIP_STACK_SET_HEADER("User-Agent", "IM-client/OMA1.0 doubango/v1.0.0"),
- TSIP_STACK_SET_PROXY_CSCF("192.168.16.225", port, "udp", "ipv4"),
- TSIP_STACK_SET_EARLY_IMS(tsk_true),
- */
- tsip_stack_handle_t *stack = tsip_stack_create(test_stack_callback, "sip:"DOMAIN, "mamadou@"DOMAIN, "sip:mamadou@"DOMAIN,
- TSIP_STACK_SET_DISPLAY_NAME("Mamadou"),
- TSIP_STACK_SET_PASSWORD("mamadou"),
- TSIP_STACK_SET_IMS_AKA_AMF(AMF),
- TSIP_STACK_SET_IMS_AKA_OPERATOR_ID("0xff08"),
- TSIP_STACK_SET_HEADER("User-Agent", "IM-client/OMA1.0 doubango/v1.0.0"),
- TSIP_STACK_SET_PROXY_CSCF("192.168.0.13", 5081, "tcp", "ipv4"),
- TSIP_STACK_SET_LOCAL_IP(LOCAL_IP),
- TSIP_STACK_SET_EARLY_IMS(tsk_true),
- /*
- tsip_stack_handle_t *stack = tsip_stack_create(test_stack_callback, "sip:"DOMAIN, "2233392625", "sip:2233392625@"DOMAIN,
- TSIP_STACK_SET_DISPLAY_NAME("Mamadou"),
- TSIP_STACK_SET_PASSWORD("d3sb7j4fb8"),
- TSIP_STACK_SET_EARLY_IMS(tsk_true),
- TSIP_STACK_SET_HEADER("User-Agent", "IM-client/OMA1.0 doubango/v1.0.0"),
- */
- /*
- tsip_stack_handle_t *stack = tsip_stack_create(test_stack_callback,
- TSIP_STACK_SET_DISPLAY_NAME("Mamadou"),
- TSIP_STACK_SET_PUBLIC_IDENTITY("sip:mamadou@"DOMAIN),
- TSIP_STACK_SET_PRIVATE_IDENTITY("mamadou@"DOMAIN),
- TSIP_STACK_SET_PASSWORD("mamadou"),
- TSIP_STACK_SET_REALM("sip:"DOMAIN), // FIXME: without sip:
- TSIP_STACK_SET_LOCAL_IP(LOCAL_IP),
- //TSIP_STACK_SET_DISCOVERY_NAPTR(1),
- TSIP_STACK_SET_PROXY_CSCF("192.168.16.104", "udp", 0),
- //TSIP_STACK_SET_PROXY_CSCF("192.168.0.15", "udp", 0),
- TSIP_STACK_SET_PROXY_CSCF_PORT(5060),
- //TSIP_STACK_SET_SECAGREE_IPSEC("hmac-md5-96", "null", "trans", "esp"),
- TSIP_STACK_SET_MOBILITY("fixed"),
- TSIP_STACK_SET_DEVICE_ID("dd1289fa-c3d7-47bd-a40d-f1f1b2cc5ffc"),
- TSIP_STACK_SET_NETINFO("ADSL;utran-cell-id-3gpp=00000000"),
- TSIP_STACK_SET_PRIVACY("header;id"),
- */
- TSIP_STACK_SET_NULL());
- //tsip_ssession_handle_t *op = tsip_ssession_create(stack,
- // TSIP_SSESSION_SET_CONTEXT(usr_context),
- // TSIP_SSESSION_SET_HEADER("expires", "30"),
- // TSIP_SSESSION_SET_HEADER("Persistence", "session"),
- //
- // TSIP_SSESSION_SET_CAPS("language", "\"en,fr\""),
- // TSIP_SSESSION_SET_CAPS("+audio", ""),
- // TSIP_SSESSION_SET_CAPS("+g.oma.sip-im", ""),
- //
- // tsk_null);
- tsip_ssession_handle_t *op = tsip_ssession_create(stack,
- TSIP_SSESSION_SET_EXPIRES(30),
- TSIP_SSESSION_SET_CAPS("+g.oma.sip-im", ""),
- TSIP_SSESSION_SET_CAPS("+audio", ""),
- TSIP_SSESSION_SET_CAPS("automata", ""),
- TSIP_SSESSION_SET_CAPS("language", "\"en,fr\""),
- TSIP_SSESSION_SET_HEADER("Supported", "ssl"),
- TSIP_SSESSION_SET_HEADER("P-Access-Network-Info", "3GPP-UTRAN-TDD;utran-cell-id-3gpp=AAAAA0000BBBB"),
- TSIP_SSESSION_UNSET_HEADER("P-Access-Network-Info"),
- TSIP_SSESSION_SET_NULL());
- //tsip_ssession_id_t opid = tsip_ssession_get_id(op);
- if((ret = tsip_stack_start(stack))) {
- goto bail;
- }
- tsip_action_REGISTER(op,
- TSIP_ACTION_SET_HEADER("My-Header-1", "My-Value-1"),
- TSIP_ACTION_SET_HEADER("My-Header-2", "My-Value-1"),
- TSIP_ACTION_SET_NULL());
- getchar();
- //tsk_thread_sleep(2000);
- tsip_action_UNREGISTER(op,
- TSIP_ACTION_SET_NULL()
- );
- getchar();
- tsk_thread_sleep(2000);
- //tsip_unregister(op,
- // TSIP_ACTION_SET_HEADER("Persistence2", "action"),
- //
- // tsk_null);
- /*
- tsip_subscribe(op,
- TSIP_ACTION_SET_HEADER("Persistence", "action"),
- tsk_null);
- tsk_thread_sleep(5000);
- tsip_unsubscribe(op,
- TSIP_ACTION_SET_HEADER("Persistence2", "action"),
- tsk_null);
- */
- /* INVITE */
- /*
- {
- tsip_ssession_handle_t *call = TSIP_SSESSION_CREATE(stack,
- TSIP_SSESSION_SET_HEADER("to", "sip:samba@"DOMAIN),
- TSIP_SSESSION_SET_CAPS("+g.3gpp.icsi-ref", "\"urn%3Aurn-7%3gpp-service.ims.icsi.mmtel\""),
- TSIP_SSESSION_SET_HEADER("Supported", "timer, norefersub, precondition"),
- TSIP_SSESSION_SET_HEADER("Require", "100rel"),
- TSIP_SSESSION_SET_PARAM("content", TEST_STACK_SDP),
- TSIP_SSESSION_SET_NULL());
- tsip_invite(stack, call);
- }
- */
- /* SUBSCRIBE */
- //{
- // tsip_ssession_handle_t *ss2 = tsip_ssession_create(stack,
- // TSIP_SSESSION_SET_CONTEXT(usr_context),
- // TSIP_SSESSION_SET_HEADER("expires", "35"),
- // TSIP_SSESSION_SET_HEADER("Event", "reg"),
- // TSIP_SSESSION_SET_HEADER("Accept", "application/reginfo+xml"),
- // TSIP_SSESSION_SET_HEADER("Allow-Events", "refer, presence, presence.winfo, xcap-diff"),
- // TSIP_SSESSION_SET_HEADER("Allow", "INVITE, ACK, CANCEL, BYE, MESSAGE, OPTIONS, NOTIFY, PRACK, UPDATE, REFER"),
- //
- // tsk_null);
- // tsip_subscribe(ss2,
- // TSIP_ACTION_SET_HEADER("Description", "subscribing"),
- // tsk_null);
- // getchar();
- // tsip_unsubscribe(ss2,
- // TSIP_ACTION_SET_HEADER("Test", "unsubscribing"),
- //
- // tsk_null);
- //}
- /* MESSAGE */
- //{
- // tsip_ssession_handle_t *ss3 = TSIP_SSESSION_CREATE(stack,
- // TSIP_SSESSION_SET_HEADER("to", "sip:alice@"DOMAIN),
- // TSIP_SSESSION_SET_HEADER("Accept-Contact", "*;+g.oma.sip-im"),
- //
- // tsk_null);
- // tsip_message(ss3,
- // TSIP_ACTION_SET_HEADER("Content-Type", "text/plain"),
- // TSIP_ACTION_SET_PAYLOAD("Hello world!", tsk_strlen("Hello world!")),
- // tsk_null
- // );
- //}
- /* PUBLISH */
- /*{
- tsip_ssession_handle_t *ss4 = TSIP_SSESSION_CREATE(stack,
- TSIP_SSESSION_SET_HEADER("expires", "30"),
- TSIP_SSESSION_SET_HEADER("to", "sip:mamadou@"DOMAIN),
- TSIP_SSESSION_SET_HEADER("Accept-Contact", "*;+g.oma.sip-im"),
- TSIP_SSESSION_SET_HEADER("Event", "presence"),
- tsk_null);
- tsip_publish(ss4,
- TSIP_ACTION_SET_HEADER("Description", "publish"),
- TSIP_ACTION_SET_HEADER("Content-Type", "application/pidf+xml"),
- TSIP_ACTION_SET_PAYLOAD(TEST_STACK_PIDF, tsk_strlen(TEST_STACK_PIDF)),
- tsk_null);
- getchar();
- tsip_unpublish(ss4,
- TSIP_ACTION_SET_HEADER("Description", "unpublish"),
- tsk_null);
- }
- */
- // /*getchar();
- // tsip_ssession_set(op4,
- // TSIP_SSESSION_SET_PARAM("content", TEST_STACK_PIDF),
- // TSIP_SSESSION_SET_NULL());
- // tsip_publish(stack, op4);*/
- //
- // getchar();
- // tsip_ssession_hangup(op4);
- //
- //}
- bail:
- //while(1);//tsk_thread_sleep(500);
- //while(1)
- //tsk_thread_sleep(50000);
- getchar();
- tsip_stack_stop(stack);
- TSK_OBJECT_SAFE_FREE(op);
- TSK_OBJECT_SAFE_FREE(stack);
- TSK_DEBUG_INFO("==================");
- TSK_DEBUG_INFO("==================");
- TSK_DEBUG_INFO("==================");
- TSK_DEBUG_INFO("==================");
- }
- #endif /* _TEST_STACK_H */
|