[svn-commits] file: branch file/originate_dial r387096 - /team/file/originate_dial/main/pbx.c

SVN commits to the Digium repositories svn-commits at lists.digium.com
Wed May 1 08:02:16 CDT 2013


Author: file
Date: Wed May  1 08:02:12 2013
New Revision: 387096

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=387096
Log:
Reduce duplicated code and apply provided callerid information.

Modified:
    team/file/originate_dial/main/pbx.c

Modified: team/file/originate_dial/main/pbx.c
URL: http://svnview.digium.com/svn/asterisk/team/file/originate_dial/main/pbx.c?view=diff&rev=387096&r1=387095&r2=387096
==============================================================================
--- team/file/originate_dial/main/pbx.c (original)
+++ team/file/originate_dial/main/pbx.c Wed May  1 08:02:12 2013
@@ -10020,7 +10020,9 @@
 	return NULL;
 }
 
-int ast_pbx_outgoing_exten(const char *type, struct ast_format_cap *cap, const char *addr, int timeout, const char *context, const char *exten, int priority, int *reason, int synchronous, const char *cid_num, const char *cid_name, struct ast_variable *vars, const char *account, struct ast_channel **channel, int early_media)
+static int pbx_outgoing_attempt(const char *type, struct ast_format_cap *cap, const char *addr, int timeout, const char *context,
+	const char *exten, int priority, const char *app, const char *appdata, int *reason, int synchronous, const char *cid_num,
+	const char *cid_name, struct ast_variable *vars, const char *account, struct ast_channel **channel, int early_media)
 {
 	RAII_VAR(struct pbx_outgoing *, outgoing, ao2_alloc(sizeof(*outgoing), pbx_outgoing_destroy), ao2_cleanup);
 	struct ast_channel *dialed;
@@ -10030,9 +10032,14 @@
 		return -1;
 	}
 
-	ast_copy_string(outgoing->context, context, sizeof(outgoing->context));
-	ast_copy_string(outgoing->exten, exten, sizeof(outgoing->exten));
-	outgoing->priority = priority;
+	if (!ast_strlen_zero(app)) {
+		ast_copy_string(outgoing->app, app, sizeof(outgoing->app));
+		outgoing->appdata = ast_strdup(appdata);
+	} else {
+		ast_copy_string(outgoing->context, context, sizeof(outgoing->context));
+		ast_copy_string(outgoing->exten, exten, sizeof(outgoing->exten));
+		outgoing->priority = priority;
+	}
 
 	if (!(outgoing->dial = ast_dial_create())) {
 		return -1;
@@ -10054,6 +10061,22 @@
 
 	if (account) {
 		ast_cdr_setaccount(dialed, account);
+	}
+
+	if (!ast_strlen_zero(cid_num) && !ast_strlen_zero(cid_name)) {
+		struct ast_party_connected_line connected;
+
+		ast_party_connected_line_set_init(&connected, ast_channel_connected(dialed));
+
+		ast_set_callerid(dialed, cid_num, cid_name, cid_num);
+		connected.id.number.valid = 1;
+		connected.id.number.str = (char *) cid_num;
+		connected.id.number.presentation = AST_PRES_ALLOWED_USER_NUMBER_NOT_SCREENED;
+		connected.id.name.valid = 1;
+		connected.id.name.str = (char *) cid_name;
+		connected.id.name.presentation = AST_PRES_ALLOWED_USER_NUMBER_NOT_SCREENED;
+
+		ast_channel_set_connected_line(dialed, &connected, NULL);
 	}
 
 	ast_mutex_init(&outgoing->lock);
@@ -10090,7 +10113,7 @@
 	}
 
 	if (ast_dial_state(outgoing->dial) != AST_DIAL_RESULT_ANSWERED &&
-		ast_exists_extension(NULL, context, "failed", 1, NULL)) {
+		ast_strlen_zero(app) &&	ast_exists_extension(NULL, context, "failed", 1, NULL)) {
 		struct ast_channel *failed = ast_channel_alloc(0, AST_STATE_DOWN, 0, 0, "", "", "", NULL, 0, "OutgoingSpoolFailed");
 
 		if (failed) {
@@ -10119,75 +10142,20 @@
 	return 0;
 }
 
+int ast_pbx_outgoing_exten(const char *type, struct ast_format_cap *cap, const char *addr, int timeout, const char *context, const char *exten, int priority, int *reason, int synchronous, const char *cid_num, const char *cid_name, struct ast_variable *vars, const char *account, struct ast_channel **channel, int early_media)
+{
+	return pbx_outgoing_attempt(type, cap, addr, timeout, context, exten, priority, NULL, NULL, reason, synchronous, cid_num,
+		cid_name, vars, account, channel, early_media);
+}
+
 int ast_pbx_outgoing_app(const char *type, struct ast_format_cap *cap, const char *addr, int timeout, const char *app, const char *appdata, int *reason, int synchronous, const char *cid_num, const char *cid_name, struct ast_variable *vars, const char *account, struct ast_channel **locked_channel)
 {
-	RAII_VAR(struct pbx_outgoing *, outgoing, ao2_alloc(sizeof(*outgoing), pbx_outgoing_destroy), ao2_cleanup);
-	struct ast_channel *dialed;
-	pthread_t thread;
-
-	if (ast_strlen_zero(app) || !outgoing) {
+	if (ast_strlen_zero(app)) {
 		return -1;
 	}
 
-	ast_copy_string(outgoing->app, app, sizeof(outgoing->app));
-	outgoing->appdata = ast_strdup(appdata);
-
-	if (!(outgoing->dial = ast_dial_create())) {
-		return -1;
-	}
-
-	if (ast_dial_append(outgoing->dial, type, addr)) {
-		return -1;
-	}
-
-	ast_dial_set_global_timeout(outgoing->dial, timeout);
-
-	if (ast_dial_prerun(outgoing->dial, NULL, cap)) {
-		return -1;
-	}
-
-	dialed = ast_dial_channel(outgoing->dial, 0);
-
-	ast_set_variables(dialed, vars);
-
-	if (account) {
-		ast_cdr_setaccount(dialed, account);
-	}
-
-	ast_mutex_init(&outgoing->lock);
-	ast_cond_init(&outgoing->cond, NULL);
-
-	ao2_ref(outgoing, +1);
-
-	if (ast_pthread_create_detached(&thread, NULL, pbx_outgoing_exec, outgoing)) {
-		ast_log(LOG_WARNING, "Unable to spawn dialing thread for '%s/%s'\n", type, addr);
-		ao2_ref(outgoing, -1);
-		return -1;
-	}
-
-	/* Wait for dialing to complete */
-	if (synchronous) {
-		ast_mutex_lock(&outgoing->lock);
-		while (!outgoing->dialed) {
-			ast_cond_wait(&outgoing->cond, &outgoing->lock);
-		}
-		ast_mutex_unlock(&outgoing->lock);
-	}
-
-	/* Wait for execution to complete */
-	if (synchronous > 1) {
-		ast_mutex_lock(&outgoing->lock);
-		while (!outgoing->executed) {
-			ast_cond_wait(&outgoing->cond, &outgoing->lock);
-		}
-		ast_mutex_unlock(&outgoing->lock);
-	}
-
-	if (reason) {
-		*reason = ast_dial_reason(outgoing->dial, 0);
-	}
-
-	return 0;
+	return pbx_outgoing_attempt(type, cap, addr, timeout, NULL, NULL, 0, app, appdata, reason, synchronous, cid_num,
+		cid_name, vars, account, locked_channel, 0);
 }
 
 /* this is the guts of destroying a context --




More information about the svn-commits mailing list