diff options
| author | Dmitry Stogov <dmitry@php.net> | 2005-07-08 09:36:28 +0000 | 
|---|---|---|
| committer | Dmitry Stogov <dmitry@php.net> | 2005-07-08 09:36:28 +0000 | 
| commit | 76a447c900c2fb81ac7fc6fe7fa4b433a9d7994b (patch) | |
| tree | 459963c210f48400b5c335e020e00b2037f0d7f1 | |
| parent | a7e85b3c07e7f842c84674be73fa56470d728970 (diff) | |
| download | php-git-76a447c900c2fb81ac7fc6fe7fa4b433a9d7994b.tar.gz | |
Fixed HTTP basic authentication headers during subrequsts to xsd files
| -rw-r--r-- | ext/soap/php_http.c | 28 | ||||
| -rw-r--r-- | ext/soap/php_http.h | 2 | ||||
| -rw-r--r-- | ext/soap/php_sdl.c | 91 | 
3 files changed, 87 insertions, 34 deletions
| diff --git a/ext/soap/php_http.c b/ext/soap/php_http.c index 1ba85d719b..000ce4408f 100644 --- a/ext/soap/php_http.c +++ b/ext/soap/php_http.c @@ -55,7 +55,7 @@ static int stream_alive(php_stream *stream  TSRMLS_DC)  }  /* Proxy HTTP Authentication */ -static void proxy_authentication(zval* this_ptr, smart_str* soap_headers TSRMLS_DC) +void proxy_authentication(zval* this_ptr, smart_str* soap_headers TSRMLS_DC)  {  	zval **login, **password; @@ -79,6 +79,32 @@ static void proxy_authentication(zval* this_ptr, smart_str* soap_headers TSRMLS_  	}  } +/* HTTP Authentication */ +void basic_authentication(zval* this_ptr, smart_str* soap_headers TSRMLS_DC) +{ +	zval **login, **password; + +	if (zend_hash_find(Z_OBJPROP_P(this_ptr), "_login", sizeof("_login"), (void **)&login) == SUCCESS && +			!zend_hash_exists(Z_OBJPROP_P(this_ptr), "_digest", sizeof("_digest"))) { +		char* buf; +		int len; +		smart_str auth = {0}; + +		smart_str_appendl(&auth, Z_STRVAL_PP(login), Z_STRLEN_PP(login)); +		smart_str_appendc(&auth, ':'); +		if (zend_hash_find(Z_OBJPROP_P(this_ptr), "_password", sizeof("_password"), (void **)&password) == SUCCESS) { +			smart_str_appendl(&auth, Z_STRVAL_PP(password), Z_STRLEN_PP(password)); +		} +		smart_str_0(&auth); +		buf = php_base64_encode(auth.c, auth.len, &len); +		smart_str_append_const(soap_headers, "Authorization: Basic "); +		smart_str_appendl(soap_headers, buf, len); +		smart_str_append_const(soap_headers, "\r\n"); +		efree(buf); +		smart_str_free(&auth); +	} +} +  static php_stream* http_connect(zval* this_ptr, php_url *phpurl, int use_ssl, int *use_proxy TSRMLS_DC)  {  	php_stream *stream; diff --git a/ext/soap/php_http.h b/ext/soap/php_http.h index fc055a144a..55f8ddcf47 100644 --- a/ext/soap/php_http.h +++ b/ext/soap/php_http.h @@ -31,4 +31,6 @@ int make_http_soap_request(zval  *this_ptr,                             char **response,                              int   *response_len TSRMLS_DC); +void proxy_authentication(zval* this_ptr, smart_str* soap_headers TSRMLS_DC); +void basic_authentication(zval* this_ptr, smart_str* soap_headers TSRMLS_DC);  #endif diff --git a/ext/soap/php_sdl.c b/ext/soap/php_sdl.c index 25022c80ea..229aed785c 100644 --- a/ext/soap/php_sdl.c +++ b/ext/soap/php_sdl.c @@ -206,46 +206,13 @@ static void load_wsdl_ex(zval *this_ptr, char *struri, sdlCtx *ctx, int include  	xmlDocPtr wsdl;  	xmlNodePtr root, definitions, trav;  	xmlAttrPtr targetNamespace; -	php_stream_context *context=NULL; -	zval **proxy_host, **proxy_port, *orig_context, *new_context;  	if (zend_hash_exists(&ctx->docs, struri, strlen(struri)+1)) {  		return;  	} - -	if (zend_hash_find(Z_OBJPROP_P(this_ptr), "_proxy_host", sizeof("_proxy_host"), (void **) &proxy_host) == SUCCESS && -	    Z_TYPE_PP(proxy_host) == IS_STRING && -	    zend_hash_find(Z_OBJPROP_P(this_ptr), "_proxy_port", sizeof("_proxy_port"), (void **) &proxy_port) == SUCCESS && -	    Z_TYPE_PP(proxy_port) == IS_LONG) { -	    	zval str_port, *str_proxy; -	    	smart_str proxy = {0}; -		str_port = **proxy_port; -		zval_copy_ctor(&str_port); -		convert_to_string(&str_port); -		smart_str_appends(&proxy,"tcp://"); -		smart_str_appends(&proxy,Z_STRVAL_PP(proxy_host)); -		smart_str_appends(&proxy,":"); -		smart_str_appends(&proxy,Z_STRVAL(str_port)); -		zval_dtor(&str_port); -		MAKE_STD_ZVAL(str_proxy); -		ZVAL_STRING(str_proxy, proxy.c, 1); -		smart_str_free(&proxy); -		 -		context = php_stream_context_alloc(); -		php_stream_context_set_option(context, "http", "proxy", str_proxy); -		zval_ptr_dtor(&str_proxy); -		MAKE_STD_ZVAL(new_context); -		php_stream_context_to_zval(context, new_context); -		orig_context = php_libxml_switch_context(new_context TSRMLS_CC); -	}  	wsdl = soap_xmlParseFile(struri); -	if (context) { -		php_libxml_switch_context(orig_context TSRMLS_CC); -		zval_ptr_dtor(&new_context); -	} -  	if (!wsdl) {  		soap_error1(E_ERROR, "Parsing WSDL: Couldn't load from '%s'", struri);  	} @@ -2246,6 +2213,57 @@ sdlPtr get_sdl(zval *this_ptr, char *uri TSRMLS_DC)  	sdlPtr sdl = NULL;  	char* old_error_code = SOAP_GLOBAL(error_code);  	int uri_len; +	php_stream_context *context=NULL; +	zval **proxy_host, **proxy_port, *orig_context, *new_context; +	smart_str headers = {0}; + +	if (zend_hash_find(Z_OBJPROP_P(this_ptr), "_proxy_host", sizeof("_proxy_host"), (void **) &proxy_host) == SUCCESS && +	    Z_TYPE_PP(proxy_host) == IS_STRING && +	    zend_hash_find(Z_OBJPROP_P(this_ptr), "_proxy_port", sizeof("_proxy_port"), (void **) &proxy_port) == SUCCESS && +	    Z_TYPE_PP(proxy_port) == IS_LONG) { +	    	zval str_port, *str_proxy; +	    	smart_str proxy = {0}; +		str_port = **proxy_port; +		zval_copy_ctor(&str_port); +		convert_to_string(&str_port); +		smart_str_appends(&proxy,"tcp://"); +		smart_str_appends(&proxy,Z_STRVAL_PP(proxy_host)); +		smart_str_appends(&proxy,":"); +		smart_str_appends(&proxy,Z_STRVAL(str_port)); +		zval_dtor(&str_port); +		MAKE_STD_ZVAL(str_proxy); +		ZVAL_STRING(str_proxy, proxy.c, 1); +		smart_str_free(&proxy); +		 +		context = php_stream_context_alloc(); +		php_stream_context_set_option(context, "http", "proxy", str_proxy); +		zval_ptr_dtor(&str_proxy); + +		proxy_authentication(this_ptr, &headers TSRMLS_CC); +	} + +	basic_authentication(this_ptr, &headers TSRMLS_CC); + +	if (headers.len > 0) { +		zval *str_headers; + +		if (!context) { +			context = php_stream_context_alloc(); +		} + +		smart_str_0(&headers); +		MAKE_STD_ZVAL(str_headers); +		ZVAL_STRING(str_headers, headers.c, 1); +		php_stream_context_set_option(context, "http", "header", str_headers); +		smart_str_free(&headers); +		zval_ptr_dtor(&str_headers); +	} + +	if (context) { +		MAKE_STD_ZVAL(new_context); +		php_stream_context_to_zval(context, new_context); +		orig_context = php_libxml_switch_context(new_context TSRMLS_CC); +	}  	SOAP_GLOBAL(error_code) = "WSDL"; @@ -2286,7 +2304,14 @@ sdlPtr get_sdl(zval *this_ptr, char *uri TSRMLS_DC)  	} else {  		sdl = load_wsdl(this_ptr, uri TSRMLS_CC);  	} +  	SOAP_GLOBAL(error_code) = old_error_code; + +	if (context) { +		php_libxml_switch_context(orig_context TSRMLS_CC); +		zval_ptr_dtor(&new_context); +	} +  	return sdl;  } | 
