mirror of
https://github.com/asterisk/asterisk.git
synced 2025-11-08 10:58:15 +00:00
Merged revisions 166696 via svnmerge from
https://origsvn.digium.com/svn/asterisk/trunk ........ r166696 | tilghman | 2008-12-23 14:47:08 -0600 (Tue, 23 Dec 2008) | 7 lines Allow semicolons and extended characters in user-specified SIP headers. (closes issue #14110) Reported by: gork Patches: 20081222__bug14110__2.diff.txt uploaded by Corydon76 (license 14) Tested by: gork, putnopvut ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.1@166698 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -22682,7 +22682,7 @@ static int sip_addheader(struct ast_channel *chan, void *data)
|
||||
int no = 0;
|
||||
int ok = FALSE;
|
||||
char varbuf[30];
|
||||
char *inbuf = data;
|
||||
char *inbuf = data, *subbuf;
|
||||
|
||||
if (ast_strlen_zero(inbuf)) {
|
||||
ast_log(LOG_WARNING, "This application requires the argument: Header\n");
|
||||
@@ -22696,13 +22696,18 @@ static int sip_addheader(struct ast_channel *chan, void *data)
|
||||
snprintf(varbuf, sizeof(varbuf), "__SIPADDHEADER%.2d", no);
|
||||
|
||||
/* Compare without the leading underscores */
|
||||
if( (pbx_builtin_getvar_helper(chan, (const char *) varbuf + 2) == (const char *) NULL) )
|
||||
if ((pbx_builtin_getvar_helper(chan, (const char *) varbuf + 2) == (const char *) NULL)) {
|
||||
ok = TRUE;
|
||||
}
|
||||
}
|
||||
if (ok) {
|
||||
pbx_builtin_setvar_helper (chan, varbuf, inbuf);
|
||||
if (sipdebug)
|
||||
size_t len = strlen(inbuf);
|
||||
subbuf = alloca(len + 1);
|
||||
ast_get_encoded_str(inbuf, subbuf, len + 1);
|
||||
pbx_builtin_setvar_helper(chan, varbuf, subbuf);
|
||||
if (sipdebug) {
|
||||
ast_debug(1, "SIP Header added \"%s\" as %s\n", inbuf, varbuf);
|
||||
}
|
||||
} else {
|
||||
ast_log(LOG_WARNING, "Too many SIP headers added, max 50\n");
|
||||
}
|
||||
|
||||
@@ -488,6 +488,9 @@ int ast_record_review(struct ast_channel *chan, const char *playfile, const char
|
||||
/*! \brief Decode an encoded control or extended ASCII character */
|
||||
int ast_get_encoded_char(const char *stream, char *result, size_t *consumed);
|
||||
|
||||
/*! \brief Decode a string which may contain multiple encoded control or extended ASCII characters */
|
||||
int ast_get_encoded_str(const char *stream, char *result, size_t result_size);
|
||||
|
||||
/*! \brief Common routine for child processes, to close all fds prior to exec(2) */
|
||||
void ast_close_fds_above_n(int n);
|
||||
|
||||
|
||||
13
main/app.c
13
main/app.c
@@ -1820,6 +1820,19 @@ int ast_get_encoded_char(const char *stream, char *result, size_t *consumed)
|
||||
return 0;
|
||||
}
|
||||
|
||||
int ast_get_encoded_str(const char *stream, char *result, size_t result_size)
|
||||
{
|
||||
char *cur = result;
|
||||
size_t consumed;
|
||||
|
||||
while (cur < result + result_size - 1 && !ast_get_encoded_char(stream, cur, &consumed)) {
|
||||
cur++;
|
||||
stream += consumed;
|
||||
}
|
||||
*cur = '\0';
|
||||
return 0;
|
||||
}
|
||||
|
||||
void ast_close_fds_above_n(int n)
|
||||
{
|
||||
int x, null;
|
||||
|
||||
Reference in New Issue
Block a user