Browse Source

pv: added $cts - contact header star status

- 1 if it is *, 0 otherwise
Daniel-Constantin Mierla 1 year ago
parent
commit
4eb39425e2
3 changed files with 28 additions and 0 deletions
  1. 2 0
      src/modules/pv/pv.c
  2. 23 0
      src/modules/pv/pv_core.c
  3. 3 0
      src/modules/pv/pv_core.h

+ 2 - 0
src/modules/pv/pv.c

@@ -163,6 +163,8 @@ static pv_export_t mod_pvs[] = {
 			PVT_OTHER, pv_get_cseq_body, 0, 0, 0, 0, 0},
 	{{"ct", (sizeof("ct") - 1)}, /* */
 			PVT_OTHER, pv_get_contact, 0, 0, 0, 0, 0},
+	{{"cts", (sizeof("cts") - 1)}, /* */
+			PVT_OTHER, pv_get_contact_star, 0, 0, 0, 0, 0},
 	{{"ctu", (sizeof("ctu") - 1)}, /* */
 			PVT_OTHER, pv_get_contact_uri, 0, 0, 0, 0, 0},
 	{{"cT", (sizeof("cT") - 1)}, /* */

+ 23 - 0
src/modules/pv/pv_core.c

@@ -404,6 +404,29 @@ int pv_get_contact_uri(struct sip_msg *msg, pv_param_t *param, pv_value_t *res)
 	return pv_get_strval(msg, param, res, &cb->contacts->uri);
 }
 
+int pv_get_contact_star(struct sip_msg *msg, pv_param_t *param, pv_value_t *res)
+{
+	contact_body_t *cb = NULL;
+
+	if(msg == NULL)
+		return -1;
+
+	if(msg->contact == NULL && parse_headers(msg, HDR_CONTACT_F, 0) == -1) {
+		LM_DBG("no contact header\n");
+		return pv_get_null(msg, param, res);
+	}
+	if(parse_contact_headers(msg) < 0) {
+		return pv_get_null(msg, param, res);
+	}
+
+	cb = (contact_body_t *)msg->contact->parsed;
+
+	if(cb->star == 1) {
+		return pv_get_uintval(msg, param, res, 1);
+	}
+	return pv_get_uintval(msg, param, res, 0);
+}
+
 int pv_get_xto_attr(struct sip_msg *msg, pv_param_t *param, pv_value_t *res,
 		struct to_body *xto, int type)
 {

+ 3 - 0
src/modules/pv/pv_core.h

@@ -67,6 +67,9 @@ int pv_get_contact(struct sip_msg *msg, pv_param_t *param, pv_value_t *res);
 
 int pv_get_contact_uri(struct sip_msg *msg, pv_param_t *param, pv_value_t *res);
 
+int pv_get_contact_star(
+		struct sip_msg *msg, pv_param_t *param, pv_value_t *res);
+
 int pv_get_xto_attr(struct sip_msg *msg, pv_param_t *param, pv_value_t *res,
 		struct to_body *xto, int type);