Selaa lähdekoodia

modules_k/presence Change delete sql query to use key

The delete operation in active_watchers is now performed on
callid, to_tag, from_tag.
Anca Vamanu 13 vuotta sitten
vanhempi
commit
5ccf1eedb4

+ 16 - 6
modules_k/presence/notify.c

@@ -1591,9 +1591,9 @@ void p_tm_callback( struct cell *t, int type, struct tmcb_params *ps)
 	c_back_param*  cb;
 	c_back_param*  cb;
 
 
 	if(ps->param==NULL || *ps->param==NULL ||
 	if(ps->param==NULL || *ps->param==NULL ||
-			((c_back_param*)(*ps->param))->pres_uri.s == NULL ||
-			((c_back_param*)(*ps->param))->ev_name.s== NULL ||
-			((c_back_param*)(*ps->param))->to_tag.s== NULL)
+			((c_back_param*)(*ps->param))->callid.s == NULL ||
+			((c_back_param*)(*ps->param))->to_tag.s== NULL ||
+			((c_back_param*)(*ps->param))->from_tag.s== NULL)
 	{
 	{
 		LM_DBG("message id not received, probably a timeout notify\n");
 		LM_DBG("message id not received, probably a timeout notify\n");
 		if(ps->param != NULL && *ps->param !=NULL)
 		if(ps->param != NULL && *ps->param !=NULL)
@@ -1606,7 +1606,8 @@ void p_tm_callback( struct cell *t, int type, struct tmcb_params *ps)
 			ps->code, cb->to_tag.len, cb->to_tag.s);
 			ps->code, cb->to_tag.len, cb->to_tag.s);
 
 
 	if(ps->code == 481 || (ps->code == 408 && timeout_rm_subs))
 	if(ps->code == 481 || (ps->code == 408 && timeout_rm_subs))
-		delete_subs(&cb->pres_uri, &cb->ev_name, &cb->to_tag);
+		delete_subs(&cb->pres_uri, &cb->ev_name,
+				&cb->to_tag, &cb->from_tag, &cb->callid);
 
 
 	free_cbparam(cb);
 	free_cbparam(cb);
 }
 }
@@ -1622,8 +1623,9 @@ c_back_param* shm_dup_cbparam(subs_t* subs)
 	int size;
 	int size;
 	c_back_param* cb_param = NULL;
 	c_back_param* cb_param = NULL;
 	
 	
-	size = sizeof(c_back_param) + subs->pres_uri.len+
-			subs->event->name.len + subs->to_tag.len;
+	size = sizeof(c_back_param) + subs->pres_uri.len +
+			subs->event->name.len + subs->to_tag.len +
+			subs->from_tag.len + subs->callid.len;
 
 
 	cb_param= (c_back_param*)shm_malloc(size);
 	cb_param= (c_back_param*)shm_malloc(size);
 	LM_DBG("=== %d/%d/%d\n", subs->pres_uri.len,
 	LM_DBG("=== %d/%d/%d\n", subs->pres_uri.len,
@@ -1645,6 +1647,14 @@ c_back_param* shm_dup_cbparam(subs_t* subs)
 	memcpy(cb_param->to_tag.s, subs->to_tag.s, subs->to_tag.len);
 	memcpy(cb_param->to_tag.s, subs->to_tag.s, subs->to_tag.len);
 	cb_param->to_tag.len = subs->to_tag.len;
 	cb_param->to_tag.len = subs->to_tag.len;
 
 
+	cb_param->from_tag.s = (char*)(cb_param->to_tag.s) + cb_param->to_tag.len;
+	memcpy(cb_param->from_tag.s, subs->from_tag.s, subs->from_tag.len);
+	cb_param->from_tag.len = subs->from_tag.len;
+
+	cb_param->callid.s = (char*)(cb_param->from_tag.s) + cb_param->from_tag.len;
+	memcpy(cb_param->callid.s, subs->callid.s, subs->callid.len);
+	cb_param->callid.len = subs->callid.len;
+
 	return cb_param;
 	return cb_param;
 }
 }
 
 

+ 2 - 1
modules_k/presence/notify.h

@@ -65,7 +65,8 @@ typedef struct wid_cback
 	str pres_uri;
 	str pres_uri;
 	str ev_name;
 	str ev_name;
 	str to_tag;   /* to identify the exact record */
 	str to_tag;   /* to identify the exact record */
-	subs_t* wi_subs;
+	str from_tag;
+	str callid;
 }c_back_param;
 }c_back_param;
 
 
 extern str str_to_user_col;
 extern str str_to_user_col;

+ 15 - 13
modules_k/presence/subscribe.c

@@ -138,30 +138,30 @@ error:
 }
 }
 
 
 
 
