Discussion:
[sr-dev] git:master:7d1e1a34: pv: support for Record-Route in $hfl(...)
Daniel-Constantin Mierla
2021-06-02 10:24:24 UTC
Permalink
Content preview: Module: kamailio Branch: master Commit: 7d1e1a349d5590f3754976b2e169fd30795c7f1b
URL: https://github.com/kamailio/kamailio/commit/7d1e1a349d5590f3754976b2e169fd30795c7f1b
Author: Daniel-Constantin Mierla <***@gmail.com> Committer: Daniel-Constantin
Mierla <***@gmail.com> Date: 2021-06-02T12:23:40+02:00

Content analysis details: (-2.4 points, 5.5 required)

pts rule name description
---- ---------------------- --------------------------------------------------
-1.0 ALL_TRUSTED Passed through trusted hosts only via SMTP
-1.9 BAYES_00 BODY: Bayes spam probability is 0 to 1%
[score: 0.0000]
0.0 DKIM_ADSP_CUSTOM_MED No valid author signature, adsp_override is
CUSTOM_MED
0.0 FREEMAIL_FROM Sender email is commonly abused enduser mail
provider (miconda[at]gmail.com)
0.2 HEADER_FROM_DIFFERENT_DOMAINS From and EnvelopeFrom 2nd level
mail domains are different
1.0 FORGED_GMAIL_RCVD 'From' gmail.com does not match 'Received'
headers
0.2 FREEMAIL_FORGED_FROMDOMAIN 2nd level domains in From and
EnvelopeFrom freemail headers are
different
-1.0 MAILING_LIST_MULTI Multiple indicators imply a widely-seen list
manager

Module: kamailio
Branch: master
Commit: 7d1e1a349d5590f3754976b2e169fd30795c7f1b
URL: https://github.com/kamailio/kamailio/commit/7d1e1a349d5590f3754976b2e169fd30795c7f1b

Author: Daniel-Constantin Mierla <***@gmail.com>
Committer: Daniel-Constantin Mierla <***@gmail.com>
Date: 2021-06-02T12:23:40+02:00

pv: support for Record-Route in $hfl(...)

---

Modified: src/modules/pv/pv_core.c

---

Diff: https://github.com/kamailio/kamailio/commit/7d1e1a349d5590f3754976b2e169fd30795c7f1b.diff
Patch: https://github.com/kamailio/kamailio/commit/7d1e1a349d5590f3754976b2e169fd30795c7f1b.patch

---

diff --git a/src/modules/pv/pv_core.c b/src/modules/pv/pv_core.c
index 4dc6d56882..65afab14e9 100644
--- a/src/modules/pv/pv_core.c
+++ b/src/modules/pv/pv_core.c
@@ -2190,6 +2190,7 @@ int pv_get_hfl(sip_msg_t *msg, pv_param_t *param, pv_value_t *res)
int idxf = 0;
pv_value_t tv = {0};
via_body_t *vb = NULL;
+ rr_t *rrb = NULL;
hdr_field_t *hf = NULL;
int n = 0;
str sval = STR_NULL;
@@ -2228,7 +2229,7 @@ int pv_get_hfl(sip_msg_t *msg, pv_param_t *param, pv_value_t *res)
if((tv.flags == 0) && (tv.ri==HDR_VIA_T)) {
if(idx<0) {
n = 1;
- /* count Vua header bodies */
+ /* count Via header bodies */
for(hf=msg->h_via1; hf!=NULL; hf=hf->next) {
if(hf->type==HDR_VIA_T) {
for(vb=(via_body_t*)hf->parsed; vb!=NULL; vb=vb->next) {
@@ -2270,6 +2271,64 @@ int pv_get_hfl(sip_msg_t *msg, pv_param_t *param, pv_value_t *res)
LM_DBG("unexpected via index out of range\n");
return pv_get_null(msg, param, res);
}
+ if((tv.flags == 0) && (tv.ri==HDR_RECORDROUTE_T)) {
+ if(idx<0) {
+ n = 1;
+ /* count Record-Route header bodies */
+ for(hf=msg->record_route; hf!=NULL; hf=hf->next) {
+ if(hf->type==HDR_RECORDROUTE_T) {
+ if(parse_rr(hf) == -1) {
+ LM_ERR("failed parsing rr header\n");
+ return pv_get_null(msg, param, res);
+ }
+ for(rrb=(rr_t*)hf->parsed; vb!=NULL; rrb=rrb->next) {
+ n++;
+ }
+ }
+ }
+
+ idx = -idx;
+ if(idx>n) {
+ LM_DBG("index out of rr headers range\n");
+ return pv_get_null(msg, param, res);
+ }
+ idx = n - idx;
+ }
+ if(idx==0) {
+ if(parse_rr(msg->record_route) == -1) {
+ LM_ERR("failed parsing rr header\n");
+ return pv_get_null(msg, param, res);
+ }
+ rrb = (rr_t*)(msg->record_route->parsed);
+ sval.s = rrb->nameaddr.name.s;
+ sval.len = rrb->len;
+ trim(&sval);
+ res->rs = sval;
+ return 0;
+ }
+ n=0;
+ for(hf=msg->record_route; hf!=NULL; hf=hf->next) {
+ if(hf->type==HDR_RECORDROUTE_T) {
+ if(parse_rr(hf) == -1) {
+ LM_ERR("failed parsing rr header\n");
+ return pv_get_null(msg, param, res);
+ }
+ for(rrb=(rr_t*)hf->parsed; vb!=NULL; rrb=rrb->next) {
+ if(n==idx) {
+ sval.s = rrb->nameaddr.name.s;
+ sval.len = rrb->len;
+ trim(&sval);
+ res->rs = sval;
+ return 0;
+ }
+ n++;
+ }
+ }
+ }
+ LM_DBG("unexpected record-route index out of range\n");
+ return pv_get_null(msg, param, res);
+ }
+
return pv_get_hdr_helper(msg, param, res, &tv, idx, idxf);
}

Loading...