- Timestamp:
- Feb 9, 2006 9:30:09 AM (19 years ago)
- Location:
- pjproject/trunk/pjsip
- Files:
-
- 1 added
- 1 deleted
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
pjproject/trunk/pjsip/build/pjsua.dsp
r156 r167 99 99 # Begin Source File 100 100 101 SOURCE=..\src\pjsua\main_old.c 102 # PROP Exclude_From_Build 1 101 SOURCE=..\src\pjsua\pjsua_core.c 103 102 # End Source File 104 103 # Begin Source File 105 104 106 SOURCE=..\src\pjsua\misc.c 107 # PROP Exclude_From_Build 1 108 # End Source File 109 # Begin Source File 110 111 SOURCE=..\src\pjsua\pjsua_core.c 105 SOURCE=..\src\pjsua\pjsua_inv.c 112 106 # End Source File 113 107 # Begin Source File -
pjproject/trunk/pjsip/include/pjsip-ua/sip_regc.h
- Property svn:keywords set to id
r141 r167 142 142 * Set authentication credentials to use by this registration. 143 143 * 144 * @param dlgThe registration structure.144 * @param regc The registration structure. 145 145 * @param count Number of credentials in the array. 146 146 * @param cred Array of credentials. … … 153 153 154 154 /** 155 * Set route set to be used for outgoing requests. 156 * 157 * @param regc The client registration structure. 158 * @param route_set List containing Route headers. 159 * 160 * @return PJ_SUCCESS on success. 161 */ 162 PJ_DECL(pj_status_t) pjsip_regc_set_route_set(pjsip_regc *regc, 163 const pjsip_route_hdr*route_set); 164 165 /** 155 166 * Create REGISTER request for the specified client registration structure. 156 167 * -
pjproject/trunk/pjsip/include/pjsip/print_util.h
- Property svn:keywords changed from Id to id
-
pjproject/trunk/pjsip/src/pjsip-ua/sip_reg.c
- Property svn:keywords set to id
r141 r167 42 42 struct pjsip_regc 43 43 { 44 pj_pool_t 45 pjsip_endpoint *endpt;46 pj_bool_t _delete_flag;47 int pending_tsx;48 49 void *token;50 pjsip_regc_cb *cb;51 52 pj_str_t str_srv_url;53 pjsip_uri *srv_url;54 pjsip_cid_hdr *cid_hdr;55 pjsip_cseq_hdr *cseq_hdr;56 pjsip_from_hdr *from_hdr;57 pjsip_to_hdr *to_hdr;58 char *contact_buf;44 pj_pool_t *pool; 45 pjsip_endpoint *endpt; 46 pj_bool_t _delete_flag; 47 int pending_tsx; 48 49 void *token; 50 pjsip_regc_cb *cb; 51 52 pj_str_t str_srv_url; 53 pjsip_uri *srv_url; 54 pjsip_cid_hdr *cid_hdr; 55 pjsip_cseq_hdr *cseq_hdr; 56 pjsip_from_hdr *from_hdr; 57 pjsip_to_hdr *to_hdr; 58 char *contact_buf; 59 59 pjsip_generic_string_hdr *contact_hdr; 60 pjsip_expires_hdr *expires_hdr; 61 pjsip_contact_hdr *unreg_contact_hdr; 62 pjsip_expires_hdr *unreg_expires_hdr; 63 pj_uint32_t expires; 60 pjsip_expires_hdr *expires_hdr; 61 pjsip_contact_hdr *unreg_contact_hdr; 62 pjsip_expires_hdr *unreg_expires_hdr; 63 pj_uint32_t expires; 64 pjsip_route_hdr route_set; 64 65 65 66 /* Authorization sessions. */ 66 pjsip_auth_clt_sess auth_sess;67 pjsip_auth_clt_sess auth_sess; 67 68 68 69 /* Auto refresh registration. */ 69 pj_bool_t auto_reg;70 pj_timer_entry timer;70 pj_bool_t auto_reg; 71 pj_timer_entry timer; 71 72 }; 72 73 … … 99 100 if (status != PJ_SUCCESS) 100 101 return status; 102 103 pj_list_init(®c->route_set); 101 104 102 105 /* Done */ … … 247 250 PJ_ASSERT_RETURN(regc && count && cred, PJ_EINVAL); 248 251 return pjsip_auth_clt_set_credentials(®c->auth_sess, count, cred); 252 } 253 254 PJ_DEF(pj_status_t) pjsip_regc_set_route_set( pjsip_regc *regc, 255 const pjsip_route_hdr *route_set) 256 { 257 const pjsip_route_hdr *chdr; 258 259 PJ_ASSERT_RETURN(regc && route_set, PJ_EINVAL); 260 261 pj_list_init(®c->route_set); 262 263 chdr = route_set->next; 264 while (chdr != route_set) { 265 pj_list_push_back(®c->route_set, pjsip_hdr_clone(regc->pool, chdr)); 266 chdr = chdr->next; 267 } 268 269 return PJ_SUCCESS; 249 270 } 250 271 … … 273 294 /* Add cached authorization headers. */ 274 295 pjsip_auth_clt_init_req( ®c->auth_sess, tdata ); 296 297 /* Add Route headers from route set, ideally after Via header */ 298 if (!pj_list_empty(®c->route_set)) { 299 pjsip_hdr *route_pos; 300 const pjsip_route_hdr *route; 301 302 route_pos = pjsip_msg_find_hdr(tdata->msg, PJSIP_H_VIA, NULL); 303 if (!route_pos) 304 route_pos = &tdata->msg->hdr; 305 306 route = regc->route_set.next; 307 while (route != ®c->route_set) { 308 pjsip_hdr *new_hdr = pjsip_hdr_shallow_clone(tdata->pool, route); 309 pj_list_insert_after(route_pos, new_hdr); 310 route_pos = new_hdr; 311 route = route->next; 312 } 313 } 275 314 276 315 /* Done. */ -
pjproject/trunk/pjsip/src/pjsua/getopt.c
- Property svn:keywords set to id
-
pjproject/trunk/pjsip/src/pjsua/getopt.h
- Property svn:keywords set to id
-
pjproject/trunk/pjsip/src/pjsua/main.c
- Property svn:keywords set to id
r160 r167 62 62 puts(""); 63 63 puts("Console keys:"); 64 puts(" m Make a call ");64 puts(" m Make a call/another call"); 65 65 puts(" a Answer incoming call"); 66 66 puts(" h Hangup current call"); … … 353 353 puts(" --use-stun2=host[:port] Use STUN and set host name and port of STUN servers"); 354 354 puts(""); 355 puts("SIMPLE options (may be specified more than once):");356 puts(" --add-buddy url Add the specified URL to the buddy list.");357 puts(" --offer-x-ms-msg Offer \"x-ms-message\" in outgoing INVITE");358 puts(" --no-presence Do not subscribe presence of buddies");355 //puts("SIMPLE options (may be specified more than once):"); 356 //puts(" --add-buddy url Add the specified URL to the buddy list."); 357 //puts(" --offer-x-ms-msg Offer \"x-ms-message\" in outgoing INVITE"); 358 //puts(" --no-presence Do not subscribe presence of buddies"); 359 359 puts(""); 360 360 fflush(stdout); -
pjproject/trunk/pjsip/src/pjsua/pjsua.h
r162 r167 129 129 130 130 /***************************************************************************** 131 * PJSUA API .131 * PJSUA API (defined in pjsua_core.c). 132 132 */ 133 133 … … 172 172 173 173 174 /***************************************************************************** 175 * PJSUA Invite session API (defined in pjsua_inv.c). 176 */ 177 174 178 /** 175 179 * Make outgoing call. … … 179 183 180 184 181 /***************************************************************************** 182 * PJSUA Client Registration API. 185 /** 186 * Handle incoming invite request. 187 */ 188 pj_bool_t pjsua_inv_on_incoming(pjsip_rx_data *rdata); 189 190 191 /** 192 * Callback to be called by session when invite session's state has changed. 193 */ 194 void pjsua_inv_on_state_changed(pjsip_inv_session *inv, pjsip_event *e); 195 196 197 /** 198 * Callback to be called by session when outgoing dialog has forked. 199 * This function will create a forked dialog. 200 */ 201 void pjsua_inv_on_new_session(pjsip_inv_session *inv, pjsip_event *e); 202 203 204 /** 205 * Callback to be called when SDP offer/answer negotiation has just completed 206 * in the session. This function will start/update media if negotiation 207 * has succeeded. 208 */ 209 void pjsua_inv_on_media_update(pjsip_inv_session *inv, pj_status_t status); 210 211 212 /***************************************************************************** 213 * PJSUA Client Registration API (defined in pjsua_reg.c). 183 214 */ 184 215 … … 199 230 /***************************************************************************** 200 231 * User Interface API. 232 * 201 233 * The UI API specifies functions that will be called by pjsua upon 202 234 * occurence of various events. -
pjproject/trunk/pjsip/src/pjsua/pjsua_core.c
r163 r167 19 19 #include "pjsua.h" 20 20 21 22 #define THIS_FILE "pjsua.c" 23 21 /* 22 * pjsua_core.c 23 * 24 * Core application functionalities. 25 */ 26 27 #define THIS_FILE "pjsua_core.c" 28 29 30 /* 31 * Global variable. 32 */ 24 33 struct pjsua pjsua; 25 34 35 26 36 /* 27 * Default local URI, if no tspecified in cmd-line37 * Default local URI, if none is specified in cmd-line 28 38 */ 29 39 #define PJSUA_LOCAL_URI "<sip:user@127.0.0.1>" … … 93 103 static pj_bool_t mod_pjsua_on_rx_request(pjsip_rx_data *rdata) 94 104 { 95 pjsip_dialog *dlg = pjsip_rdata_get_dlg(rdata); 96 pjsip_transaction *tsx = pjsip_rdata_get_tsx(rdata); 97 pjsip_msg *msg = rdata->msg_info.msg; 98 99 /* 100 * Handle incoming INVITE outside dialog. 101 */ 102 if (dlg == NULL && tsx == NULL && 103 msg->line.req.method.id == PJSIP_INVITE_METHOD) 104 { 105 pj_status_t status; 106 pjsip_tx_data *response = NULL; 107 unsigned options = 0; 108 109 /* Verify that we can handle the request. */ 110 status = pjsip_inv_verify_request(rdata, &options, NULL, NULL, 111 pjsua.endpt, &response); 112 if (status != PJ_SUCCESS) { 113 114 /* 115 * No we can't handle the incoming INVITE request. 116 */ 117 118 if (response) { 119 pjsip_response_addr res_addr; 120 121 pjsip_get_response_addr(response->pool, rdata, &res_addr); 122 pjsip_endpt_send_response(pjsua.endpt, &res_addr, response, 123 NULL, NULL); 124 125 } else { 126 127 /* Respond with 500 (Internal Server Error) */ 128 pjsip_endpt_respond_stateless(pjsua.endpt, rdata, 500, NULL, 129 NULL, NULL); 130 } 131 132 } else { 133 /* 134 * Yes we can handle the incoming INVITE request. 135 */ 136 pjsip_inv_session *inv; 137 struct pjsua_inv_data *inv_data; 138 pjmedia_sdp_session *answer; 139 140 141 /* Get media capability from media endpoint: */ 142 143 status = pjmedia_endpt_create_sdp( pjsua.med_endpt, rdata->tp_info.pool, 144 1, &pjsua.med_skinfo, &answer ); 145 if (status != PJ_SUCCESS) { 146 147 pjsip_endpt_respond_stateless(pjsua.endpt, rdata, 500, NULL, 148 NULL, NULL); 149 return PJ_TRUE; 150 } 151 152 /* Create dialog: */ 153 154 status = pjsip_dlg_create_uas( pjsip_ua_instance(), rdata, 155 &pjsua.contact_uri, &dlg); 156 if (status != PJ_SUCCESS) 157 return PJ_TRUE; 158 159 160 /* Create invite session: */ 161 162 status = pjsip_inv_create_uas( dlg, rdata, answer, 0, &inv); 163 if (status != PJ_SUCCESS) { 164 165 status = pjsip_dlg_create_response( dlg, rdata, 500, NULL, 166 &response); 167 if (status == PJ_SUCCESS) 168 status = pjsip_dlg_send_response(dlg, 169 pjsip_rdata_get_tsx(rdata), 170 response); 171 return PJ_TRUE; 172 173 } 174 175 176 /* Create and attach pjsua data to the dialog: */ 177 178 inv_data = pj_pool_zalloc(dlg->pool, sizeof(struct pjsua_inv_data)); 179 dlg->mod_data[pjsua.mod.id] = inv_data; 180 181 182 /* Answer with 100 (using the dialog, not invite): */ 183 184 status = pjsip_dlg_create_response(dlg, rdata, 100, NULL, &response); 185 if (status == PJ_SUCCESS) 186 status = pjsip_dlg_send_response(dlg, pjsip_rdata_get_tsx(rdata), response); 187 } 188 189 /* This INVITE request has been handled. */ 190 return PJ_TRUE; 191 } 192 193 105 106 if (rdata->msg_info.msg->line.req.method.id == PJSIP_INVITE_METHOD) { 107 108 return pjsua_inv_on_incoming(rdata); 109 110 } 194 111 195 112 return PJ_FALSE; … … 214 131 } 215 132 216 217 /*218 * This callback receives notification from invite session when the219 * session state has changed.220 */221 static void pjsua_inv_on_state_changed(pjsip_inv_session *inv, pjsip_event *e)222 {223 224 /* Destroy media session when invite session is disconnected. */225 if (inv->state == PJSIP_INV_STATE_DISCONNECTED) {226 struct pjsua_inv_data *inv_data;227 228 inv_data = inv->dlg->mod_data[pjsua.mod.id];229 if (inv_data && inv_data->session) {230 pjmedia_session_destroy(inv_data->session);231 inv_data->session = NULL;232 233 PJ_LOG(3,(THIS_FILE,"Media session is destroyed"));234 }235 236 }237 238 pjsua_ui_inv_on_state_changed(inv, e);239 }240 241 242 /*243 * This callback is called by invite session framework when UAC session244 * has forked.245 */246 static void pjsua_inv_on_new_session(pjsip_inv_session *inv, pjsip_event *e)247 {248 PJ_UNUSED_ARG(inv);249 PJ_UNUSED_ARG(e);250 251 PJ_TODO(HANDLE_FORKED_DIALOG);252 }253 254 /*255 *256 */257 static void pjsua_inv_on_media_update(pjsip_inv_session *inv,258 pj_status_t status)259 {260 struct pjsua_inv_data *inv_data;261 const pjmedia_sdp_session *local_sdp;262 const pjmedia_sdp_session *remote_sdp;263 264 if (status != PJ_SUCCESS) {265 266 pjsua_perror("SDP negotiation has failed", status);267 return;268 269 }270 271 /* Destroy existing media session, if any. */272 273 inv_data = inv->dlg->mod_data[pjsua.mod.id];274 if (inv_data && inv_data->session) {275 pjmedia_session_destroy(inv_data->session);276 inv_data->session = NULL;277 }278 279 /* Get local and remote SDP */280 281 status = pjmedia_sdp_neg_get_active_local(inv->neg, &local_sdp);282 if (status != PJ_SUCCESS) {283 pjsua_perror("Unable to retrieve currently active local SDP", status);284 return;285 }286 287 288 status = pjmedia_sdp_neg_get_active_remote(inv->neg, &remote_sdp);289 if (status != PJ_SUCCESS) {290 pjsua_perror("Unable to retrieve currently active remote SDP", status);291 return;292 }293 294 295 /* Create new media session.296 * The media session is active immediately.297 */298 299 status = pjmedia_session_create( pjsua.med_endpt, 1, &pjsua.med_skinfo,300 local_sdp, remote_sdp, &inv_data->session );301 if (status != PJ_SUCCESS) {302 pjsua_perror("Unable to create media session", status);303 return;304 }305 306 PJ_LOG(3,(THIS_FILE,"Media has been started successfully"));307 }308 133 309 134 /* … … 846 671 847 672 /* Destroy endpoint. */ 673 848 674 pjsip_endpt_destroy(pjsua.endpt); 849 675 pjsua.endpt = NULL; 850 676 851 677 /* Destroy caching pool. */ 678 852 679 pj_caching_pool_destroy(&pjsua.cp); 853 680 … … 858 685 } 859 686 860 861 /**862 * Make outgoing call.863 */864 pj_status_t pjsua_invite(const char *cstr_dest_uri,865 pjsip_inv_session **p_inv)866 {867 pj_str_t dest_uri;868 pjsip_dialog *dlg;869 pjmedia_sdp_session *offer;870 pjsip_inv_session *inv;871 struct pjsua_inv_data *inv_data;872 pjsip_tx_data *tdata;873 pj_status_t status;874 875 /* Convert cstr_dest_uri to dest_uri */876 877 dest_uri = pj_str((char*)cstr_dest_uri);878 879 /* Create outgoing dialog: */880 881 status = pjsip_dlg_create_uac( pjsip_ua_instance(), &pjsua.local_uri,882 &pjsua.contact_uri, &dest_uri, &dest_uri,883 &dlg);884 if (status != PJ_SUCCESS) {885 pjsua_perror("Dialog creation failed", status);886 return status;887 }888 889 /* Get media capability from media endpoint: */890 891 status = pjmedia_endpt_create_sdp( pjsua.med_endpt, dlg->pool,892 1, &pjsua.med_skinfo, &offer);893 if (status != PJ_SUCCESS) {894 pjsua_perror("pjmedia unable to create SDP", status);895 goto on_error;896 }897 898 /* Create the INVITE session: */899 900 status = pjsip_inv_create_uac( dlg, offer, 0, &inv);901 if (status != PJ_SUCCESS) {902 pjsua_perror("Invite session creation failed", status);903 goto on_error;904 }905 906 907 /* Create and associate our data in the session. */908 909 inv_data = pj_pool_zalloc( dlg->pool, sizeof(struct pjsua_inv_data));910 dlg->mod_data[pjsua.mod.id] = inv_data;911 912 913 /* Set dialog Route-Set: */914 915 if (!pj_list_empty(&pjsua.route_set))916 pjsip_dlg_set_route_set(dlg, &pjsua.route_set);917 918 919 /* Set credentials: */920 921 pjsip_auth_clt_set_credentials( &dlg->auth_sess, pjsua.cred_count,922 pjsua.cred_info);923 924 925 /* Create initial INVITE: */926 927 status = pjsip_inv_invite(inv, &tdata);928 if (status != PJ_SUCCESS) {929 pjsua_perror("Unable to create initial INVITE request", status);930 goto on_error;931 }932 933 934 /* Send initial INVITE: */935 936 status = pjsip_inv_send_msg(inv, tdata, NULL);937 if (status != PJ_SUCCESS) {938 pjsua_perror("Unable to send initial INVITE request", status);939 goto on_error;940 }941 942 943 /* Done. */944 945 *p_inv = inv;946 947 return PJ_SUCCESS;948 949 950 on_error:951 952 PJ_TODO(DESTROY_DIALOG_ON_FAIL);953 return status;954 }955 -
pjproject/trunk/pjsip/src/pjsua/pjsua_reg.c
r149 r167 19 19 #include "pjsua.h" 20 20 21 22 /* 23 * pjsua_reg.c 24 * 25 * Client registration handler. 26 */ 27 21 28 #define THIS_FILE "pjsua_reg.c" 22 29 30 31 /* 32 * This callback is called by pjsip_regc when outgoing register 33 * request has completed. 34 */ 23 35 static void regc_cb(struct pjsip_regc_cbparam *param) 24 36 { … … 98 110 pjsip_regc_set_credentials( pjsua.regc, pjsua.cred_count, 99 111 pjsua.cred_info ); 112 113 pjsip_regc_set_route_set( pjsua.regc, &pjsua.route_set ); 100 114 } 101 115
Note: See TracChangeset
for help on using the changeset viewer.