[Freeswitch-svn] [commit] r12570 - freeswitch/trunk/src/mod/xml_int/mod_xml_curl
FreeSWITCH SVN
anthm at freeswitch.org
Wed Mar 11 09:54:39 PDT 2009
Author: anthm
Date: Wed Mar 11 11:54:38 2009
New Revision: 12570
Log:
limit bytes read by xml_curl to 1 meg
Modified:
freeswitch/trunk/src/mod/xml_int/mod_xml_curl/mod_xml_curl.c
Modified: freeswitch/trunk/src/mod/xml_int/mod_xml_curl/mod_xml_curl.c
==============================================================================
--- freeswitch/trunk/src/mod/xml_int/mod_xml_curl/mod_xml_curl.c (original)
+++ freeswitch/trunk/src/mod/xml_int/mod_xml_curl/mod_xml_curl.c Wed Mar 11 11:54:38 2009
@@ -54,9 +54,14 @@
typedef struct xml_binding xml_binding_t;
+#define XML_CURL_MAX_BYTES 1024 * 1024
+
struct config_data {
char *name;
int fd;
+ switch_size_t bytes;
+ switch_size_t max_bytes;
+ int err;
};
typedef struct hash_node {
@@ -102,6 +107,15 @@
register unsigned int realsize = (unsigned int) (size * nmemb);
struct config_data *config_data = data;
int x;
+
+ config_data->bytes += realsize;
+
+ if (config_data->bytes > config_data->max_bytes) {
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Oversized file detected [%ld bytes]\n", config_data->bytes);
+ config_data->err = 1;
+ return 0;
+ }
+
x = write(config_data->fd, ptr, realsize);
if (x != (int) realsize) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Short write! %d out of %d\n", x, realsize);
@@ -185,6 +199,7 @@
}
config_data.name = filename;
+ config_data.max_bytes = XML_CURL_MAX_BYTES;
if ((config_data.fd = open(filename, O_CREAT | O_RDWR | O_TRUNC, S_IRUSR | S_IWUSR)) > -1) {
if (!switch_strlen_zero(binding->cred)) {
curl_easy_setopt(curl_handle, CURLOPT_HTTPAUTH, CURLAUTH_ANY);
@@ -222,13 +237,18 @@
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error Opening temp file!\n");
}
- if (httpRes == 200) {
- if (!(xml = switch_xml_parse_file(filename))) {
- switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error Parsing Result!\n");
- }
- } else {
- switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Received HTTP error %ld trying to fetch %s\ndata: [%s]\n", httpRes, binding->url, data);
+ if (config_data.err) {
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error encountered!\n");
xml = NULL;
+ } else {
+ if (httpRes == 200) {
+ if (!(xml = switch_xml_parse_file(filename))) {
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Error Parsing Result!\n");
+ }
+ } else {
+ switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Received HTTP error %ld trying to fetch %s\ndata: [%s]\n", httpRes, binding->url, data);
+ xml = NULL;
+ }
}
/* Debug by leaving the file behind for review */
More information about the Freeswitch-svn
mailing list