diff options
| -rw-r--r-- | NEWS | 2 | ||||
| -rw-r--r-- | ext/soap/php_encoding.c | 45 | ||||
| -rwxr-xr-x | ext/soap/tests/bugs/bug39832.phpt | 29 | ||||
| -rwxr-xr-x | ext/soap/tests/bugs/bug39832.wsdl | 55 | 
4 files changed, 124 insertions, 7 deletions
| @@ -6,6 +6,8 @@ PHP                                                                        NEWS    . cookies    . canary protection (debug build only)    . random generation of cookies and canaries +- Fixed bug #39832 (SOAP Server: parameter not matching the WSDL specified type +  are set to 0). (Dmitry)  14 Dec 2006, PHP 5.2.1RC1  - Added a meta tag to phpinfo() output to prevent search engines from indexing  diff --git a/ext/soap/php_encoding.c b/ext/soap/php_encoding.c index eb1b2f2595..b401d6d430 100644 --- a/ext/soap/php_encoding.c +++ b/ext/soap/php_encoding.c @@ -669,9 +669,15 @@ static zval *to_zval_base64(encodeTypePtr type, xmlNodePtr data)  		if (data->children->type == XML_TEXT_NODE && data->children->next == NULL) {  			whiteSpace_collapse(data->children->content);  			str = (char*)php_base64_decode(data->children->content, strlen((char*)data->children->content), &str_len); +			if (!str) { +				soap_error0(E_ERROR, "Encoding: Violation of encoding rules"); +			}  			ZVAL_STRINGL(ret, str, str_len, 0);  		} else if (data->children->type == XML_CDATA_SECTION_NODE && data->children->next == NULL) {  			str = (char*)php_base64_decode(data->children->content, strlen((char*)data->children->content), &str_len); +			if (!str) { +				soap_error0(E_ERROR, "Encoding: Violation of encoding rules"); +			}  			ZVAL_STRINGL(ret, str, str_len, 0);  		} else {  			soap_error0(E_ERROR, "Encoding: Violation of encoding rules"); @@ -708,6 +714,8 @@ static zval *to_zval_hexbin(encodeTypePtr type, xmlNodePtr data)  				str[i] = (c - 'a' + 10) << 4;  			} else if (c >= 'A' && c <= 'F') {  				str[i] = (c - 'A' + 10) << 4; +			} else { +				soap_error0(E_ERROR, "Encoding: Violation of encoding rules");  			}  			c = data->children->content[j++];  			if (c >= '0' && c <= '9') { @@ -716,6 +724,8 @@ static zval *to_zval_hexbin(encodeTypePtr type, xmlNodePtr data)  				str[i] |= c - 'a' + 10;  			} else if (c >= 'A' && c <= 'F') {  				str[i] |= c - 'A' + 10; +			} else { +				soap_error0(E_ERROR, "Encoding: Violation of encoding rules");  			}  		}  		str[str_len] = '\0'; @@ -858,8 +868,22 @@ static zval *to_zval_double(encodeTypePtr type, xmlNodePtr data)  	if (data && data->children) {  		if (data->children->type == XML_TEXT_NODE && data->children->next == NULL) { +			long lval; +			double dval; +  			whiteSpace_collapse(data->children->content); -			ZVAL_DOUBLE(ret, atof((char*)data->children->content)); +			switch (is_numeric_string((char*)data->children->content, strlen((char*)data->children->content), &lval, &dval, 0)) { +				case IS_LONG: +					Z_TYPE_P(ret) = IS_DOUBLE; +					Z_DVAL_P(ret) = lval; +					break; +				case IS_DOUBLE: +					Z_TYPE_P(ret) = IS_DOUBLE; +					Z_DVAL_P(ret) = dval; +					break; +				default: +					soap_error0(E_ERROR, "Encoding: Violation of encoding rules"); +			}  		} else {  			soap_error0(E_ERROR, "Encoding: Violation of encoding rules");  		} @@ -877,14 +901,21 @@ static zval *to_zval_long(encodeTypePtr type, xmlNodePtr data)  	if (data && data->children) {  		if (data->children->type == XML_TEXT_NODE && data->children->next == NULL) { +			long lval; +			double dval; +  			whiteSpace_collapse(data->children->content);  			errno = 0; -			ret->value.lval = strtol((char*)data->children->content, NULL, 0); -			if (errno == ERANGE) { /* overflow */ -				ret->value.dval = zend_strtod((char*)data->children->content, NULL); -				ret->type = IS_DOUBLE; -			} else { -				ret->type = IS_LONG; + +			switch ((Z_TYPE_P(ret) = is_numeric_string((char*)data->children->content, strlen((char*)data->children->content), &lval, &dval, 0))) { +				case IS_LONG: +					Z_LVAL_P(ret) = lval; +					break; +				case IS_DOUBLE: +					Z_DVAL_P(ret) = dval; +					break; +				default: +					soap_error0(E_ERROR, "Encoding: Violation of encoding rules");  			}  		} else {  			soap_error0(E_ERROR, "Encoding: Violation of encoding rules"); diff --git a/ext/soap/tests/bugs/bug39832.phpt b/ext/soap/tests/bugs/bug39832.phpt new file mode 100755 index 0000000000..010b2e2689 --- /dev/null +++ b/ext/soap/tests/bugs/bug39832.phpt @@ -0,0 +1,29 @@ +--TEST-- +Bug #39832 (SOAP Server: parameter not matching the WSDL specified type are set to 0) +--SKIPIF-- +<?php require_once('skipif.inc'); ?> +--INI-- +soap.wsdl_cache_enabled=0 +--FILE-- +<?php +$HTTP_RAW_POST_DATA = <<<EOF +<?xml version="1.0" encoding="UTF-8"?> +<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" xmlns:ns1="http://test.pl"><SOAP-ENV:Body> +<SOAP-ENV:Test> +<parameters priority="high"> +<ns1:NetworkErrorCode>1</ns1:NetworkErrorCode> +</parameters> +</SOAP-ENV:Test></SOAP-ENV:Body></SOAP-ENV:Envelope> +EOF; + +function Test($x) { +  return $x->priority; +} + +$x = new SoapServer(dirname(__FILE__)."/bug39832.wsdl"); +$x->addFunction("Test"); +$x->handle(); +?> +--EXPECT-- +<?xml version="1.0" encoding="UTF-8"?> +<SOAP-ENV:Envelope xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/"><SOAP-ENV:Body><SOAP-ENV:Fault><faultcode>SOAP-ENV:Server</faultcode><faultstring>SOAP-ERROR: Encoding: Violation of encoding rules</faultstring></SOAP-ENV:Fault></SOAP-ENV:Body></SOAP-ENV:Envelope> diff --git a/ext/soap/tests/bugs/bug39832.wsdl b/ext/soap/tests/bugs/bug39832.wsdl new file mode 100755 index 0000000000..a71f581dd5 --- /dev/null +++ b/ext/soap/tests/bugs/bug39832.wsdl @@ -0,0 +1,55 @@ +<?xml version="1.0" encoding="UTF-8"?>
 +<definitions
 +		xmlns:http="http://schemas.xmlsoap.org/wsdl/http/"
 +		xmlns:soap="http://schemas.xmlsoap.org/wsdl/soap/"
 +		xmlns:s="http://www.w3.org/2001/XMLSchema"
 +		xmlns:s0="http://test.pl"
 +		targetNamespace="http://test.pl"
 +		xmlns="http://schemas.xmlsoap.org/wsdl/">
 +	<types>
 +		<s:schema elementFormDefault="qualified" targetNamespace="http://test.pl">
 +			<s:complexType name="MessageInfoType">
 +			   <s:sequence>
 +			      <s:element name="NetworkErrorCode" type="s:integer" minOccurs="0"/>
 +			   </s:sequence>
 +			   <s:attribute name="priority" type="s0:PriorityType"/>
 +			</s:complexType>
 +			<s:simpleType name="PriorityType">
 +				<s:restriction base="s:integer">
 +					<s:minInclusive value="0"/>
 +					<s:maxInclusive value="3"/>
 +			   </s:restriction>
 +			</s:simpleType>	
 +		</s:schema>
 +	</types>
 +
 +	<message name="TestSoapIn">
 +		<part name="parameters" type="s0:MessageInfoType" />
 +	</message>
 +	<message name="TestSoapOut">
 +		<part name="parameters" type="s:string" />
 +	</message>
 +	<portType name="TestSoap">
 +		<operation name="Test">
 +			<input message="s0:TestSoapIn"/>
 +			<output message="s0:TestSoapOut"/>
 +		</operation>
 +	</portType>
 +	<binding name="TestSoap" type="s0:TestSoap">
 +		<soap:binding transport="http://schemas.xmlsoap.org/soap/http" style="document"/>
 +		<operation name="Test">
 +			<soap:operation soapAction="http:/Test/Test" style="rpc"/>
 +			<input>
 +				<soap:body use="literal"/>
 +			</input>
 +			<output>
 +				<soap:body use="literal"/>
 +			</output>
 +		</operation>
 +	</binding>
 +	<service name="Test">
 +		<port name="TestSoapPort" binding="s0:TestSoap">
 +			<soap:address location="http://localhost/server.php"/>
 +		</port>
 +	</service>
 +</definitions>
 | 
