X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=src%2FValue.php;h=ec43fc140e9f21d83adf00d590600ec8adb913c7;hb=b59f82d97356e3777e2630cb6640382f42ad9670;hp=2627e58cb44e025ff9be24c0e37fcb62f1babe02;hpb=b08a42e525d486f753ae8c1b2e79041c99d05601;p=plcapi.git diff --git a/src/Value.php b/src/Value.php index 2627e58..ec43fc1 100644 --- a/src/Value.php +++ b/src/Value.php @@ -37,20 +37,52 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess "null" => 1, ); + protected static $logger; + protected static $charsetEncoder; + /// @todo: do these need to be public? /** @var Value[]|mixed */ public $me = array(); - /** @var int $mytype */ + /** + * @var int $mytype + * @internal + */ public $mytype = 0; /** @var string|null $_php_class */ public $_php_class = null; + public function getLogger() + { + if (self::$logger === null) { + self::$logger = Logger::instance(); + } + return self::$logger; + } + + public static function setLogger($logger) + { + self::$logger = $logger; + } + + public function getCharsetEncoder() + { + if (self::$charsetEncoder === null) { + self::$charsetEncoder = Charset::instance(); + } + return self::$charsetEncoder; + } + + public function setCharsetEncoder($charsetEncoder) + { + self::$charsetEncoder = $charsetEncoder; + } + /** * Build an xmlrpc value. * * When no value or type is passed in, the value is left uninitialized, and the value can be added later. * - * @param mixed $val if passing in an array, all array elements should be PhpXmlRpc\Value themselves + * @param Value[]|mixed $val if passing in an array, all array elements should be PhpXmlRpc\Value themselves * @param string $type any valid xmlrpc type name (lowercase): i4, int, boolean, string, double, dateTime.iso8601, * base64, array, struct, null. * If null, 'string' is assumed. @@ -87,7 +119,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess $this->me['struct'] = $val; break; default: - Logger::instance()->errorLog("XML-RPC: " . __METHOD__ . ": not a known type ($type)"); + $this->getLogger()->errorLog("XML-RPC: " . __METHOD__ . ": not a known type ($type)"); } } } @@ -112,7 +144,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } if ($typeOf !== 1) { - Logger::instance()->errorLog("XML-RPC: " . __METHOD__ . ": not a scalar type ($type)"); + $this->getLogger()->errorLog("XML-RPC: " . __METHOD__ . ": not a scalar type ($type)"); return 0; } @@ -129,10 +161,10 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess switch ($this->mytype) { case 1: - Logger::instance()->errorLog('XML-RPC: ' . __METHOD__ . ': scalar xmlrpc value can have only one value'); + $this->getLogger()->errorLog('XML-RPC: ' . __METHOD__ . ': scalar xmlrpc value can have only one value'); return 0; case 3: - Logger::instance()->errorLog('XML-RPC: ' . __METHOD__ . ': cannot add anonymous scalar to struct xmlrpc value'); + $this->getLogger()->errorLog('XML-RPC: ' . __METHOD__ . ': cannot add anonymous scalar to struct xmlrpc value'); return 0; case 2: // we're adding a scalar value to an array here @@ -174,7 +206,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess return 1; } else { - Logger::instance()->errorLog('XML-RPC: ' . __METHOD__ . ': already initialized as a [' . $this->kindOf() . ']'); + $this->getLogger()->errorLog('XML-RPC: ' . __METHOD__ . ': already initialized as a [' . $this->kindOf() . ']'); return 0; } } @@ -205,7 +237,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess return 1; } else { - Logger::instance()->errorLog('XML-RPC: ' . __METHOD__ . ': already initialized as a [' . $this->kindOf() . ']'); + $this->getLogger()->errorLog('XML-RPC: ' . __METHOD__ . ': already initialized as a [' . $this->kindOf() . ']'); return 0; } } @@ -229,6 +261,12 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } } + /** + * @param string typ + * @param Value[]|mixed $val + * @param string $charsetEncoding + * @return string + */ protected function serializedata($typ, $val, $charsetEncoding = '') { $rs = ''; @@ -248,7 +286,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess break; case static::$xmlrpcString: // Do NOT use htmlentities, since it will produce named html entities, which are invalid xml - $rs .= "<${typ}>" . Charset::instance()->encodeEntities($val, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding) . ""; + $rs .= "<${typ}>" . $this->getCharsetEncoder()->encodeEntities($val, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding) . ""; break; case static::$xmlrpcInt: case static::$xmlrpcI4: @@ -295,7 +333,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } else { $rs .= "\n"; } - $charsetEncoder = Charset::instance(); + $charsetEncoder = $this->getCharsetEncoder(); /** @var Value $val2 */ foreach ($val as $key2 => $val2) { $rs .= '' . $charsetEncoder->encodeEntities($key2, PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding) . "\n"; @@ -480,6 +518,7 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess * * @return integer */ + #[\ReturnTypeWillChange] public function count() { switch ($this->mytype) { @@ -498,7 +537,9 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess * Implements the IteratorAggregate interface * * @return \ArrayIterator + * @internal required to be public to implement an Interface */ + #[\ReturnTypeWillChange] public function getIterator() { switch ($this->mytype) { @@ -513,6 +554,13 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } } + /** + * @internal required to be public to implement an Interface + * @param mixed $offset + * @param mixed $value + * @throws \Exception + */ + #[\ReturnTypeWillChange] public function offsetSet($offset, $value) { switch ($this->mytype) { @@ -553,6 +601,12 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } } + /** + * @internal required to be public to implement an Interface + * @param mixed $offset + * @return bool + */ + #[\ReturnTypeWillChange] public function offsetExists($offset) { switch ($this->mytype) { @@ -568,6 +622,12 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } } + /** + * @internal required to be public to implement an Interface + * @param mixed $offset + * @throws \Exception + */ + #[\ReturnTypeWillChange] public function offsetUnset($offset) { switch ($this->mytype) { @@ -585,6 +645,13 @@ class Value implements \Countable, \IteratorAggregate, \ArrayAccess } } + /** + * @internal required to be public to implement an Interface + * @param mixed $offset + * @return mixed|Value|null + * @throws \Exception + */ + #[\ReturnTypeWillChange] public function offsetGet($offset) { switch ($this->mytype) {