-int delete_db_subs(str* pres_uri, str* ev_stored_name, str* to_tag)
+int delete_db_subs(str* to_tag, str* from_tag, str* callid)
 {
 {
-	db_key_t query_cols[5];
-	db_val_t query_vals[5];
+	db_key_t query_cols[3];
+	db_val_t query_vals[3];
 	int n_query_cols= 0;
 	int n_query_cols= 0;
 
 
-	query_cols[n_query_cols] = &str_presentity_uri_col;
+	query_cols[n_query_cols] = &str_callid_col;
 	query_vals[n_query_cols].type = DB1_STR;
 	query_vals[n_query_cols].type = DB1_STR;
 	query_vals[n_query_cols].nul = 0;
 	query_vals[n_query_cols].nul = 0;
-	query_vals[n_query_cols].val.str_val = *pres_uri;
+	query_vals[n_query_cols].val.str_val = *callid;
 	n_query_cols++;
 	n_query_cols++;
 
 
-	query_cols[n_query_cols] = &str_event_col;
+	query_cols[n_query_cols] = &str_to_tag_col;
 	query_vals[n_query_cols].type = DB1_STR;
 	query_vals[n_query_cols].type = DB1_STR;
 	query_vals[n_query_cols].nul = 0;
 	query_vals[n_query_cols].nul = 0;
-	query_vals[n_query_cols].val.str_val = *ev_stored_name;
+	query_vals[n_query_cols].val.str_val = *to_tag;
 	n_query_cols++;
 	n_query_cols++;
 
 
-	query_cols[n_query_cols] = &str_to_tag_col;
+	query_cols[n_query_cols] = &str_from_tag_col;
 	query_vals[n_query_cols].type = DB1_STR;
 	query_vals[n_query_cols].type = DB1_STR;
 	query_vals[n_query_cols].nul = 0;
 	query_vals[n_query_cols].nul = 0;
-	query_vals[n_query_cols].val.str_val = *to_tag;
+	query_vals[n_query_cols].val.str_val = *from_tag;
 	n_query_cols++;
 	n_query_cols++;
-	
+
 	if (pa_dbf.use_table(pa_db, &active_watchers_table) < 0) 
 	if (pa_dbf.use_table(pa_db, &active_watchers_table) < 0) 
 	{
 	{
 		LM_ERR("in use table sql operation\n");
 		LM_ERR("in use table sql operation\n");
@@ -405,7 +405,8 @@ int update_subs_db(subs_t* subs, int type)
 	return 0;
 	return 0;
 }
 }
 
 
-void delete_subs(str* pres_uri, str* ev_name, str* to_tag)
+void delete_subs(str* pres_uri, str* ev_name, str* to_tag,
+		str* from_tag, str* callid)
 {
 {
 	/* delete record from hash table also if not in dbonly mode */
 	/* delete record from hash table also if not in dbonly mode */
 	if(subs_dbmode != DB_ONLY)
 	if(subs_dbmode != DB_ONLY)
@@ -415,7 +416,7 @@ void delete_subs(str* pres_uri, str* ev_name, str* to_tag)
 			LM_ERR("Failed to delete subscription from memory\n");
 			LM_ERR("Failed to delete subscription from memory\n");
 	}
 	}
 
 
-	if(subs_dbmode != NO_DB && delete_db_subs(pres_uri, ev_name, to_tag)< 0)
+	if(subs_dbmode != NO_DB && delete_db_subs(to_tag, from_tag, callid)< 0)
 		LM_ERR("Failed to delete subscription from database\n");
 		LM_ERR("Failed to delete subscription from database\n");
 }
 }
 
 
@@ -436,7 +437,8 @@ int update_subscription(struct sip_msg* msg, subs_t* subs, int to_tag_gen,
 		{
 		{
 			LM_DBG("expires =0 -> deleting record\n");
 			LM_DBG("expires =0 -> deleting record\n");
 
 
-			delete_subs(&subs->pres_uri, &subs->event->name, &subs->to_tag);
+			delete_subs(&subs->pres_uri, &subs->event->name, &subs->to_tag,
+					&subs->from_tag, &subs->callid);
 
 
 			if(subs->event->type & PUBL_TYPE)
 			if(subs->event->type & PUBL_TYPE)
 			{
 			{

+ 1 - 1
modules_k/presence/subscribe.h

@@ -116,6 +116,6 @@ int extract_sdialog_info(subs_t* subs,struct sip_msg* msg, int max_expire,
 		int* to_tag_gen, str scontact);
 		int* to_tag_gen, str scontact);
 typedef int (*extract_sdialog_info_t)(subs_t* subs, struct sip_msg* msg,
 typedef int (*extract_sdialog_info_t)(subs_t* subs, struct sip_msg* msg,
 		int max_expire, int* to_tag_gen, str scontact);
 		int max_expire, int* to_tag_gen, str scontact);
-void delete_subs(str* pres_uri, str* ev_name, str* to_tag);
+void delete_subs(str* pres_uri, str* ev_name, str* to_tag, str* from_tag, str* callid);
 
 
 #endif
 #endif