您的位置:首页 > 其它

QuteCom手记:exosip初始化和构建INVITE请求

2011-07-01 17:33 399 查看
@1、exosip初始化
qutecom/wifo/phapi/phapi.c
fun:owplInit()
Line:291

eXosip_set_user_agent(ua);设置SIP包头域User-Agent="qutecom/rev-335d495adbc1-trunk",即SIP客户端名称。
return_code = eXosip_init(0,0,udpPort,tcpPort,tlsPort);
if (return_code != 0){
owplLogError("eXosip_init failed");
return OWPL_RESULT_FAILURE;
}
//...
{
const char * ua=QUTECOM_UA;
eXosip_set_user_agent(ua);
}


@2、创建一个INVITE请求包
拨出电话需要构建一个INVITE发给服务器,服务器转发给另一个UAC。

调用关系:
PhApiWrapper::makeCall()
==>owplCallConnect()
==>phLinePlaceCall_withCa()
==>eXosip_build_initial_invite()
函数声明:
qutecom/wifo/eXosip/include/eXosip/eXosip.h

/**
* Build a default INVITE message for a new call.
*
* @param invite    Pointer for the SIP element to hold.
* @param to        SIP url for callee. * @param from      SIP url for caller.
* @param route     Route header for INVITE. (optionnal)
* @param subject   Subject for the call.
*/
int   eXosip_build_initial_invite(osip_message_t **invite, char *to, char *from, char *route, char *subject);


作用:
构建一个INVITE消息。
实现:
File: qutecom/wifo/eXosip/src/jrequest.c

/* this method can't be called unless the previous   INVITE transaction is over. */
int eXosip_build_initial_invite(osip_message_t **invite, char *to, char *from,char *route, char *subject){
int i;  if (to!=NULL && *to=='/0')
return -1;  osip_clrspace(to);
//清除空格  osip_clrspace(subject);
osip_clrspace(from);
osip_clrspace(route);
if (route!=NULL && *route=='/0')
route=NULL;
if (subject!=NULL && *subject=='/0')
subject=NULL;
//构建INVITE包
i = generating_request_out_of_dialog(invite, "INVITE", to, from, route);
if (i!=0) return -1;
#if 0  if (subject==NULL)
osip_message_set_subject(*invite, "New Call");
else  osip_message_set_subject(*invite, subject);
#else  if (subject!=NULL)
osip_message_set_subject(*invite, subject);
//设置SIP头域的SUBJECT字段 //"Subject: Phone call"
#endif  /* after this delay, we should send a CANCEL */
//设置超时
owsip_message_set_expires(*invite, "120");
/* osip_message_set_organization(*invite, "Jack's Org"); */
return 0;}


函数generating_request_out_of_dialog调用generating_request_out_of_dialog2

generating_request_out_of_dialog2在qutecom/wifo/eXosip/src/jrequest.c实现
部分代码
static intgenerating_request_out_of_dialog2(osip_message_t **dest, char *method_name, char *to, char *from, char *proxy, int seqnum){
//...
i = osip_message_init(&request);
//初始化  if (i!=0) return -1;
/* prepare the request-line */
osip_message_set_method(request, osip_strdup(method_name));
osip_message_set_version(request, osip_strdup("SIP/2.0"));//"INVITE sip:to@192.168.105.14 SIP/2.0"
osip_message_set_status_code(request, 0);
osip_message_set_reason_phrase(request, NULL);//
//...
i = osip_message_set_to(request, to);//"To: <sip:to@192.168.105.14>"
//...
osip_message_set_from(request, from);//
osip_from_set_tag(request->from, osip_from_tag_new_random());//"rom: <sip:from@192.168.105.5>;tag=29244"
//...
osip_call_id_set_number(callid, cidrand);//"Call-ID: 8103"
//...  osip_cseq_set_number(cseq, num);
osip_cseq_set_method(cseq, osip_strdup(method_name));
request->cseq = cseq; //"CSeq: 20 INVITE"
//...
osip_message_set_max_forwards(request, "70");
/* a UA should start a request with 70 */
//Max-Forwards: 70
//...
osip_message_set_via(request, tmp);//"Via: SIP/2.0/UDP 192.168.105.5:5060;rport;branch=z9hG4bK2195"
//...
osip_message_set_contact (request, contact) ;//"Contact: <sip:from@192.168.105.5:5060>"
//...
osip_message_set_user_agent(request, eXosip.user_agent);//"User-Agent: QuteCom2.2.1 (eXosip2/3.3.0)"
//...
//设定完头域后,INVITE消息应该长得像这样:
//INVITE sip:to@192.168.105.14 SIP/2.0
//Via: SIP/2.0/UDP 192.168.105.5:5060;rport;branch=z9hG4bK2195
//From: <sip:from@192.168.105.5>;tag=29244
//To: <sip:to@192.168.105.14>
//Call-ID: 8103
//CSeq: 20 INVITE
//Contact: <sip:from@192.168.105.5:5060>
//Max-Forwards: 70
//User-Agent: Linphone/3.2.1 (eXosip2/3.3.0)
//Subject: Phone call  //subject在eXosip_build_initial_invite中被设置。在本函数调用后随即调用
}

这个函数调用了oSip2库的一系列xxsetxx函数设置INVITE包的各个头域。
头域的定义在《sip中文参考手册》P122 20 头域一节有完整说明
《sip中文参考手册》已经放在资源中。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: