git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@15107 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2009-10-07 14:44:25 +00:00
parent 0c96b8e32d
commit 04ca6f4ec5
1 changed files with 23 additions and 1 deletions

View File

@ -55,6 +55,7 @@ struct xml_binding {
char *cookie_file; char *cookie_file;
switch_hash_t *vars_map; switch_hash_t *vars_map;
int use_dynamic_url; int use_dynamic_url;
int auth_scheme;
}; };
static int keep_files_around = 0; static int keep_files_around = 0;
@ -217,7 +218,7 @@ static switch_xml_t xml_url_fetch(const char *section, const char *tag_name, con
if ((config_data.fd = open(filename, O_CREAT | O_RDWR | O_TRUNC, S_IRUSR | S_IWUSR)) > -1) { if ((config_data.fd = open(filename, O_CREAT | O_RDWR | O_TRUNC, S_IRUSR | S_IWUSR)) > -1) {
if (!switch_strlen_zero(binding->cred)) { if (!switch_strlen_zero(binding->cred)) {
curl_easy_setopt(curl_handle, CURLOPT_HTTPAUTH, CURLAUTH_ANY); curl_easy_setopt(curl_handle, CURLOPT_HTTPAUTH, binding->auth_scheme);
curl_easy_setopt(curl_handle, CURLOPT_USERPWD, binding->cred); curl_easy_setopt(curl_handle, CURLOPT_USERPWD, binding->cred);
} }
curl_easy_setopt(curl_handle, CURLOPT_HTTPHEADER, headers); curl_easy_setopt(curl_handle, CURLOPT_HTTPHEADER, headers);
@ -355,6 +356,8 @@ static switch_status_t do_config(void)
hash_node_t* hash_node; hash_node_t* hash_node;
need_vars_map = 0; need_vars_map = 0;
vars_map = NULL; vars_map = NULL;
int auth_scheme = CURLAUTH_BASIC;
for (param = switch_xml_child(binding_tag, "param"); param; param = param->next) { for (param = switch_xml_child(binding_tag, "param"); param; param = param->next) {
char *var = (char *) switch_xml_attr_soft(param, "name"); char *var = (char *) switch_xml_attr_soft(param, "name");
@ -366,6 +369,23 @@ static switch_status_t do_config(void)
} }
} else if (!strcasecmp(var, "gateway-credentials")) { } else if (!strcasecmp(var, "gateway-credentials")) {
bind_cred = val; bind_cred = val;
} else if (!strcasecmp(var, "auth-scheme")) {
if (*val == '=') {
auth_scheme = 0;
val++;
}
if (!strcasecmp(val, "basic")) {
auth_scheme |= CURLAUTH_BASIC;
} else if (!strcasecmp(val, "digest")) {
auth_scheme = CURLAUTH_DIGEST;
} else if (!strcasecmp(val, "NTLM")) {
auth_scheme = CURLAUTH_NTLM;
} else if (!strcasecmp(val, "GSS-NEGOTIATE")) {
auth_scheme = CURLAUTH_GSSNEGOTIATE;
} else if (!strcasecmp(val, "any")) {
auth_scheme = CURLAUTH_ANY;
}
} else if (!strcasecmp(var, "disable-100-continue") && switch_true(val)) { } else if (!strcasecmp(var, "disable-100-continue") && switch_true(val)) {
disable100continue = 1; disable100continue = 1;
} else if (!strcasecmp(var, "method")) { } else if (!strcasecmp(var, "method")) {
@ -419,6 +439,8 @@ static switch_status_t do_config(void)
} }
memset(binding, 0, sizeof(*binding)); memset(binding, 0, sizeof(*binding));
binding->auth_scheme = auth_scheme;
binding->url = strdup(url); binding->url = strdup(url);
switch_assert(binding->url); switch_assert(binding->url);