What are the code guidelines we must follow when developing for s-r ? I have
not found a code-guideline on the wiki.
I don't know if I used the correct LOG macros on the call_control module I
just taked a look at tm module and see that is used the LOG macros instead of
LM_* macros
--
Raúl Alexis Betancor Santana
Dimensión Virtual
Module: sip-router
Branch: master
Commit: 22f9bd6620b851848853befc677ce6b6b318c483
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=22f9bd6…
Author: Andrei Pelinescu-Onciul <andrei(a)iptel.org>
Committer: Andrei Pelinescu-Onciul <andrei(a)iptel.org>
Date: Thu Jun 11 20:25:47 2009 +0200
tm: t_check_trans ends script on neg. or local ACK
- t_check_trans will now end the script if the message is an ACK
to an existing transaction ended with a negative reply or an ACK
to a local transaction (as opposed to a normal proxied one).
Before ending the script it will process the ACK in the same way
t_newtran would, including calling the appropriate callbacks.
t_check_trans behaviour for other requests (e.g. retransmissions,
cancels, e2e ACK) remains unchanged.
- added missing callbacks for the retransmitted request case.
Reported-and-tested-by: Juha Heinanen jh at tutpro com.
---
modules/tm/tm.c | 32 ++++++++++++++++++++++----------
1 files changed, 22 insertions(+), 10 deletions(-)
diff --git a/modules/tm/tm.c b/modules/tm/tm.c
index 982681a..e769b75 100644
--- a/modules/tm/tm.c
+++ b/modules/tm/tm.c
@@ -1742,8 +1742,9 @@ int w_t_reply_wrp(struct sip_msg *m, unsigned int code, char *txt)
/** script function, check if a msg is assoc. to a transaction.
- * @return -1 (not), 1 (reply, ack or cancel for an existing transaction),
- * 0 (request retransmission)
+ * @return -1 (not), 1 (reply, e2e ack or cancel for an existing transaction),
+ * 0 (request retransmission, ack to negative reply or ack to local
+ * transaction)
* Note: the e2e ack matching works only for local e2e acks or for
* transactions with E2EACK* callbacks installed (but even in this
* case matching E2EACKs on proxied transaction is not entirely
@@ -1763,15 +1764,26 @@ static int t_check_trans(struct sip_msg* msg, char* foo, char* bar)
case -2: /* possible e2e ack */
return 1;
case 1: /* found */
- if (msg->REQ_METHOD==METHOD_ACK)
- /* ack to neg. reply */
- return 1;
- /* else retransmission */
t=get_t();
- t_retransmit_reply(t);
- UNREF(t);
- set_t(0);
- return 0;
+ if (msg->REQ_METHOD==METHOD_ACK){
+ /* ack to neg. reply or ack to local trans.
+ => process it and end the script */
+ /* FIXME: there's no way to distinguish here
+ between acks to local trans. and neg. acks */
+ if (unlikely(has_tran_tmcbs(t, TMCB_ACK_NEG_IN)))
+ run_trans_callbacks(TMCB_ACK_NEG_IN, t, msg,
+ 0, msg->REQ_METHOD);
+ t_release_transaction(t);
+ } else {
+ /* is a retransmission */
+ if (unlikely(has_tran_tmcbs(t, TMCB_REQ_RETR_IN)))
+ run_trans_callbacks(TMCB_REQ_RETR_IN, t, msg,
+ 0, msg->REQ_METHOD);
+ t_retransmit_reply(t);
+ }
+ /* no need for UNREF(t); set_t(0) - the end-of-script
+ t_unref callback will take care of them */
+ return 0; /* return from the script */
}
/* not found or error */
}
Module: sip-router
Branch: master
Commit: 6e729562274f7b5ec5230a7df2764f36ddb0f39f
URL: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=6e72956…
Author: Daniel-Constantin Mierla <miconda(a)gmail.com>
Committer: Daniel-Constantin Mierla <miconda(a)gmail.com>
Date: Thu Jun 11 21:02:47 2009 +0300
presence_xml: implementation of pv $xml(...)
- handling of xml docs using xpath
- $xml(name=>doc) - get/set an xml doc under 'name'
- $xml(name=>xpath:xpath-expression) - evaluate/update xpath extension
- example:
$xml(x=>doc) = '<?xml version="1.0" encoding="UTF-8"?><a><b>test</b></a>';
xlog("content of node b: $xml(a=>xpath:/a/b/text())\n");
$xml(a=>xpath:/a/b) = "1234";
- TODO list:
- extend presence modules to work also with xml documents from $xml() PV
- support to set node content to an xml tree
- usage:
- do routing decisions based on content of xml documents comming
with SIP messages (such as PUBLISH)
- update xml document content
- evaluate XPath-allowed expressions and functions, see:
http://www.w3.org/TR/xpath
---
modules_k/presence_xml/pv_xml.c | 463 +++++++++++++++++++++++++++++++++++++++
modules_k/presence_xml/pv_xml.h | 35 +++
2 files changed, 498 insertions(+), 0 deletions(-)
Diff: http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commitdiff;h=6e7…