104 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| if (!defined('W3TC')) {
 | |
|     die();
 | |
| }
 | |
| 
 | |
| /**
 | |
| * For creating serializable abstractions of native PHP types.  This class
 | |
| * allows element name/namespace, XSD type, and XML attributes to be
 | |
| * associated with a value.  This is extremely useful when WSDL is not
 | |
| * used, but is also useful when WSDL is used with polymorphic types, including
 | |
| * xsd:anyType and user-defined types.
 | |
| *
 | |
| * @author   Dietrich Ayala <dietrich@ganx4.com>
 | |
| * @version  $Id: class.soap_val.php,v 1.11 2007/04/06 13:56:32 snichol Exp $
 | |
| * @access   public
 | |
| */
 | |
| class soapval extends nusoap_base {
 | |
| 	/**
 | |
| 	 * The XML element name
 | |
| 	 *
 | |
| 	 * @var string
 | |
| 	 * @access private
 | |
| 	 */
 | |
| 	var $name;
 | |
| 	/**
 | |
| 	 * The XML type name (string or false)
 | |
| 	 *
 | |
| 	 * @var mixed
 | |
| 	 * @access private
 | |
| 	 */
 | |
| 	var $type;
 | |
| 	/**
 | |
| 	 * The PHP value
 | |
| 	 *
 | |
| 	 * @var mixed
 | |
| 	 * @access private
 | |
| 	 */
 | |
| 	var $value;
 | |
| 	/**
 | |
| 	 * The XML element namespace (string or false)
 | |
| 	 *
 | |
| 	 * @var mixed
 | |
| 	 * @access private
 | |
| 	 */
 | |
| 	var $element_ns;
 | |
| 	/**
 | |
| 	 * The XML type namespace (string or false)
 | |
| 	 *
 | |
| 	 * @var mixed
 | |
| 	 * @access private
 | |
| 	 */
 | |
| 	var $type_ns;
 | |
| 	/**
 | |
| 	 * The XML element attributes (array or false)
 | |
| 	 *
 | |
| 	 * @var mixed
 | |
| 	 * @access private
 | |
| 	 */
 | |
| 	var $attributes;
 | |
| 
 | |
| 	/**
 | |
| 	* constructor
 | |
| 	*
 | |
| 	* @param    string $name optional name
 | |
| 	* @param    mixed $type optional type name
 | |
| 	* @param	mixed $value optional value
 | |
| 	* @param	mixed $element_ns optional namespace of value
 | |
| 	* @param	mixed $type_ns optional namespace of type
 | |
| 	* @param	mixed $attributes associative array of attributes to add to element serialization
 | |
| 	* @access   public
 | |
| 	*/
 | |
|   	function __construct($name='soapval',$type=false,$value=-1,$element_ns=false,$type_ns=false,$attributes=false) {
 | |
| 		parent::nusoap_base();
 | |
| 		$this->name = $name;
 | |
| 		$this->type = $type;
 | |
| 		$this->value = $value;
 | |
| 		$this->element_ns = $element_ns;
 | |
| 		$this->type_ns = $type_ns;
 | |
| 		$this->attributes = $attributes;
 | |
|     }
 | |
| 
 | |
| 	/**
 | |
| 	* return serialized value
 | |
| 	*
 | |
| 	* @param	string $use The WSDL use value (encoded|literal)
 | |
| 	* @return	string XML data
 | |
| 	* @access   public
 | |
| 	*/
 | |
| 	function serialize($use='encoded') {
 | |
| 		return $this->serialize_val($this->value, $this->name, $this->type, $this->element_ns, $this->type_ns, $this->attributes, $use, true);
 | |
|     }
 | |
| 
 | |
| 	/**
 | |
| 	* decodes a soapval object into a PHP native type
 | |
| 	*
 | |
| 	* @return	mixed
 | |
| 	* @access   public
 | |
| 	*/
 | |
| 	function decode(){
 | |
| 		return $this->value;
 | |
| 	}
 | |
| }
 |