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

Author: Daniel-Constantin Mierla <mico...@gmail.com>
Committer: Daniel-Constantin Mierla <mico...@gmail.com>
Date: 2018-09-08T21:29:11+02:00

htable: added sht_rm(htname, iname)

- api function to remove an item from hash table

---

Modified: src/modules/htable/htable.c

---

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

---

diff --git a/src/modules/htable/htable.c b/src/modules/htable/htable.c
index 214b6e3608..04c4bb7c9a 100644
--- a/src/modules/htable/htable.c
+++ b/src/modules/htable/htable.c
@@ -66,6 +66,7 @@ static int child_init(int rank);
 static void destroy(void);
 
 static int fixup_ht_key(void** param, int param_no);
+static int w_ht_rm(sip_msg_t* msg, char* htname, char* itname);
 static int ht_rm_name_re(struct sip_msg* msg, char* key, char* foo);
 static int ht_rm_value_re(struct sip_msg* msg, char* key, char* foo);
 static int w_ht_rm_name(struct sip_msg* msg, char* hname, char* op, char *val);
@@ -106,7 +107,9 @@ static pv_export_t mod_pvs[] = {
 
 
 static cmd_export_t cmds[]={
-       {"sht_print",       (cmd_function)ht_print,        0, 0, 0,
+       {"sht_print",       (cmd_function)ht_print,       0, 0, 0,
+               ANY_ROUTE},
+       {"sht_rm",      (cmd_function)w_ht_rm,  2, fixup_spve_spve, 0,
                ANY_ROUTE},
        {"sht_rm_name_re",  (cmd_function)ht_rm_name_re,   1, fixup_ht_key, 0,
                ANY_ROUTE},
@@ -543,6 +546,43 @@ static int ki_ht_rm_value(sip_msg_t* msg, str* sname, str* 
sop, str *sval)
        return ht_rm_items(msg, sname, sop, sval, 1);
 }
 
+static int ki_ht_rm(sip_msg_t* msg, str* hname, str* iname)
+{
+       ht_t *ht;
+
+       ht = ht_get_table(hname);
+       if(ht==NULL) {
+               LM_ERR("cannot get hash table [%.*s]\n", hname->len, hname->s);
+               return -1;
+       }
+
+       /* delete it */
+       if (ht->dmqreplicate>0
+                       && ht_dmq_replicate_action(HT_DMQ_DEL_CELL, hname,
+                               iname, 0, NULL, 0)!=0) {
+               LM_ERR("dmq relication failed\n");
+       }
+       ht_del_cell(ht, iname);
+       return 1;
+}
+
+static int w_ht_rm(sip_msg_t* msg, char* htname, char* itname)
+{
+       str shtname;
+       str sitname;
+
+       if(fixup_get_svalue(msg, (gparam_t*)htname, &shtname)<0 || 
shtname.len<=0) {
+               LM_ERR("cannot get the hash table name\n");
+               return -1;
+       }
+       if(fixup_get_svalue(msg, (gparam_t*)itname, &sitname)<0 || 
sitname.len<=0) {
+               LM_ERR("cannot get the item table name\n");
+               return -1;
+       }
+
+       return ki_ht_rm(msg, &shtname, &sitname);
+}
+
 static int ht_has_str_items(sip_msg_t* msg, str* hname, str* op, str *val,
                int mkey)
 {
@@ -1409,6 +1449,11 @@ static sr_kemi_t sr_kemi_htable_exports[] = {
                { SR_KEMIP_STR, SR_KEMIP_NONE, SR_KEMIP_NONE,
                        SR_KEMIP_NONE, SR_KEMIP_NONE, SR_KEMIP_NONE }
        },
+       { str_init("htable"), str_init("sht_rm"),
+               SR_KEMIP_INT, ki_ht_rm,
+               { SR_KEMIP_STR, SR_KEMIP_STR, SR_KEMIP_NONE,
+                       SR_KEMIP_NONE, SR_KEMIP_NONE, SR_KEMIP_NONE }
+       },
        { str_init("htable"), str_init("sht_rm_name_re"),
                SR_KEMIP_INT, ki_ht_rm_name_re,
                { SR_KEMIP_STR, SR_KEMIP_STR, SR_KEMIP_NONE,


_______________________________________________
Kamailio (SER) - Development Mailing List
sr-dev@lists.kamailio.org
https://lists.kamailio.org/cgi-bin/mailman/listinfo/sr-dev

Reply via email to