Module: sip-router
Branch: master
Commit: 9a46452cf724457edeea2cd0fd88a6652d22a61d
URL:    
http://git.sip-router.org/cgi-bin/gitweb.cgi/sip-router/?a=commit;h=9a46452cf724457edeea2cd0fd88a6652d22a61d

Author: Daniel-Constantin Mierla <[email protected]>
Committer: Daniel-Constantin Mierla <[email protected]>
Date:   Mon Sep  8 18:45:52 2014 +0200

pv: new variable $su to return source address in uri format

- $su is expanded "sip:$si:$sp;transport=$pr"
- example: "sip:127.0.0.1:5060;transport=udp"

---

 modules/pv/pv.c      |    3 ++
 modules/pv/pv_core.c |   91 ++++++++++++++++++++++++++++++++++---------------
 modules/pv/pv_core.h |    3 ++
 3 files changed, 69 insertions(+), 28 deletions(-)

diff --git a/modules/pv/pv.c b/modules/pv/pv.c
index 02726e2..53edc38 100644
--- a/modules/pv/pv.c
+++ b/modules/pv/pv.c
@@ -373,6 +373,9 @@ static pv_export_t mod_pvs[] = {
        {{"sp", (sizeof("sp")-1)}, /* */
                PVT_OTHER, pv_get_srcport, 0,
                0, 0, 0, 0},
+       {{"su", (sizeof("su")-1)}, /* */
+               PVT_OTHER, pv_get_srcaddr_uri, 0,
+               0, 0, 0, 0},
        {{"td", (sizeof("td")-1)}, /* */
                PVT_OTHER, pv_get_to_attr, pv_set_to_domain,
                0, 0, pv_init_iname, 3},
diff --git a/modules/pv/pv_core.c b/modules/pv/pv_core.c
index c0943e8..724ceb8 100644
--- a/modules/pv/pv_core.c
+++ b/modules/pv/pv_core.c
@@ -112,6 +112,37 @@ int pv_get_return_code(struct sip_msg *msg, pv_param_t 
*param,
 }
 */
 
+int pv_get_known_proto_string(int proto, str *sproto)
+{
+       switch(proto) {
+               case PROTO_UDP:
+                       sproto->s = "udp";
+                       sproto->len = 3;
+               return 0;
+               case PROTO_TCP:
+                       sproto->s = "tcp";
+                       sproto->len = 3;
+               return 0;
+               case PROTO_TLS:
+                       sproto->s = "tls";
+                       sproto->len = 3;
+               return 0;
+               case PROTO_SCTP:
+                       sproto->s = "sctp";
+                       sproto->len = 4;
+               return 0;
+               case PROTO_WS:
+                       sproto->s = "ws";
+                       sproto->len = 2;
+               return 0;
+               case PROTO_WSS:
+                       sproto->s = "wss";
+                       sproto->len = 3;
+               return 0;
+       }
+       return -1;
+}
+
 int pv_get_pid(struct sip_msg *msg, pv_param_t *param,
                pv_value_t *res)
 {
@@ -660,6 +691,35 @@ int pv_get_srcport(struct sip_msg *msg, pv_param_t *param,
        return pv_get_uintval(msg, param, res, msg->rcv.src_port);
 }
 
+int pv_get_srcaddr_uri(struct sip_msg *msg, pv_param_t *param,
+               pv_value_t *res)
+{
+       str sip;
+       str sproto;
+       str sr;
+
+       if(msg==NULL)
+               return -1;
+
+       if(pv_get_known_proto_string(msg->rcv.proto, &sproto)<0)
+               return pv_get_null(msg, param, res);
+
+       sip.s = ip_addr2a(&msg->rcv.src_ip);
+       sip.len = strlen(sip.s);
+       if (sip.len + sproto.len + 32 >= pv_get_buffer_size())
+       {
+               LM_ERR("local buffer size exceeded\n");
+               return pv_get_null(msg, param, res);
+       }
+
+       sr.s = pv_get_buffer();
+       sr.len = snprintf(sr.s, pv_get_buffer_size(),
+                       "sip:%.*s:%d;transport=%.*s", sip.len, sip.s,
+                       msg->rcv.src_port, sproto.len, sproto.s);
+
+       return pv_get_strval(msg, param, res, &sr);
+}
+
 int pv_get_rcvip(struct sip_msg *msg, pv_param_t *param,
                pv_value_t *res)
 {
@@ -1040,35 +1100,10 @@ int pv_get_proto(struct sip_msg *msg, pv_param_t *param,
        if(msg==NULL)
                return -1;
 
-       switch(msg->rcv.proto)
+       if(pv_get_known_proto_string(msg->rcv.proto, &s)<0)
        {
-               case PROTO_UDP:
-                       s.s = "udp";
-                       s.len = 3;
-               break;
-               case PROTO_TCP:
-                       s.s = "tcp";
-                       s.len = 3;
-               break;
-               case PROTO_TLS:
-                       s.s = "tls";
-                       s.len = 3;
-               break;
-               case PROTO_SCTP:
-                       s.s = "sctp";
-                       s.len = 4;
-               break;
-               case PROTO_WS:
-                       s.s = "ws";
-                       s.len = 2;
-               break;
-               case PROTO_WSS:
-                       s.s = "wss";
-                       s.len = 3;
-               break;
-               default:
-                       s.s = "NONE";
-                       s.len = 4;
+               s.s = "NONE";
+               s.len = 4;
        }
 
        return pv_get_strintval(msg, param, res, &s, (int)msg->rcv.proto);
diff --git a/modules/pv/pv_core.h b/modules/pv/pv_core.h
index a444ffe..9f2c6fc 100644
--- a/modules/pv/pv_core.h
+++ b/modules/pv/pv_core.h
@@ -132,6 +132,9 @@ int pv_get_srcip(struct sip_msg *msg, pv_param_t *param,
 int pv_get_srcport(struct sip_msg *msg, pv_param_t *param,
                pv_value_t *res);
 
+int pv_get_srcaddr_uri(struct sip_msg *msg, pv_param_t *param,
+               pv_value_t *res);
+
 int pv_get_rcvip(struct sip_msg *msg, pv_param_t *param,
                pv_value_t *res);
 


_______________________________________________
sr-dev mailing list
[email protected]
http://lists.sip-router.org/cgi-bin/mailman/listinfo/sr-dev

Reply via email to