[asterisk-commits] tilghman: branch 10 r337342 - in /branches/10:	./ funcs/func_curl.c
    SVN commits to the Asterisk project 
    asterisk-commits at lists.digium.com
       
    Wed Sep 21 15:52:27 CDT 2011
    
    
  
Author: tilghman
Date: Wed Sep 21 15:52:21 2011
New Revision: 337342
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=337342
Log:
........
Escape commas in keys and values, when keys and values are enumerated by commas.
Review: https://reviewboard.asterisk.org/r/1433
........
Merged revisions 337325 from https://origsvn.digium.com/svn/asterisk/branches/1.8
Modified:
    branches/10/   (props changed)
    branches/10/funcs/func_curl.c
Propchange: branches/10/
------------------------------------------------------------------------------
Binary property 'branch-1.8-merged' - no diff available.
Modified: branches/10/funcs/func_curl.c
URL: http://svnview.digium.com/svn/asterisk/branches/10/funcs/func_curl.c?view=diff&rev=337342&r1=337341&r2=337342
==============================================================================
--- branches/10/funcs/func_curl.c (original)
+++ branches/10/funcs/func_curl.c Wed Sep 21 15:52:21 2011
@@ -564,9 +564,11 @@
 }
 
 AST_THREADSTORAGE_CUSTOM(curl_instance, curl_instance_init, curl_instance_cleanup);
+AST_THREADSTORAGE(thread_escapebuf);
 
 static int acf_curl_helper(struct ast_channel *chan, const char *cmd, char *info, char *buf, struct ast_str **input_str, ssize_t len)
 {
+	struct ast_str *escapebuf = ast_str_thread_get(&thread_escapebuf, 16);
 	struct ast_str *str = ast_str_create(16);
 	int ret = -1;
 	AST_DECLARE_APP_ARGS(args,
@@ -584,6 +586,11 @@
 	}
 
 	if (!str) {
+		return -1;
+	}
+
+	if (!escapebuf) {
+		ast_free(str);
 		return -1;
 	}
 
@@ -670,8 +677,8 @@
 					}
 					ast_uri_decode(name, ast_uri_http);
 				}
-				ast_str_append(&fields, 0, "%s%s", rowcount ? "," : "", name);
-				ast_str_append(&values, 0, "%s%s", rowcount ? "," : "", S_OR(piece, ""));
+				ast_str_append(&fields, 0, "%s%s", rowcount ? "," : "", ast_str_set_escapecommas(&escapebuf, 0, name, INT_MAX));
+				ast_str_append(&values, 0, "%s%s", rowcount ? "," : "", ast_str_set_escapecommas(&escapebuf, 0, S_OR(piece, ""), INT_MAX));
 				rowcount++;
 			}
 			pbx_builtin_setvar_helper(chan, "~ODBCFIELDS~", ast_str_buffer(fields));
    
    
More information about the asterisk-commits
mailing list