(closes issue #13425)

Reported by: mdu113
Tested by: mdu113

Similar to r143204, masquerade the channel in the case of Park being called from AGI.



git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@146129 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Jeff Peeler
2008-10-03 20:44:22 +00:00
parent b161b2df6e
commit fc2e08f823
3 changed files with 9 additions and 3 deletions

View File

@@ -31,6 +31,8 @@
#define FEATURE_EXTEN_LEN 32 #define FEATURE_EXTEN_LEN 32
#define FEATURE_MOH_LEN 80 /* same as MAX_MUSICCLASS from channel.h */ #define FEATURE_MOH_LEN 80 /* same as MAX_MUSICCLASS from channel.h */
#define PARK_APP_NAME "Park"
/*! \brief main call feature structure */ /*! \brief main call feature structure */
struct ast_call_feature { struct ast_call_feature {
int feature_mask; int feature_mask;

View File

@@ -64,6 +64,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
#include "asterisk/lock.h" #include "asterisk/lock.h"
#include "asterisk/strings.h" #include "asterisk/strings.h"
#include "asterisk/agi.h" #include "asterisk/agi.h"
#include "asterisk/features.h"
#define MAX_ARGS 128 #define MAX_ARGS 128
#define MAX_COMMANDS 128 #define MAX_COMMANDS 128
@@ -1110,6 +1111,9 @@ static int handle_exec(struct ast_channel *chan, AGI *agi, int argc, char **argv
app = pbx_findapp(argv[1]); app = pbx_findapp(argv[1]);
if (app) { if (app) {
if(!strcasecmp(argv[1], PARK_APP_NAME)) {
ast_masq_park_call(chan, NULL, 0, NULL);
}
res = pbx_exec(chan, app, argv[2]); res = pbx_exec(chan, app, argv[2]);
} else { } else {
ast_log(LOG_WARNING, "Could not find application (%s)\n", argv[1]); ast_log(LOG_WARNING, "Could not find application (%s)\n", argv[1]);
@@ -2035,7 +2039,7 @@ static int agi_exec_full(struct ast_channel *chan, void *data, int enhanced, int
int fds[2]; int fds[2];
int efd = -1; int efd = -1;
int pid; int pid;
char *stringp; char *stringp;
AGI agi; AGI agi;
if (ast_strlen_zero(data)) { if (ast_strlen_zero(data)) {

View File

@@ -118,7 +118,7 @@ static char *descrip = "ParkedCall(exten):"
"into the dialplan, although you should include the 'parkedcalls'\n" "into the dialplan, although you should include the 'parkedcalls'\n"
"context.\n"; "context.\n";
static char *parkcall = "Park"; static char *parkcall = PARK_APP_NAME;
static char *synopsis2 = "Park yourself"; static char *synopsis2 = "Park yourself";
@@ -565,7 +565,7 @@ static void set_peers(struct ast_channel **caller, struct ast_channel **callee,
static int builtin_parkcall(struct ast_channel *chan, struct ast_channel *peer, struct ast_bridge_config *config, char *code, int sense, void *data) static int builtin_parkcall(struct ast_channel *chan, struct ast_channel *peer, struct ast_bridge_config *config, char *code, int sense, void *data)
{ {
struct ast_channel *parker; struct ast_channel *parker;
struct ast_channel *parkee; struct ast_channel *parkee;
int res = 0; int res = 0;
struct ast_module_user *u; struct ast_module_user *u;