mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-25 06:00:36 +00:00 
			
		
		
		
	chan_sip: 3PCC patch for AMI "SIPnotify"
A patch for sending in-dialog SIP NOTIFY message with "SIPnotify" AMI action. ASTERISK-27461 Change-Id: I5797ded4752acd966db6b13971284db684cc5ab4
This commit is contained in:
		| @@ -593,6 +593,9 @@ | ||||
| 				<para>At least one variable pair must be specified. | ||||
| 				<replaceable>name</replaceable>=<replaceable>value</replaceable></para> | ||||
| 			</parameter> | ||||
| 			<parameter name="Call-ID" required="false"> | ||||
| 				<para>When specified, SIP notity will be sent as a part of an existing dialog.</para> | ||||
| 			</parameter> | ||||
| 		</syntax> | ||||
| 		<description> | ||||
| 			<para>Sends a SIP Notify event.</para> | ||||
| @@ -15591,11 +15594,13 @@ static int manager_sipnotify(struct mansession *s, const struct message *m) | ||||
| { | ||||
| 	const char *channame = astman_get_header(m, "Channel"); | ||||
| 	struct ast_variable *vars = astman_get_variables_order(m, ORDER_NATURAL); | ||||
| 	const char *callid = astman_get_header(m, "Call-ID"); | ||||
| 	struct sip_pvt *p; | ||||
| 	struct ast_variable *header, *var; | ||||
| 
 | ||||
| 	if (ast_strlen_zero(channame)) { | ||||
| 		astman_send_error(s, m, "SIPNotify requires a channel name"); | ||||
| 		ast_variables_destroy(vars); | ||||
| 		return 0; | ||||
| 	} | ||||
| 
 | ||||
| @@ -15603,8 +15608,28 @@ static int manager_sipnotify(struct mansession *s, const struct message *m) | ||||
| 		channame += 4; | ||||
| 	} | ||||
| 
 | ||||
| 	/* check if Call-ID header is set */ | ||||
| 	if (!ast_strlen_zero(callid)) { | ||||
| 		struct sip_pvt tmp_dialog = { | ||||
| 			.callid = callid, | ||||
| 		}; | ||||
| 
 | ||||
| 		p = ao2_find(dialogs, &tmp_dialog, OBJ_SEARCH_OBJECT); | ||||
| 		if (!p) { | ||||
| 			astman_send_error(s, m, "Call-ID not found"); | ||||
| 			ast_variables_destroy(vars); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| 		if (!(p->notify)) { | ||||
| 			sip_notify_alloc(p); | ||||
| 		} else { | ||||
| 			ast_variables_destroy(p->notify->headers); | ||||
| 		} | ||||
| 	} else { | ||||
| 		if (!(p = sip_alloc(NULL, NULL, 0, SIP_NOTIFY, NULL, 0))) { | ||||
| 			astman_send_error(s, m, "Unable to build sip pvt data for notify (memory/socket error)"); | ||||
| 			ast_variables_destroy(vars); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| @@ -15614,6 +15639,7 @@ static int manager_sipnotify(struct mansession *s, const struct message *m) | ||||
| 			dialog_unref(p, "unref dialog inside for loop" ); | ||||
| 			/* sip_destroy(p); */ | ||||
| 			astman_send_error(s, m, "Could not create address"); | ||||
| 			ast_variables_destroy(vars); | ||||
| 			return 0; | ||||
| 		} | ||||
| 
 | ||||
| @@ -15621,6 +15647,8 @@ static int manager_sipnotify(struct mansession *s, const struct message *m) | ||||
| 		ast_set_flag(&p->flags[0], SIP_OUTGOING); | ||||
| 		sip_notify_alloc(p); | ||||
| 
 | ||||
| 	} | ||||
| 
 | ||||
| 	p->notify->headers = header = ast_variable_new("Subscription-State", "terminated", ""); | ||||
| 
 | ||||
| 	for (var = vars; var; var = var->next) { | ||||
| @@ -15636,6 +15664,7 @@ static int manager_sipnotify(struct mansession *s, const struct message *m) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	if (ast_strlen_zero(callid)) { | ||||
| 		/* Now that we have the peer's address, set our ip and change callid */ | ||||
| 		ast_sip_ouraddrfor(&p->sa, &p->ourip, p); | ||||
| 		build_via(p); | ||||
| @@ -15644,6 +15673,10 @@ static int manager_sipnotify(struct mansession *s, const struct message *m) | ||||
| 
 | ||||
| 		sip_scheddestroy(p, SIP_TRANS_TIMEOUT); | ||||
| 		transmit_invite(p, SIP_NOTIFY, 0, 2, NULL); | ||||
| 	} else { | ||||
| 		sip_scheddestroy(p, SIP_TRANS_TIMEOUT); | ||||
| 		transmit_invite(p, SIP_NOTIFY, 0, 1, NULL); | ||||
| 	} | ||||
| 	dialog_unref(p, "bump down the count of p since we're done with it."); | ||||
| 
 | ||||
| 	astman_send_ack(s, m, "Notify Sent"); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user