| @@ -338,10 +338,10 @@ discard block | ||
| 338 | 338 | $server = $parts['host']; | 
| 339 | 339 | $path = isset($parts['path']) ? $parts['path'] : ''; | 
| 340 | 340 |              if (isset($parts['query'])) { | 
| 341 | - $path .= '?' . $parts['query']; | |
| 341 | + $path .= '?'.$parts['query']; | |
| 342 | 342 | } | 
| 343 | 343 |              if (isset($parts['fragment'])) { | 
| 344 | - $path .= '#' . $parts['fragment']; | |
| 344 | + $path .= '#'.$parts['fragment']; | |
| 345 | 345 | } | 
| 346 | 346 |              if (isset($parts['port'])) { | 
| 347 | 347 | $port = $parts['port']; | 
| @@ -357,7 +357,7 @@ discard block | ||
| 357 | 357 | } | 
| 358 | 358 | } | 
| 359 | 359 |          if ($path == '' || $path[0] != '/') { | 
| 360 | - $this->path = '/' . $path; | |
| 360 | + $this->path = '/'.$path; | |
| 361 | 361 |          } else { | 
| 362 | 362 | $this->path = $path; | 
| 363 | 363 | } | 
| @@ -389,7 +389,7 @@ discard block | ||
| 389 | 389 | //$this->accepted_charset_encodings = $ch->knownCharsets(); | 
| 390 | 390 | |
| 391 | 391 | // initialize user_agent string | 
| 392 | - $this->user_agent = PhpXmlRpc::$xmlrpcName . ' ' . PhpXmlRpc::$xmlrpcVersion; | |
| 392 | + $this->user_agent = PhpXmlRpc::$xmlrpcName.' '.PhpXmlRpc::$xmlrpcVersion; | |
| 393 | 393 | } | 
| 394 | 394 | |
| 395 | 395 | /** | 
| @@ -561,7 +561,7 @@ discard block | ||
| 561 | 561 | */ | 
| 562 | 562 | public function setSSLVerifyPeer($i) | 
| 563 | 563 |      { | 
| 564 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 564 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 565 | 565 | |
| 566 | 566 | $this->verifypeer = $i; | 
| 567 | 567 | return $this; | 
| @@ -578,7 +578,7 @@ discard block | ||
| 578 | 578 | */ | 
| 579 | 579 | public function setSSLVerifyHost($i) | 
| 580 | 580 |      { | 
| 581 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 581 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 582 | 582 | |
| 583 | 583 | $this->verifyhost = $i; | 
| 584 | 584 | return $this; | 
| @@ -596,7 +596,7 @@ discard block | ||
| 596 | 596 | */ | 
| 597 | 597 | public function setSSLVersion($i) | 
| 598 | 598 |      { | 
| 599 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 599 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 600 | 600 | |
| 601 | 601 | $this->sslversion = $i; | 
| 602 | 602 | return $this; | 
| @@ -661,7 +661,7 @@ discard block | ||
| 661 | 661 | */ | 
| 662 | 662 | public function setRequestCompression($compMethod) | 
| 663 | 663 |      { | 
| 664 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 664 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 665 | 665 | |
| 666 | 666 | $this->request_compression = $compMethod; | 
| 667 | 667 | return $this; | 
| @@ -711,7 +711,7 @@ discard block | ||
| 711 | 711 | */ | 
| 712 | 712 | public function setCurlOptions($options) | 
| 713 | 713 |      { | 
| 714 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 714 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 715 | 715 | |
| 716 | 716 | $this->extracurlopts = $options; | 
| 717 | 717 | return $this; | 
| @@ -725,7 +725,7 @@ discard block | ||
| 725 | 725 | */ | 
| 726 | 726 | public function setUseCurl($useCurlMode) | 
| 727 | 727 |      { | 
| 728 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 728 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 729 | 729 | |
| 730 | 730 | $this->use_curl = $useCurlMode; | 
| 731 | 731 | return $this; | 
| @@ -742,7 +742,7 @@ discard block | ||
| 742 | 742 | */ | 
| 743 | 743 | public function setUserAgent($agentString) | 
| 744 | 744 |      { | 
| 745 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 745 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 746 | 746 | |
| 747 | 747 | $this->user_agent = $agentString; | 
| 748 | 748 | return $this; | 
| @@ -774,12 +774,12 @@ discard block | ||
| 774 | 774 | } | 
| 775 | 775 | } | 
| 776 | 776 | |
| 777 | - $url = $this->method . '://' . $this->server; | |
| 777 | + $url = $this->method.'://'.$this->server; | |
| 778 | 778 |          if ($this->port == 0 || ($this->port == 80 && in_array($this->method, array('http', 'http10', 'http11', 'h2c'))) || | 
| 779 | 779 |              ($this->port == 443 && in_array($this->method, array('https', 'h2')))) { | 
| 780 | - return $url . $this->path; | |
| 780 | + return $url.$this->path; | |
| 781 | 781 |          } else { | 
| 782 | - return $url . ':' . $this->port . $this->path; | |
| 782 | + return $url.':'.$this->port.$this->path; | |
| 783 | 783 | } | 
| 784 | 784 | } | 
| 785 | 785 | |
| @@ -822,7 +822,7 @@ discard block | ||
| 822 | 822 | public function send($req, $timeout = 0, $method = '') | 
| 823 | 823 |      { | 
| 824 | 824 |          if ($method !== '' || $timeout !== 0) { | 
| 825 | -            $this->logDeprecation("Using non-default values for arguments 'method' and 'timeout' when calling method " . __METHOD__ . ' is deprecated'); | |
| 825 | +            $this->logDeprecation("Using non-default values for arguments 'method' and 'timeout' when calling method ".__METHOD__.' is deprecated'); | |
| 826 | 826 | } | 
| 827 | 827 | |
| 828 | 828 | // if user does not specify http protocol, use native method of this client | 
| @@ -946,7 +946,7 @@ discard block | ||
| 946 | 946 | $payload = $a; | 
| 947 | 947 | $encodingHdr = "Content-Encoding: gzip\r\n"; | 
| 948 | 948 |                  } else { | 
| 949 | -                    $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': gzencode failure in compressing request'); | |
| 949 | +                    $this->getLogger()->warning('XML-RPC: '.__METHOD__.': gzencode failure in compressing request'); | |
| 950 | 950 | } | 
| 951 | 951 |              } else if (function_exists('gzcompress')) { | 
| 952 | 952 | $a = @gzcompress($payload); | 
| @@ -954,14 +954,14 @@ discard block | ||
| 954 | 954 | $payload = $a; | 
| 955 | 955 | $encodingHdr = "Content-Encoding: deflate\r\n"; | 
| 956 | 956 |                  } else { | 
| 957 | -                    $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': gzcompress failure in compressing request'); | |
| 957 | +                    $this->getLogger()->warning('XML-RPC: '.__METHOD__.': gzcompress failure in compressing request'); | |
| 958 | 958 | } | 
| 959 | 959 |              } else { | 
| 960 | -                $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': desired request compression method is unsupported by this PHP install'); | |
| 960 | +                $this->getLogger()->warning('XML-RPC: '.__METHOD__.': desired request compression method is unsupported by this PHP install'); | |
| 961 | 961 | } | 
| 962 | 962 |          } else { | 
| 963 | 963 |              if ($opts['request_compression'] != '') { | 
| 964 | -                $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': desired request compression method is unsupported'); | |
| 964 | +                $this->getLogger()->warning('XML-RPC: '.__METHOD__.': desired request compression method is unsupported'); | |
| 965 | 965 | } | 
| 966 | 966 | } | 
| 967 | 967 | |
| @@ -969,16 +969,16 @@ discard block | ||
| 969 | 969 | $credentials = ''; | 
| 970 | 970 |          if ($opts['username'] != '') { | 
| 971 | 971 |              if ($opts['authtype'] != 1) { | 
| 972 | -                $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': warning. Only Basic auth is supported with HTTP 1.0'); | |
| 972 | +                $this->getLogger()->error('XML-RPC: '.__METHOD__.': warning. Only Basic auth is supported with HTTP 1.0'); | |
| 973 | 973 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], | 
| 974 | - PhpXmlRpc::$xmlrpcerr['unsupported_option'] . ': only Basic auth is supported with HTTP 1.0'); | |
| 974 | + PhpXmlRpc::$xmlrpcerr['unsupported_option'].': only Basic auth is supported with HTTP 1.0'); | |
| 975 | 975 | } | 
| 976 | - $credentials = 'Authorization: Basic ' . base64_encode($opts['username'] . ':' . $opts['password']) . "\r\n"; | |
| 976 | + $credentials = 'Authorization: Basic '.base64_encode($opts['username'].':'.$opts['password'])."\r\n"; | |
| 977 | 977 | } | 
| 978 | 978 | |
| 979 | 979 | $acceptedEncoding = ''; | 
| 980 | 980 |          if (is_array($opts['accepted_compression']) && count($opts['accepted_compression'])) { | 
| 981 | -            $acceptedEncoding = 'Accept-Encoding: ' . implode(', ', $opts['accepted_compression']) . "\r\n"; | |
| 981 | +            $acceptedEncoding = 'Accept-Encoding: '.implode(', ', $opts['accepted_compression'])."\r\n"; | |
| 982 | 982 | } | 
| 983 | 983 | |
| 984 | 984 |          if ($port == 0) { | 
| @@ -999,21 +999,21 @@ discard block | ||
| 999 | 999 |              } elseif ($method === 'h2') { | 
| 1000 | 1000 | $protocol = 'https'; | 
| 1001 | 1001 |              } else if (strpos($protocol, ':') !== false) { | 
| 1002 | -                $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ": warning - attempted hacking attempt?. The protocol requested for the call is: '$protocol'"); | |
| 1003 | - return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], PhpXmlRpc::$xmlrpcerr['unsupported_option'] . | |
| 1002 | +                $this->getLogger()->error('XML-RPC: '.__METHOD__.": warning - attempted hacking attempt?. The protocol requested for the call is: '$protocol'"); | |
| 1003 | + return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], PhpXmlRpc::$xmlrpcerr['unsupported_option']. | |
| 1004 | 1004 | " attempted hacking attempt?. The protocol requested for the call is: '$protocol'"); | 
| 1005 | 1005 | } | 
| 1006 | 1006 | /// @todo this does not work atm (tested at least with an http proxy forwarding to an https server) - we | 
| 1007 | 1007 | /// should implement the CONNECT protocol | 
| 1008 | - $uri = $protocol . '://' . $server . ':' . $port . $path; | |
| 1008 | + $uri = $protocol.'://'.$server.':'.$port.$path; | |
| 1009 | 1009 |              if ($opts['proxy_user'] != '') { | 
| 1010 | 1010 |                  if ($opts['proxy_authtype'] != 1) { | 
| 1011 | -                    $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': warning. Only Basic auth to proxy is supported with HTTP 1.0'); | |
| 1011 | +                    $this->getLogger()->error('XML-RPC: '.__METHOD__.': warning. Only Basic auth to proxy is supported with HTTP 1.0'); | |
| 1012 | 1012 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], | 
| 1013 | - PhpXmlRpc::$xmlrpcerr['unsupported_option'] . ': only Basic auth to proxy is supported with socket transport'); | |
| 1013 | + PhpXmlRpc::$xmlrpcerr['unsupported_option'].': only Basic auth to proxy is supported with socket transport'); | |
| 1014 | 1014 | } | 
| 1015 | - $proxyCredentials = 'Proxy-Authorization: Basic ' . base64_encode($opts['proxy_user'] . ':' . | |
| 1016 | - $opts['proxy_pass']) . "\r\n"; | |
| 1015 | + $proxyCredentials = 'Proxy-Authorization: Basic '.base64_encode($opts['proxy_user'].':'. | |
| 1016 | + $opts['proxy_pass'])."\r\n"; | |
| 1017 | 1017 | } | 
| 1018 | 1018 |          } else { | 
| 1019 | 1019 | $connectServer = $server; | 
| @@ -1030,14 +1030,14 @@ discard block | ||
| 1030 | 1030 | $version = ''; | 
| 1031 | 1031 |              foreach ($opts['cookies'] as $name => $cookie) { | 
| 1032 | 1032 | /// @todo should we sanitize the cookie value on behalf of the user? See setCookie comments | 
| 1033 | - $cookieHeader .= ' ' . $name . '=' . $cookie['value'] . ";"; | |
| 1033 | + $cookieHeader .= ' '.$name.'='.$cookie['value'].";"; | |
| 1034 | 1034 | } | 
| 1035 | - $cookieHeader = 'Cookie:' . $version . substr($cookieHeader, 0, -1) . "\r\n"; | |
| 1035 | + $cookieHeader = 'Cookie:'.$version.substr($cookieHeader, 0, -1)."\r\n"; | |
| 1036 | 1036 | } | 
| 1037 | 1037 | |
| 1038 | 1038 | $extraHeaders = ''; | 
| 1039 | 1039 |          if (is_array($this->extra_headers) && $this->extra_headers) { | 
| 1040 | -            $extraHeaders = implode("\r\n", $this->extra_headers) . "\r\n"; | |
| 1040 | +            $extraHeaders = implode("\r\n", $this->extra_headers)."\r\n"; | |
| 1041 | 1041 | } | 
| 1042 | 1042 | |
| 1043 | 1043 | // omit port if default | 
| @@ -1045,24 +1045,24 @@ discard block | ||
| 1045 | 1045 |          if (($port == 80 && in_array($method, array('http', 'http10', 'http11'))) || ($port == 443 && $method == 'https')) { | 
| 1046 | 1046 | $port = ''; | 
| 1047 | 1047 |          } else { | 
| 1048 | - $port = ':' . $port; | |
| 1049 | - } | |
| 1050 | - | |
| 1051 | - $op = 'POST ' . $uri . " HTTP/1.0\r\n" . | |
| 1052 | - 'User-Agent: ' . $opts['user_agent'] . "\r\n" . | |
| 1053 | - 'Host: ' . $server . $port . "\r\n" . | |
| 1054 | - $credentials . | |
| 1055 | - $proxyCredentials . | |
| 1056 | - $acceptedEncoding . | |
| 1057 | - $encodingHdr . | |
| 1058 | -            'Accept-Charset: ' . implode(',', $opts['accepted_charset_encodings']) . "\r\n" . | |
| 1059 | - $cookieHeader . | |
| 1060 | - 'Content-Type: ' . $req->getContentType() . "\r\n" . | |
| 1061 | - $extraHeaders . | |
| 1062 | - 'Content-Length: ' . strlen($payload) . "\r\n\r\n" . | |
| 1048 | + $port = ':'.$port; | |
| 1049 | + } | |
| 1050 | + | |
| 1051 | + $op = 'POST '.$uri." HTTP/1.0\r\n". | |
| 1052 | + 'User-Agent: '.$opts['user_agent']."\r\n". | |
| 1053 | + 'Host: '.$server.$port."\r\n". | |
| 1054 | + $credentials. | |
| 1055 | + $proxyCredentials. | |
| 1056 | + $acceptedEncoding. | |
| 1057 | + $encodingHdr. | |
| 1058 | +            'Accept-Charset: '.implode(',', $opts['accepted_charset_encodings'])."\r\n". | |
| 1059 | + $cookieHeader. | |
| 1060 | + 'Content-Type: '.$req->getContentType()."\r\n". | |
| 1061 | + $extraHeaders. | |
| 1062 | + 'Content-Length: '.strlen($payload)."\r\n\r\n". | |
| 1063 | 1063 | $payload; | 
| 1064 | 1064 | |
| 1065 | -        if ($opts['debug'] > 1) { | |
| 1065 | +        if ($opts['debug']>1) { | |
| 1066 | 1066 |              $this->getLogger()->debug("---SENDING---\n$op\n---END---"); | 
| 1067 | 1067 | } | 
| 1068 | 1068 | |
| @@ -1091,13 +1091,13 @@ discard block | ||
| 1091 | 1091 | /// https://www.php.net/manual/en/function.stream-socket-enable-crypto.php | 
| 1092 | 1092 | /// https://www.php.net/manual/en/migration56.openssl.php, | 
| 1093 | 1093 | /// https://wiki.php.net/rfc/improved-tls-constants | 
| 1094 | -                switch($opts['sslversion']) { | |
| 1094 | +                switch ($opts['sslversion']) { | |
| 1095 | 1095 | case 1: // TLSv1x | 
| 1096 | 1096 |                          if (version_compare(PHP_VERSION, '7.2.0', '>=')) { | 
| 1097 | 1097 | $contextOptions['ssl']['crypto_method'] = STREAM_CRYPTO_METHOD_TLS_CLIENT; | 
| 1098 | 1098 |                          } else { | 
| 1099 | 1099 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], | 
| 1100 | - PhpXmlRpc::$xmlrpcerr['unsupported_option'] . ': TLS-any only is supported with PHP 7.2 or later'); | |
| 1100 | + PhpXmlRpc::$xmlrpcerr['unsupported_option'].': TLS-any only is supported with PHP 7.2 or later'); | |
| 1101 | 1101 | } | 
| 1102 | 1102 | break; | 
| 1103 | 1103 | case 2: // SSLv2 | 
| @@ -1120,12 +1120,12 @@ discard block | ||
| 1120 | 1120 | $contextOptions['ssl']['crypto_method'] = STREAM_CRYPTO_METHOD_TLSv1_3_CLIENT; | 
| 1121 | 1121 |                          } else { | 
| 1122 | 1122 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], | 
| 1123 | - PhpXmlRpc::$xmlrpcerr['unsupported_option'] . ': TLS-1.3 only is supported with PHP 7.4 or later'); | |
| 1123 | + PhpXmlRpc::$xmlrpcerr['unsupported_option'].': TLS-1.3 only is supported with PHP 7.4 or later'); | |
| 1124 | 1124 | } | 
| 1125 | 1125 | break; | 
| 1126 | 1126 | default: | 
| 1127 | 1127 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['unsupported_option'], | 
| 1128 | - PhpXmlRpc::$xmlrpcerr['unsupported_option'] . ': Unsupported required TLS version'); | |
| 1128 | + PhpXmlRpc::$xmlrpcerr['unsupported_option'].': Unsupported required TLS version'); | |
| 1129 | 1129 | } | 
| 1130 | 1130 | } | 
| 1131 | 1131 | } | 
| @@ -1138,7 +1138,7 @@ discard block | ||
| 1138 | 1138 | |
| 1139 | 1139 | $context = stream_context_create($contextOptions); | 
| 1140 | 1140 | |
| 1141 | -        if ($opts['timeout'] <= 0) { | |
| 1141 | +        if ($opts['timeout']<=0) { | |
| 1142 | 1142 |              $connectTimeout = ini_get('default_socket_timeout'); | 
| 1143 | 1143 |          } else { | 
| 1144 | 1144 | $connectTimeout = $opts['timeout']; | 
| @@ -1157,7 +1157,7 @@ discard block | ||
| 1157 | 1157 |          $fp = @stream_socket_client("$transport://$connectServer:$connectPort", $this->errno, $this->errstr, $connectTimeout, | 
| 1158 | 1158 | STREAM_CLIENT_CONNECT, $context); | 
| 1159 | 1159 |          if ($fp) { | 
| 1160 | -            if ($opts['timeout'] > 0) { | |
| 1160 | +            if ($opts['timeout']>0) { | |
| 1161 | 1161 | stream_set_timeout($fp, $opts['timeout'], 0); | 
| 1162 | 1162 | } | 
| 1163 | 1163 |          } else { | 
| @@ -1166,8 +1166,8 @@ discard block | ||
| 1166 | 1166 | $this->errstr = $err['message']; | 
| 1167 | 1167 | } | 
| 1168 | 1168 | |
| 1169 | - $this->errstr = 'Connect error: ' . $this->errstr; | |
| 1170 | -            return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['http_error'], $this->errstr . ' (' . $this->errno . ')'); | |
| 1169 | + $this->errstr = 'Connect error: '.$this->errstr; | |
| 1170 | +            return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['http_error'], $this->errstr.' ('.$this->errno.')'); | |
| 1171 | 1171 | } | 
| 1172 | 1172 | |
| 1173 | 1173 | /// @todo from here onwards, we can inject the results of stream_get_meta_data in the response. We could | 
| @@ -1250,19 +1250,19 @@ discard block | ||
| 1250 | 1250 | $opts['keepalive'], $opts['key'], $opts['keypass'], $opts['sslversion']); | 
| 1251 | 1251 | |
| 1252 | 1252 |          if (!$curl) { | 
| 1253 | - return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['curl_fail'], PhpXmlRpc::$xmlrpcstr['curl_fail'] . | |
| 1253 | + return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['curl_fail'], PhpXmlRpc::$xmlrpcstr['curl_fail']. | |
| 1254 | 1254 | ': error during curl initialization. Check php error log for details'); | 
| 1255 | 1255 | } | 
| 1256 | 1256 | |
| 1257 | 1257 | $result = curl_exec($curl); | 
| 1258 | 1258 | |
| 1259 | -        if ($opts['debug'] > 1) { | |
| 1259 | +        if ($opts['debug']>1) { | |
| 1260 | 1260 | $message = "---CURL INFO---\n"; | 
| 1261 | 1261 |              foreach (curl_getinfo($curl) as $name => $val) { | 
| 1262 | 1262 |                  if (is_array($val)) { | 
| 1263 | 1263 |                      $val = implode("\n", $val); | 
| 1264 | 1264 | } | 
| 1265 | - $message .= $name . ': ' . $val . "\n"; | |
| 1265 | + $message .= $name.': '.$val."\n"; | |
| 1266 | 1266 | } | 
| 1267 | 1267 | $message .= '---END---'; | 
| 1268 | 1268 | $this->getLogger()->debug($message); | 
| @@ -1272,21 +1272,21 @@ discard block | ||
| 1272 | 1272 | /// @todo we should use a better check here - what if we get back '' or '0'? | 
| 1273 | 1273 | |
| 1274 | 1274 | $this->errstr = 'no response'; | 
| 1275 | - $resp = new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['curl_fail'], PhpXmlRpc::$xmlrpcstr['curl_fail'] . | |
| 1276 | - ': ' . curl_error($curl)); | |
| 1277 | - if (PHP_MAJOR_VERSION < 8) curl_close($curl); | |
| 1275 | + $resp = new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['curl_fail'], PhpXmlRpc::$xmlrpcstr['curl_fail']. | |
| 1276 | + ': '.curl_error($curl)); | |
| 1277 | + if (PHP_MAJOR_VERSION<8) curl_close($curl); | |
| 1278 | 1278 |              if ($opts['keepalive']) { | 
| 1279 | 1279 | $this->xmlrpc_curl_handle = null; | 
| 1280 | 1280 | } | 
| 1281 | 1281 |          } else { | 
| 1282 | 1282 |              if (!$opts['keepalive']) { | 
| 1283 | - if (PHP_MAJOR_VERSION < 8) curl_close($curl); | |
| 1283 | + if (PHP_MAJOR_VERSION<8) curl_close($curl); | |
| 1284 | 1284 | } | 
| 1285 | 1285 | $resp = $req->parseResponse($result, true, $opts['return_type']); | 
| 1286 | 1286 |              if ($opts['keepalive']) { | 
| 1287 | 1287 | /// @todo if we got back a 302 or 308, we should not reuse the curl handle for later calls | 
| 1288 | 1288 |                  if ($resp->faultCode() == PhpXmlRpc::$xmlrpcerr['http_error']) { | 
| 1289 | - if (PHP_MAJOR_VERSION < 8) curl_close($curl); | |
| 1289 | + if (PHP_MAJOR_VERSION<8) curl_close($curl); | |
| 1290 | 1290 | $this->xmlrpc_curl_handle = null; | 
| 1291 | 1291 | } | 
| 1292 | 1292 | } | 
| @@ -1331,7 +1331,7 @@ discard block | ||
| 1331 | 1331 | $payload = $a; | 
| 1332 | 1332 | $encodingHdr = 'Content-Encoding: gzip'; | 
| 1333 | 1333 |                  } else { | 
| 1334 | -                    $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': gzencode failure in compressing request'); | |
| 1334 | +                    $this->getLogger()->warning('XML-RPC: '.__METHOD__.': gzencode failure in compressing request'); | |
| 1335 | 1335 | } | 
| 1336 | 1336 |              } else if (function_exists('gzcompress')) { | 
| 1337 | 1337 | $a = @gzcompress($payload); | 
| @@ -1339,14 +1339,14 @@ discard block | ||
| 1339 | 1339 | $payload = $a; | 
| 1340 | 1340 | $encodingHdr = 'Content-Encoding: deflate'; | 
| 1341 | 1341 |                  } else { | 
| 1342 | -                    $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': gzcompress failure in compressing request'); | |
| 1342 | +                    $this->getLogger()->warning('XML-RPC: '.__METHOD__.': gzcompress failure in compressing request'); | |
| 1343 | 1343 | } | 
| 1344 | 1344 |              } else { | 
| 1345 | -                $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': desired request compression method is unsupported by this PHP install'); | |
| 1345 | +                $this->getLogger()->warning('XML-RPC: '.__METHOD__.': desired request compression method is unsupported by this PHP install'); | |
| 1346 | 1346 | } | 
| 1347 | 1347 |          } else { | 
| 1348 | 1348 |              if ($opts['request_compression'] != '') { | 
| 1349 | -                $this->getLogger()->warning('XML-RPC: ' . __METHOD__ . ': desired request compression method is unsupported'); | |
| 1349 | +                $this->getLogger()->warning('XML-RPC: '.__METHOD__.': desired request compression method is unsupported'); | |
| 1350 | 1350 | } | 
| 1351 | 1351 | } | 
| 1352 | 1352 | |
| @@ -1360,12 +1360,12 @@ discard block | ||
| 1360 | 1360 | // http, https | 
| 1361 | 1361 | $protocol = $method; | 
| 1362 | 1362 |                      if (strpos($protocol, ':') !== false) { | 
| 1363 | -                        $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ": warning - attempted hacking attempt?. The curl protocol requested for the call is: '$protocol'"); | |
| 1363 | +                        $this->getLogger()->error('XML-RPC: '.__METHOD__.": warning - attempted hacking attempt?. The curl protocol requested for the call is: '$protocol'"); | |
| 1364 | 1364 | return false; | 
| 1365 | 1365 | } | 
| 1366 | 1366 | } | 
| 1367 | 1367 | } | 
| 1368 | - $curl = curl_init($protocol . '://' . $server . ':' . $port . $path); | |
| 1368 | + $curl = curl_init($protocol.'://'.$server.':'.$port.$path); | |
| 1369 | 1369 |              if (!$curl) { | 
| 1370 | 1370 | return false; | 
| 1371 | 1371 | } | 
| @@ -1379,7 +1379,7 @@ discard block | ||
| 1379 | 1379 | // results into variable | 
| 1380 | 1380 | curl_setopt($curl, CURLOPT_RETURNTRANSFER, true); | 
| 1381 | 1381 | |
| 1382 | -        if ($opts['debug'] > 1) { | |
| 1382 | +        if ($opts['debug']>1) { | |
| 1383 | 1383 | curl_setopt($curl, CURLOPT_VERBOSE, true); | 
| 1384 | 1384 | /// @todo redirect curlopt_stderr to some stream which can be piped to the logger | 
| 1385 | 1385 | } | 
| @@ -1404,7 +1404,7 @@ discard block | ||
| 1404 | 1404 | } | 
| 1405 | 1405 | } | 
| 1406 | 1406 | // extra headers | 
| 1407 | -        $headers = array('Content-Type: ' . $req->getContentType(), 'Accept-Charset: ' . implode(',', $opts['accepted_charset_encodings'])); | |
| 1407 | +        $headers = array('Content-Type: '.$req->getContentType(), 'Accept-Charset: '.implode(',', $opts['accepted_charset_encodings'])); | |
| 1408 | 1408 | // if no keepalive is wanted, let the server know it in advance | 
| 1409 | 1409 |          if (!$opts['keepalive']) { | 
| 1410 | 1410 | $headers[] = 'Connection: close'; | 
| @@ -1441,8 +1441,8 @@ discard block | ||
| 1441 | 1441 |                  if (defined('CURL_HTTP_VERSION_2_PRIOR_KNOWLEDGE')) { | 
| 1442 | 1442 | curl_setopt($curl, CURLOPT_HTTP_VERSION, CURL_HTTP_VERSION_2_PRIOR_KNOWLEDGE); | 
| 1443 | 1443 |                  } else { | 
| 1444 | -                    $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': warning. HTTP2 is not supported by the current PHP/curl install'); | |
| 1445 | - if (PHP_MAJOR_VERSION < 8) curl_close($curl); | |
| 1444 | +                    $this->getLogger()->error('XML-RPC: '.__METHOD__.': warning. HTTP2 is not supported by the current PHP/curl install'); | |
| 1445 | + if (PHP_MAJOR_VERSION<8) curl_close($curl); | |
| 1446 | 1446 | return false; | 
| 1447 | 1447 | } | 
| 1448 | 1448 | break; | 
| @@ -1452,12 +1452,12 @@ discard block | ||
| 1452 | 1452 | } | 
| 1453 | 1453 | |
| 1454 | 1454 |          if ($opts['username'] && $opts['password']) { | 
| 1455 | - curl_setopt($curl, CURLOPT_USERPWD, $opts['username'] . ':' . $opts['password']); | |
| 1455 | + curl_setopt($curl, CURLOPT_USERPWD, $opts['username'].':'.$opts['password']); | |
| 1456 | 1456 |              if (defined('CURLOPT_HTTPAUTH')) { | 
| 1457 | 1457 | curl_setopt($curl, CURLOPT_HTTPAUTH, $opts['authtype']); | 
| 1458 | 1458 |              } elseif ($opts['authtype'] != 1) { | 
| 1459 | -                $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': warning. Only Basic auth is supported by the current PHP/curl install'); | |
| 1460 | - if (PHP_MAJOR_VERSION < 8) curl_close($curl); | |
| 1459 | +                $this->getLogger()->error('XML-RPC: '.__METHOD__.': warning. Only Basic auth is supported by the current PHP/curl install'); | |
| 1460 | + if (PHP_MAJOR_VERSION<8) curl_close($curl); | |
| 1461 | 1461 | return false; | 
| 1462 | 1462 | } | 
| 1463 | 1463 | } | 
| @@ -1501,14 +1501,14 @@ discard block | ||
| 1501 | 1501 |              if ($opts['proxyport'] == 0) { | 
| 1502 | 1502 | $opts['proxyport'] = 8080; // NB: even for HTTPS, local connection is on port 8080 | 
| 1503 | 1503 | } | 
| 1504 | - curl_setopt($curl, CURLOPT_PROXY, $opts['proxy'] . ':' . $opts['proxyport']); | |
| 1504 | + curl_setopt($curl, CURLOPT_PROXY, $opts['proxy'].':'.$opts['proxyport']); | |
| 1505 | 1505 |              if ($opts['proxy_user']) { | 
| 1506 | - curl_setopt($curl, CURLOPT_PROXYUSERPWD, $opts['proxy_user'] . ':' . $opts['proxy_pass']); | |
| 1506 | + curl_setopt($curl, CURLOPT_PROXYUSERPWD, $opts['proxy_user'].':'.$opts['proxy_pass']); | |
| 1507 | 1507 |                  if (defined('CURLOPT_PROXYAUTH')) { | 
| 1508 | 1508 | curl_setopt($curl, CURLOPT_PROXYAUTH, $opts['proxy_authtype']); | 
| 1509 | 1509 |                  } elseif ($opts['proxy_authtype'] != 1) { | 
| 1510 | -                    $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': warning. Only Basic auth to proxy is supported by the current PHP/curl install'); | |
| 1511 | - if (PHP_MAJOR_VERSION < 8) curl_close($curl); | |
| 1510 | +                    $this->getLogger()->error('XML-RPC: '.__METHOD__.': warning. Only Basic auth to proxy is supported by the current PHP/curl install'); | |
| 1511 | + if (PHP_MAJOR_VERSION<8) curl_close($curl); | |
| 1512 | 1512 | return false; | 
| 1513 | 1513 | } | 
| 1514 | 1514 | } | 
| @@ -1519,7 +1519,7 @@ discard block | ||
| 1519 | 1519 |          if (count($opts['cookies'])) { | 
| 1520 | 1520 | $cookieHeader = ''; | 
| 1521 | 1521 |              foreach ($opts['cookies'] as $name => $cookie) { | 
| 1522 | - $cookieHeader .= $name . '=' . $cookie['value'] . '; '; | |
| 1522 | + $cookieHeader .= $name.'='.$cookie['value'].'; '; | |
| 1523 | 1523 | } | 
| 1524 | 1524 | curl_setopt($curl, CURLOPT_COOKIE, substr($cookieHeader, 0, -2)); | 
| 1525 | 1525 | } | 
| @@ -1528,7 +1528,7 @@ discard block | ||
| 1528 | 1528 | curl_setopt($curl, $opt, $val); | 
| 1529 | 1529 | } | 
| 1530 | 1530 | |
| 1531 | -        if ($opts['debug'] > 1) { | |
| 1531 | +        if ($opts['debug']>1) { | |
| 1532 | 1532 |              $this->getLogger()->debug("---SENDING---\n$payload\n---END---"); | 
| 1533 | 1533 | } | 
| 1534 | 1534 | |
| @@ -1629,7 +1629,7 @@ discard block | ||
| 1629 | 1629 | $call['methodName'] = new Value($req->method(), 'string'); | 
| 1630 | 1630 | $numParams = $req->getNumParams(); | 
| 1631 | 1631 | $params = array(); | 
| 1632 | -            for ($i = 0; $i < $numParams; $i++) { | |
| 1632 | +            for ($i = 0; $i<$numParams; $i++) { | |
| 1633 | 1633 | $params[$i] = $req->getParam($i); | 
| 1634 | 1634 | } | 
| 1635 | 1635 | $call['params'] = new Value($params, 'array'); | 
| @@ -1651,7 +1651,7 @@ discard block | ||
| 1651 | 1651 | $response = array(); | 
| 1652 | 1652 | |
| 1653 | 1653 |          if ($this->return_type == 'xml') { | 
| 1654 | -            for ($i = 0; $i < count($reqs); $i++) { | |
| 1654 | +            for ($i = 0; $i<count($reqs); $i++) { | |
| 1655 | 1655 | $response[] = new static::$responseClass($rets, 0, '', 'xml', $result->httpResponse()); | 
| 1656 | 1656 | } | 
| 1657 | 1657 | |
| @@ -1659,21 +1659,21 @@ discard block | ||
| 1659 | 1659 |              if (!is_array($rets)) { | 
| 1660 | 1660 | // bad return type from system.multicall | 
| 1661 | 1661 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1662 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ': not an array', 'phpvals', $result->httpResponse()); | |
| 1662 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].': not an array', 'phpvals', $result->httpResponse()); | |
| 1663 | 1663 | } | 
| 1664 | 1664 | $numRets = count($rets); | 
| 1665 | 1665 |              if ($numRets != count($reqs)) { | 
| 1666 | 1666 | // wrong number of return values. | 
| 1667 | 1667 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1668 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ': incorrect number of responses', 'phpvals', | |
| 1668 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].': incorrect number of responses', 'phpvals', | |
| 1669 | 1669 | $result->httpResponse()); | 
| 1670 | 1670 | } | 
| 1671 | 1671 | |
| 1672 | -            for ($i = 0; $i < $numRets; $i++) { | |
| 1672 | +            for ($i = 0; $i<$numRets; $i++) { | |
| 1673 | 1673 | $val = $rets[$i]; | 
| 1674 | 1674 |                  if (!is_array($val)) { | 
| 1675 | 1675 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1676 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i is not an array or struct", | |
| 1676 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i is not an array or struct", | |
| 1677 | 1677 | 'phpvals', $result->httpResponse()); | 
| 1678 | 1678 | } | 
| 1679 | 1679 |                  switch (count($val)) { | 
| @@ -1681,7 +1681,7 @@ discard block | ||
| 1681 | 1681 |                          if (!isset($val[0])) { | 
| 1682 | 1682 | // Bad value | 
| 1683 | 1683 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1684 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has no value", | |
| 1684 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has no value", | |
| 1685 | 1685 | 'phpvals', $result->httpResponse()); | 
| 1686 | 1686 | } | 
| 1687 | 1687 | // Normal return value | 
| @@ -1693,20 +1693,20 @@ discard block | ||
| 1693 | 1693 |                          if (!is_int($code)) { | 
| 1694 | 1694 | /// @todo should we check that it is != 0? | 
| 1695 | 1695 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1696 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has invalid or no faultCode", | |
| 1696 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has invalid or no faultCode", | |
| 1697 | 1697 | 'phpvals', $result->httpResponse()); | 
| 1698 | 1698 | } | 
| 1699 | 1699 | $str = @$val['faultString']; | 
| 1700 | 1700 |                          if (!is_string($str)) { | 
| 1701 | 1701 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1702 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has invalid or no FaultString", | |
| 1702 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has invalid or no FaultString", | |
| 1703 | 1703 | 'phpvals', $result->httpResponse()); | 
| 1704 | 1704 | } | 
| 1705 | 1705 | $response[$i] = new static::$responseClass(0, $code, $str, 'phpvals', $result->httpResponse()); | 
| 1706 | 1706 | break; | 
| 1707 | 1707 | default: | 
| 1708 | 1708 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1709 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has too many items", | |
| 1709 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has too many items", | |
| 1710 | 1710 | 'phpvals', $result->httpResponse()); | 
| 1711 | 1711 | } | 
| 1712 | 1712 | } | 
| @@ -1715,14 +1715,14 @@ discard block | ||
| 1715 | 1715 | // return type == 'xmlrpcvals' | 
| 1716 | 1716 |              if ($rets->kindOf() != 'array') { | 
| 1717 | 1717 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1718 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i is not an array", 'xmlrpcvals', | |
| 1718 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i is not an array", 'xmlrpcvals', | |
| 1719 | 1719 | $result->httpResponse()); | 
| 1720 | 1720 | } | 
| 1721 | 1721 | $numRets = $rets->count(); | 
| 1722 | 1722 |              if ($numRets != count($reqs)) { | 
| 1723 | 1723 | // wrong number of return values. | 
| 1724 | 1724 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1725 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ': incorrect number of responses', 'xmlrpcvals', | |
| 1725 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].': incorrect number of responses', 'xmlrpcvals', | |
| 1726 | 1726 | $result->httpResponse()); | 
| 1727 | 1727 | } | 
| 1728 | 1728 | |
| @@ -1731,7 +1731,7 @@ discard block | ||
| 1731 | 1731 | case 'array': | 
| 1732 | 1732 |                          if ($val->count() != 1) { | 
| 1733 | 1733 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1734 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has too many items", | |
| 1734 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has too many items", | |
| 1735 | 1735 | 'phpvals', $result->httpResponse()); | 
| 1736 | 1736 | } | 
| 1737 | 1737 | // Normal return value | 
| @@ -1740,28 +1740,28 @@ discard block | ||
| 1740 | 1740 | case 'struct': | 
| 1741 | 1741 |                          if ($val->count() != 2) { | 
| 1742 | 1742 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1743 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has too many items", | |
| 1743 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has too many items", | |
| 1744 | 1744 | 'phpvals', $result->httpResponse()); | 
| 1745 | 1745 | } | 
| 1746 | 1746 | /** @var Value $code */ | 
| 1747 | 1747 | $code = $val['faultCode']; | 
| 1748 | 1748 |                          if ($code->kindOf() != 'scalar' || $code->scalarTyp() != 'int') { | 
| 1749 | 1749 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1750 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has invalid or no faultCode", | |
| 1750 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has invalid or no faultCode", | |
| 1751 | 1751 | 'xmlrpcvals', $result->httpResponse()); | 
| 1752 | 1752 | } | 
| 1753 | 1753 | /** @var Value $str */ | 
| 1754 | 1754 | $str = $val['faultString']; | 
| 1755 | 1755 |                          if ($str->kindOf() != 'scalar' || $str->scalarTyp() != 'string') { | 
| 1756 | 1756 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1757 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i has invalid or no faultCode", | |
| 1757 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i has invalid or no faultCode", | |
| 1758 | 1758 | 'xmlrpcvals', $result->httpResponse()); | 
| 1759 | 1759 | } | 
| 1760 | 1760 | $response[] = new static::$responseClass(0, $code->scalarVal(), $str->scalarVal(), 'xmlrpcvals', $result->httpResponse()); | 
| 1761 | 1761 | break; | 
| 1762 | 1762 | default: | 
| 1763 | 1763 | return new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['multicall_error'], | 
| 1764 | - PhpXmlRpc::$xmlrpcstr['multicall_error'] . ": response element $i is not an array or struct", | |
| 1764 | + PhpXmlRpc::$xmlrpcstr['multicall_error'].": response element $i is not an array or struct", | |
| 1765 | 1765 | 'xmlrpcvals', $result->httpResponse()); | 
| 1766 | 1766 | } | 
| 1767 | 1767 | } | 
| @@ -1796,7 +1796,7 @@ discard block | ||
| 1796 | 1796 | $authType = 1, $proxyHost = '', $proxyPort = 0, $proxyUsername = '', $proxyPassword = '', $proxyAuthType = 1, | 
| 1797 | 1797 | $method = 'http') | 
| 1798 | 1798 |      { | 
| 1799 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 1799 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 1800 | 1800 | |
| 1801 | 1801 | return $this->sendPayloadSocket($req, $server, $port, $timeout, $username, $password, $authType, null, null, | 
| 1802 | 1802 | null, null, $proxyHost, $proxyPort, $proxyUsername, $proxyPassword, $proxyAuthType, $method); | 
| @@ -1834,7 +1834,7 @@ discard block | ||
| 1834 | 1834 | $proxyUsername = '', $proxyPassword = '', $proxyAuthType = 1, $keepAlive = false, $key = '', $keyPass = '', | 
| 1835 | 1835 | $sslVersion = 0) | 
| 1836 | 1836 |      { | 
| 1837 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 1837 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 1838 | 1838 | |
| 1839 | 1839 | return $this->sendPayloadCURL($req, $server, $port, $timeout, $username, | 
| 1840 | 1840 | $password, $authType, $cert, $certPass, $caCert, $caCertDir, $proxyHost, $proxyPort, | 
| @@ -2047,7 +2047,7 @@ discard block | ||
| 2047 | 2047 | public function &__get($name) | 
| 2048 | 2048 |      { | 
| 2049 | 2049 |          if (in_array($name, static::$options)) { | 
| 2050 | -            $this->logDeprecation('Getting property Client::' . $name . ' is deprecated'); | |
| 2050 | +            $this->logDeprecation('Getting property Client::'.$name.' is deprecated'); | |
| 2051 | 2051 | return $this->$name; | 
| 2052 | 2052 | } | 
| 2053 | 2053 | |
| @@ -2058,12 +2058,12 @@ discard block | ||
| 2058 | 2058 | case 'server': | 
| 2059 | 2059 | case 'port': | 
| 2060 | 2060 | case 'path': | 
| 2061 | -                $this->logDeprecation('Getting property Client::' . $name . ' is deprecated'); | |
| 2061 | +                $this->logDeprecation('Getting property Client::'.$name.' is deprecated'); | |
| 2062 | 2062 | return $this->$name; | 
| 2063 | 2063 | default: | 
| 2064 | 2064 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 2065 | 2065 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 2066 | -                trigger_error('Undefined property via __get(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 2066 | +                trigger_error('Undefined property via __get(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 2067 | 2067 | $result = null; | 
| 2068 | 2068 | return $result; | 
| 2069 | 2069 | } | 
| @@ -2072,7 +2072,7 @@ discard block | ||
| 2072 | 2072 | public function __set($name, $value) | 
| 2073 | 2073 |      { | 
| 2074 | 2074 |          if (in_array($name, static::$options)) { | 
| 2075 | -            $this->logDeprecation('Setting property Client::' . $name . ' is deprecated'); | |
| 2075 | +            $this->logDeprecation('Setting property Client::'.$name.' is deprecated'); | |
| 2076 | 2076 | $this->$name = $value; | 
| 2077 | 2077 | return; | 
| 2078 | 2078 | } | 
| @@ -2084,20 +2084,20 @@ discard block | ||
| 2084 | 2084 | case 'server': | 
| 2085 | 2085 | case 'port': | 
| 2086 | 2086 | case 'path': | 
| 2087 | -                $this->logDeprecation('Setting property Client::' . $name . ' is deprecated'); | |
| 2087 | +                $this->logDeprecation('Setting property Client::'.$name.' is deprecated'); | |
| 2088 | 2088 | $this->$name = $value; | 
| 2089 | 2089 | return; | 
| 2090 | 2090 | default: | 
| 2091 | 2091 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 2092 | 2092 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 2093 | -                trigger_error('Undefined property via __set(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 2093 | +                trigger_error('Undefined property via __set(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 2094 | 2094 | } | 
| 2095 | 2095 | } | 
| 2096 | 2096 | |
| 2097 | 2097 | public function __isset($name) | 
| 2098 | 2098 |      { | 
| 2099 | 2099 |          if (in_array($name, static::$options)) { | 
| 2100 | -            $this->logDeprecation('Checking property Client::' . $name . ' is deprecated'); | |
| 2100 | +            $this->logDeprecation('Checking property Client::'.$name.' is deprecated'); | |
| 2101 | 2101 | return isset($this->$name); | 
| 2102 | 2102 | } | 
| 2103 | 2103 | |
| @@ -2108,7 +2108,7 @@ discard block | ||
| 2108 | 2108 | case 'server': | 
| 2109 | 2109 | case 'port': | 
| 2110 | 2110 | case 'path': | 
| 2111 | -                $this->logDeprecation('Checking property Client::' . $name . ' is deprecated'); | |
| 2111 | +                $this->logDeprecation('Checking property Client::'.$name.' is deprecated'); | |
| 2112 | 2112 | return isset($this->$name); | 
| 2113 | 2113 | default: | 
| 2114 | 2114 | return false; | 
| @@ -2118,7 +2118,7 @@ discard block | ||
| 2118 | 2118 | public function __unset($name) | 
| 2119 | 2119 |      { | 
| 2120 | 2120 |          if (in_array($name, static::$options)) { | 
| 2121 | -            $this->logDeprecation('Unsetting property Client::' . $name . ' is deprecated'); | |
| 2121 | +            $this->logDeprecation('Unsetting property Client::'.$name.' is deprecated'); | |
| 2122 | 2122 | unset($this->$name); | 
| 2123 | 2123 | return; | 
| 2124 | 2124 | } | 
| @@ -2130,13 +2130,13 @@ discard block | ||
| 2130 | 2130 | case 'server': | 
| 2131 | 2131 | case 'port': | 
| 2132 | 2132 | case 'path': | 
| 2133 | -                $this->logDeprecation('Unsetting property Client::' . $name . ' is deprecated'); | |
| 2133 | +                $this->logDeprecation('Unsetting property Client::'.$name.' is deprecated'); | |
| 2134 | 2134 | unset($this->$name); | 
| 2135 | 2135 | return; | 
| 2136 | 2136 | default: | 
| 2137 | 2137 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 2138 | 2138 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 2139 | -                trigger_error('Undefined property via __unset(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 2139 | +                trigger_error('Undefined property via __unset(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 2140 | 2140 | } | 
| 2141 | 2141 | } | 
| 2142 | 2142 | } | 
| @@ -187,12 +187,12 @@ discard block | ||
| 187 | 187 | // q: can php be built without ctype? should we use a regexp? | 
| 188 | 188 |              if (is_string($key) && !ctype_digit($key)) { | 
| 189 | 189 | /// @todo on invalid options, throw/error-out instead of logging an error message? | 
| 190 | -                switch($key) { | |
| 190 | +                switch ($key) { | |
| 191 | 191 | case 'target_charset': | 
| 192 | 192 |                          if (function_exists('mb_convert_encoding')) { | 
| 193 | 193 | $this->current_parsing_options['target_charset'] = $val; | 
| 194 | 194 |                          } else { | 
| 195 | -                            $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ": 'target_charset' option is unsupported without mbstring"); | |
| 195 | +                            $this->getLogger()->error('XML-RPC: '.__METHOD__.": 'target_charset' option is unsupported without mbstring"); | |
| 196 | 196 | } | 
| 197 | 197 | break; | 
| 198 | 198 | |
| @@ -200,7 +200,7 @@ discard block | ||
| 200 | 200 |                          if (is_callable($val)) { | 
| 201 | 201 | $this->current_parsing_options['methodname_callback'] = $val; | 
| 202 | 202 |                          } else { | 
| 203 | -                            $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ": Callback passed as 'methodname_callback' is not callable"); | |
| 203 | +                            $this->getLogger()->error('XML-RPC: '.__METHOD__.": Callback passed as 'methodname_callback' is not callable"); | |
| 204 | 204 | } | 
| 205 | 205 | break; | 
| 206 | 206 | |
| @@ -211,7 +211,7 @@ discard block | ||
| 211 | 211 | break; | 
| 212 | 212 | |
| 213 | 213 | default: | 
| 214 | -                        $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ": unsupported option: $key"); | |
| 214 | +                        $this->getLogger()->error('XML-RPC: '.__METHOD__.": unsupported option: $key"); | |
| 215 | 215 | } | 
| 216 | 216 | unset($mergedOptions[$key]); | 
| 217 | 217 | } | 
| @@ -255,10 +255,10 @@ discard block | ||
| 255 | 255 | |
| 256 | 256 |          try { | 
| 257 | 257 | // @see ticket #70 - we have to parse big xml docs in chunks to avoid errors | 
| 258 | -            for ($offset = 0; $offset < $len; $offset += $this->maxChunkLength) { | |
| 258 | +            for ($offset = 0; $offset<$len; $offset += $this->maxChunkLength) { | |
| 259 | 259 | $chunk = substr($data, $offset, $this->maxChunkLength); | 
| 260 | 260 | // error handling: xml not well formed | 
| 261 | -                if (!@xml_parse($parser, $chunk, $offset + $this->maxChunkLength >= $len)) { | |
| 261 | +                if (!@xml_parse($parser, $chunk, $offset+$this->maxChunkLength>=$len)) { | |
| 262 | 262 | $errCode = xml_get_error_code($parser); | 
| 263 | 263 |                      $errStr = sprintf('XML error %s: %s at line %d, column %d', $errCode, xml_error_string($errCode), | 
| 264 | 264 | xml_get_current_line_number($parser), xml_get_current_column_number($parser)); | 
| @@ -266,25 +266,25 @@ discard block | ||
| 266 | 266 | $this->_xh['isf_reason'] = $errStr; | 
| 267 | 267 | } | 
| 268 | 268 | // no need to parse further if we already have a fatal error | 
| 269 | -                if ($this->_xh['isf'] >= 2) { | |
| 269 | +                if ($this->_xh['isf']>=2) { | |
| 270 | 270 | break; | 
| 271 | 271 | } | 
| 272 | 272 | } | 
| 273 | 273 | /// @todo bump minimum php version to 5.5 and use a finally clause instead of doing cleanup 3 times | 
| 274 | 274 |          } catch (\Exception $e) { | 
| 275 | - if (PHP_MAJOR_VERSION < 8) xml_parser_free($parser); | |
| 275 | + if (PHP_MAJOR_VERSION<8) xml_parser_free($parser); | |
| 276 | 276 | $this->current_parsing_options = array(); | 
| 277 | 277 | /// @todo should we set $this->_xh['isf'] and $this->_xh['isf_reason'] ? | 
| 278 | 278 | throw $e; | 
| 279 | 279 |          } catch (\Error $e) { | 
| 280 | - if (PHP_MAJOR_VERSION < 8) xml_parser_free($parser); | |
| 280 | + if (PHP_MAJOR_VERSION<8) xml_parser_free($parser); | |
| 281 | 281 | $this->current_parsing_options = array(); | 
| 282 | 282 | //$this->accept = $prevAccept; | 
| 283 | 283 | /// @todo should we set $this->_xh['isf'] and $this->_xh['isf_reason'] ? | 
| 284 | 284 | throw $e; | 
| 285 | 285 | } | 
| 286 | 286 | |
| 287 | - if (PHP_MAJOR_VERSION < 8) xml_parser_free($parser); | |
| 287 | + if (PHP_MAJOR_VERSION<8) xml_parser_free($parser); | |
| 288 | 288 | $this->current_parsing_options = array(); | 
| 289 | 289 | |
| 290 | 290 | // BC | 
| @@ -311,7 +311,7 @@ discard block | ||
| 311 | 311 | public function xmlrpc_se($parser, $name, $attrs, $acceptSingleVals = false) | 
| 312 | 312 |      { | 
| 313 | 313 | // if invalid xml-rpc already detected, skip all processing | 
| 314 | -        if ($this->_xh['isf'] >= 2) { | |
| 314 | +        if ($this->_xh['isf']>=2) { | |
| 315 | 315 | return; | 
| 316 | 316 | } | 
| 317 | 317 | |
| @@ -325,7 +325,7 @@ discard block | ||
| 325 | 325 |              if ($acceptSingleVals === false) { | 
| 326 | 326 | $accept = $this->current_parsing_options['accept']; | 
| 327 | 327 |              } else { | 
| 328 | -                $this->logDeprecation('Using argument $acceptSingleVals for method ' . __METHOD__ . ' is deprecated'); | |
| 328 | +                $this->logDeprecation('Using argument $acceptSingleVals for method '.__METHOD__.' is deprecated'); | |
| 329 | 329 | $accept = self::ACCEPT_REQUEST | self::ACCEPT_RESPONSE | self::ACCEPT_VALUE; | 
| 330 | 330 | } | 
| 331 | 331 | if (($name == 'METHODCALL' && ($accept & self::ACCEPT_REQUEST)) || | 
| @@ -335,7 +335,7 @@ discard block | ||
| 335 | 335 | $this->_xh['rt'] = strtolower($name); | 
| 336 | 336 |              } else { | 
| 337 | 337 | $this->_xh['isf'] = 2; | 
| 338 | - $this->_xh['isf_reason'] = 'missing top level xmlrpc element. Found: ' . $name; | |
| 338 | + $this->_xh['isf_reason'] = 'missing top level xmlrpc element. Found: '.$name; | |
| 339 | 339 | |
| 340 | 340 | return; | 
| 341 | 341 | } | 
| @@ -440,7 +440,7 @@ discard block | ||
| 440 | 440 | |
| 441 | 441 | case 'MEMBER': | 
| 442 | 442 | // set member name to null, in case we do not find in the xml later on | 
| 443 | - $this->_xh['valuestack'][count($this->_xh['valuestack']) - 1]['name'] = null; | |
| 443 | + $this->_xh['valuestack'][count($this->_xh['valuestack'])-1]['name'] = null; | |
| 444 | 444 | //$this->_xh['ac']=''; | 
| 445 | 445 | // Drop trough intentionally | 
| 446 | 446 | |
| @@ -503,7 +503,7 @@ discard block | ||
| 503 | 503 | */ | 
| 504 | 504 | public function xmlrpc_ee($parser, $name, $rebuildXmlrpcvals = 1) | 
| 505 | 505 |      { | 
| 506 | -        if ($this->_xh['isf'] >= 2) { | |
| 506 | +        if ($this->_xh['isf']>=2) { | |
| 507 | 507 | return; | 
| 508 | 508 | } | 
| 509 | 509 | |
| @@ -525,7 +525,7 @@ discard block | ||
| 525 | 525 | $this->_xh['value'] = mb_convert_encoding($this->_xh['value'], $this->current_parsing_options['target_charset'], 'UTF-8'); | 
| 526 | 526 | } | 
| 527 | 527 | |
| 528 | -                if ($rebuildXmlrpcvals > 0) { | |
| 528 | +                if ($rebuildXmlrpcvals>0) { | |
| 529 | 529 | // build the xml-rpc val out of the data received, and substitute it | 
| 530 | 530 | $temp = new Value($this->_xh['value'], $this->_xh['vt']); | 
| 531 | 531 | // in case we got info about underlying php class, save it in the object we're rebuilding | 
| @@ -533,15 +533,15 @@ discard block | ||
| 533 | 533 | $temp->_php_class = $this->_xh['php_class']; | 
| 534 | 534 | } | 
| 535 | 535 | $this->_xh['value'] = $temp; | 
| 536 | -                } elseif ($rebuildXmlrpcvals < 0) { | |
| 536 | +                } elseif ($rebuildXmlrpcvals<0) { | |
| 537 | 537 |                      if ($this->_xh['vt'] == Value::$xmlrpcDateTime) { | 
| 538 | - $this->_xh['value'] = (object)array( | |
| 538 | + $this->_xh['value'] = (object) array( | |
| 539 | 539 | 'xmlrpc_type' => 'datetime', | 
| 540 | 540 | 'scalar' => $this->_xh['value'], | 
| 541 | 541 | 'timestamp' => \PhpXmlRpc\Helper\Date::iso8601Decode($this->_xh['value']) | 
| 542 | 542 | ); | 
| 543 | 543 |                      } elseif ($this->_xh['vt'] == Value::$xmlrpcBase64) { | 
| 544 | - $this->_xh['value'] = (object)array( | |
| 544 | + $this->_xh['value'] = (object) array( | |
| 545 | 545 | 'xmlrpc_type' => 'base64', | 
| 546 | 546 | 'scalar' => $this->_xh['value'] | 
| 547 | 547 | ); | 
| @@ -556,8 +556,8 @@ discard block | ||
| 556 | 556 | // check if we are inside an array or struct: | 
| 557 | 557 | // if value just built is inside an array, let's move it into array on the stack | 
| 558 | 558 | $vscount = count($this->_xh['valuestack']); | 
| 559 | -                if ($vscount && $this->_xh['valuestack'][$vscount - 1]['type'] == 'ARRAY') { | |
| 560 | - $this->_xh['valuestack'][$vscount - 1]['values'][] = $this->_xh['value']; | |
| 559 | +                if ($vscount && $this->_xh['valuestack'][$vscount-1]['type'] == 'ARRAY') { | |
| 560 | + $this->_xh['valuestack'][$vscount-1]['values'][] = $this->_xh['value']; | |
| 561 | 561 | } | 
| 562 | 562 | break; | 
| 563 | 563 | |
| @@ -584,7 +584,7 @@ discard block | ||
| 584 | 584 | // log if receiving something strange, even though we set the value to false anyway | 
| 585 | 585 | /// @todo to be consistent with the other types, we should return a value outside the good-value domain, e.g. NULL | 
| 586 | 586 |                      if ($this->_xh['ac'] != '0' && strcasecmp($this->_xh['ac'], 'false') !== 0) { | 
| 587 | -                        if (!$this->handleParsingError('invalid data received in BOOLEAN value: ' . | |
| 587 | +                        if (!$this->handleParsingError('invalid data received in BOOLEAN value: '. | |
| 588 | 588 |                              $this->truncateValueForLog($this->_xh['ac']), __METHOD__)) { | 
| 589 | 589 | return; | 
| 590 | 590 | } | 
| @@ -604,7 +604,7 @@ discard block | ||
| 604 | 604 | $this->_xh['vt'] = strtolower($name); | 
| 605 | 605 | $this->_xh['lv'] = 3; // indicate we've found a value | 
| 606 | 606 |                  if (!preg_match(PhpXmlRpc::$xmlrpc_int_format, $this->_xh['ac'])) { | 
| 607 | -                    if (!$this->handleParsingError('non numeric data received in INT value: ' . | |
| 607 | +                    if (!$this->handleParsingError('non numeric data received in INT value: '. | |
| 608 | 608 |                          $this->truncateValueForLog($this->_xh['ac']), __METHOD__)) { | 
| 609 | 609 | return; | 
| 610 | 610 | } | 
| @@ -612,7 +612,7 @@ discard block | ||
| 612 | 612 | $this->_xh['value'] = 'ERROR_NON_NUMERIC_FOUND'; | 
| 613 | 613 |                  } else { | 
| 614 | 614 | // it's ok, add it on | 
| 615 | - $this->_xh['value'] = (int)$this->_xh['ac']; | |
| 615 | + $this->_xh['value'] = (int) $this->_xh['ac']; | |
| 616 | 616 | } | 
| 617 | 617 | break; | 
| 618 | 618 | |
| @@ -620,7 +620,7 @@ discard block | ||
| 620 | 620 | $this->_xh['vt'] = Value::$xmlrpcDouble; | 
| 621 | 621 | $this->_xh['lv'] = 3; // indicate we've found a value | 
| 622 | 622 |                  if (!preg_match(PhpXmlRpc::$xmlrpc_double_format, $this->_xh['ac'])) { | 
| 623 | -                    if (!$this->handleParsingError('non numeric data received in DOUBLE value: ' . | |
| 623 | +                    if (!$this->handleParsingError('non numeric data received in DOUBLE value: '. | |
| 624 | 624 |                          $this->truncateValueForLog($this->_xh['ac']), __METHOD__)) { | 
| 625 | 625 | return; | 
| 626 | 626 | } | 
| @@ -628,7 +628,7 @@ discard block | ||
| 628 | 628 | $this->_xh['value'] = 'ERROR_NON_NUMERIC_FOUND'; | 
| 629 | 629 |                  } else { | 
| 630 | 630 | // it's ok, add it on | 
| 631 | - $this->_xh['value'] = (float)$this->_xh['ac']; | |
| 631 | + $this->_xh['value'] = (float) $this->_xh['ac']; | |
| 632 | 632 | } | 
| 633 | 633 | break; | 
| 634 | 634 | |
| @@ -636,7 +636,7 @@ discard block | ||
| 636 | 636 | $this->_xh['vt'] = Value::$xmlrpcDateTime; | 
| 637 | 637 | $this->_xh['lv'] = 3; // indicate we've found a value | 
| 638 | 638 |                  if (!preg_match(PhpXmlRpc::$xmlrpc_datetime_format, $this->_xh['ac'])) { | 
| 639 | -                    if (!$this->handleParsingError('invalid data received in DATETIME value: ' . | |
| 639 | +                    if (!$this->handleParsingError('invalid data received in DATETIME value: '. | |
| 640 | 640 |                          $this->truncateValueForLog($this->_xh['ac']), __METHOD__)) { | 
| 641 | 641 | return; | 
| 642 | 642 | } | 
| @@ -647,9 +647,9 @@ discard block | ||
| 647 | 647 | |
| 648 | 648 | // the default regex used to validate the date string a few lines above should make this case impossible, | 
| 649 | 649 | // but one never knows... | 
| 650 | -                    } catch(\Exception $e) { | |
| 650 | +                    } catch (\Exception $e) { | |
| 651 | 651 | // what to do? We can not guarantee that a valid date can be created. We return null... | 
| 652 | -                        if (!$this->handleParsingError('invalid data received in DATETIME value. Error ' . | |
| 652 | +                        if (!$this->handleParsingError('invalid data received in DATETIME value. Error '. | |
| 653 | 653 |                              $e->getMessage(), __METHOD__)) { | 
| 654 | 654 | return; | 
| 655 | 655 | } | 
| @@ -666,14 +666,14 @@ discard block | ||
| 666 | 666 | $v = base64_decode($this->_xh['ac'], true); | 
| 667 | 667 |                      if ($v === false) { | 
| 668 | 668 | $this->_xh['isf'] = 2; | 
| 669 | - $this->_xh['isf_reason'] = 'Invalid data received in BASE64 value: '. $this->truncateValueForLog($this->_xh['ac']); | |
| 669 | + $this->_xh['isf_reason'] = 'Invalid data received in BASE64 value: '.$this->truncateValueForLog($this->_xh['ac']); | |
| 670 | 670 | return; | 
| 671 | 671 | } | 
| 672 | 672 |                  } else { | 
| 673 | 673 | $v = base64_decode($this->_xh['ac']); | 
| 674 | 674 |                      if ($v === '' && $this->_xh['ac'] !== '') { | 
| 675 | 675 | // only the empty string should decode to the empty string | 
| 676 | -                        $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': invalid data received in BASE64 value: ' . | |
| 676 | +                        $this->getLogger()->error('XML-RPC: '.__METHOD__.': invalid data received in BASE64 value: '. | |
| 677 | 677 | $this->truncateValueForLog($this->_xh['ac'])); | 
| 678 | 678 | } | 
| 679 | 679 | } | 
| @@ -681,20 +681,20 @@ discard block | ||
| 681 | 681 | break; | 
| 682 | 682 | |
| 683 | 683 | case 'NAME': | 
| 684 | - $this->_xh['valuestack'][count($this->_xh['valuestack']) - 1]['name'] = $this->_xh['ac']; | |
| 684 | + $this->_xh['valuestack'][count($this->_xh['valuestack'])-1]['name'] = $this->_xh['ac']; | |
| 685 | 685 | break; | 
| 686 | 686 | |
| 687 | 687 | case 'MEMBER': | 
| 688 | 688 | // add to array in the stack the last element built, unless no VALUE or no NAME were found | 
| 689 | 689 |                  if ($this->_xh['vt']) { | 
| 690 | 690 | $vscount = count($this->_xh['valuestack']); | 
| 691 | -                    if ($this->_xh['valuestack'][$vscount - 1]['name'] === null) { | |
| 691 | +                    if ($this->_xh['valuestack'][$vscount-1]['name'] === null) { | |
| 692 | 692 |                          if (!$this->handleParsingError('missing NAME inside STRUCT in received xml', __METHOD__)) { | 
| 693 | 693 | return; | 
| 694 | 694 | } | 
| 695 | - $this->_xh['valuestack'][$vscount - 1]['name'] = ''; | |
| 695 | + $this->_xh['valuestack'][$vscount-1]['name'] = ''; | |
| 696 | 696 | } | 
| 697 | - $this->_xh['valuestack'][$vscount - 1]['values'][$this->_xh['valuestack'][$vscount - 1]['name']] = $this->_xh['value']; | |
| 697 | + $this->_xh['valuestack'][$vscount-1]['values'][$this->_xh['valuestack'][$vscount-1]['name']] = $this->_xh['value']; | |
| 698 | 698 |                  } else { | 
| 699 | 699 |                      if (!$this->handleParsingError('missing VALUE inside STRUCT in received xml', __METHOD__)) { | 
| 700 | 700 | return; | 
| @@ -828,7 +828,7 @@ discard block | ||
| 828 | 828 | public function xmlrpc_cd($parser, $data) | 
| 829 | 829 |      { | 
| 830 | 830 | // skip processing if xml fault already detected | 
| 831 | -        if ($this->_xh['isf'] >= 2) { | |
| 831 | +        if ($this->_xh['isf']>=2) { | |
| 832 | 832 | return; | 
| 833 | 833 | } | 
| 834 | 834 | |
| @@ -850,7 +850,7 @@ discard block | ||
| 850 | 850 | public function xmlrpc_dh($parser, $data) | 
| 851 | 851 |      { | 
| 852 | 852 | // skip processing if xml fault already detected | 
| 853 | -        if ($this->_xh['isf'] >= 2) { | |
| 853 | +        if ($this->_xh['isf']>=2) { | |
| 854 | 854 | return; | 
| 855 | 855 | } | 
| 856 | 856 | |
| @@ -930,8 +930,8 @@ discard block | ||
| 930 | 930 | // SPACE: (#x20 | #x9 | #xD | #xA)+ === [ \x9\xD\xA]+ | 
| 931 | 931 | // EQ: SPACE?=SPACE? === [ \x9\xD\xA]*=[ \x9\xD\xA]* | 
| 932 | 932 | // We could be stricter on version number: VersionNum ::= '1.' [0-9]+ | 
| 933 | -        if (preg_match('/^<\?xml\s+version\s*=\s*' . "((?:\"[a-zA-Z0-9_.:-]+\")|(?:'[a-zA-Z0-9_.:-]+'))" . | |
| 934 | - '\s+encoding\s*=\s*' . "((?:\"[A-Za-z][A-Za-z0-9._-]*\")|(?:'[A-Za-z][A-Za-z0-9._-]*'))/", | |
| 933 | +        if (preg_match('/^<\?xml\s+version\s*=\s*'."((?:\"[a-zA-Z0-9_.:-]+\")|(?:'[a-zA-Z0-9_.:-]+'))". | |
| 934 | + '\s+encoding\s*=\s*'."((?:\"[A-Za-z][A-Za-z0-9._-]*\")|(?:'[A-Za-z][A-Za-z0-9._-]*'))/", | |
| 935 | 935 |              $xmlChunk, $matches)) { | 
| 936 | 936 | return strtoupper(substr($matches[2], 1, -1)); | 
| 937 | 937 | } | 
| @@ -949,7 +949,7 @@ discard block | ||
| 949 | 949 | // NB: mb_detect likes to call it ascii, xml parser likes to call it US_ASCII... | 
| 950 | 950 | // IANA also likes better US-ASCII, so go with it | 
| 951 | 951 |              if ($enc == 'ASCII') { | 
| 952 | - $enc = 'US-' . $enc; | |
| 952 | + $enc = 'US-'.$enc; | |
| 953 | 953 | } | 
| 954 | 954 | |
| 955 | 955 | return $enc; | 
| @@ -990,8 +990,8 @@ discard block | ||
| 990 | 990 | // SPACE: (#x20 | #x9 | #xD | #xA)+ === [ \x9\xD\xA]+ | 
| 991 | 991 | // EQ: SPACE?=SPACE? === [ \x9\xD\xA]*=[ \x9\xD\xA]* | 
| 992 | 992 | // We could be stricter on version number: VersionNum ::= '1.' [0-9]+ | 
| 993 | -        if (preg_match('/^<\?xml\s+version\s*=\s*' . "((?:\"[a-zA-Z0-9_.:-]+\")|(?:'[a-zA-Z0-9_.:-]+'))" . | |
| 994 | - '\s+encoding\s*=\s*' . "((?:\"[A-Za-z][A-Za-z0-9._-]*\")|(?:'[A-Za-z][A-Za-z0-9._-]*'))/", | |
| 993 | +        if (preg_match('/^<\?xml\s+version\s*=\s*'."((?:\"[a-zA-Z0-9_.:-]+\")|(?:'[a-zA-Z0-9_.:-]+'))". | |
| 994 | + '\s+encoding\s*=\s*'."((?:\"[A-Za-z][A-Za-z0-9._-]*\")|(?:'[A-Za-z][A-Za-z0-9._-]*'))/", | |
| 995 | 995 |              $xmlChunk)) { | 
| 996 | 996 | return true; | 
| 997 | 997 | } | 
| @@ -1011,7 +1011,7 @@ discard block | ||
| 1011 | 1011 | $this->_xh['isf_reason'] = ucfirst($message); | 
| 1012 | 1012 | return false; | 
| 1013 | 1013 |          } else { | 
| 1014 | -            $this->getLogger()->error('XML-RPC: ' . ($method != '' ? $method . ': ' : '') . $message); | |
| 1014 | +            $this->getLogger()->error('XML-RPC: '.($method != '' ? $method.': ' : '').$message); | |
| 1015 | 1015 | return true; | 
| 1016 | 1016 | } | 
| 1017 | 1017 | } | 
| @@ -1023,8 +1023,8 @@ discard block | ||
| 1023 | 1023 | */ | 
| 1024 | 1024 | protected function truncateValueForLog($data) | 
| 1025 | 1025 |      { | 
| 1026 | -        if (strlen($data) > $this->maxLogValueLength) { | |
| 1027 | - return substr($data, 0, $this->maxLogValueLength - 3) . '...'; | |
| 1026 | +        if (strlen($data)>$this->maxLogValueLength) { | |
| 1027 | + return substr($data, 0, $this->maxLogValueLength-3).'...'; | |
| 1028 | 1028 | } | 
| 1029 | 1029 | |
| 1030 | 1030 | return $data; | 
| @@ -1045,7 +1045,7 @@ discard block | ||
| 1045 | 1045 | public function xmlrpc_se_any($parser, $name, $attrs) | 
| 1046 | 1046 |      { | 
| 1047 | 1047 | // this will be spamming the log if this method is in use... | 
| 1048 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 1048 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 1049 | 1049 | |
| 1050 | 1050 | $this->xmlrpc_se($parser, $name, $attrs, true); | 
| 1051 | 1051 | } | 
| @@ -1055,12 +1055,12 @@ discard block | ||
| 1055 | 1055 |          switch ($name) { | 
| 1056 | 1056 | case '_xh': | 
| 1057 | 1057 | case 'xmlrpc_valid_parents': | 
| 1058 | -                $this->logDeprecation('Getting property XMLParser::' . $name . ' is deprecated'); | |
| 1058 | +                $this->logDeprecation('Getting property XMLParser::'.$name.' is deprecated'); | |
| 1059 | 1059 | return $this->$name; | 
| 1060 | 1060 | default: | 
| 1061 | 1061 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 1062 | 1062 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 1063 | -                trigger_error('Undefined property via __get(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 1063 | +                trigger_error('Undefined property via __get(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 1064 | 1064 | $result = null; | 
| 1065 | 1065 | return $result; | 
| 1066 | 1066 | } | 
| @@ -1071,18 +1071,18 @@ discard block | ||
| 1071 | 1071 |          switch ($name) { | 
| 1072 | 1072 | // this should only ever be called by subclasses which overtook `parse()` | 
| 1073 | 1073 | case 'accept': | 
| 1074 | -                $this->logDeprecation('Setting property XMLParser::' . $name . ' is deprecated'); | |
| 1074 | +                $this->logDeprecation('Setting property XMLParser::'.$name.' is deprecated'); | |
| 1075 | 1075 | $this->current_parsing_options['accept'] = $value; | 
| 1076 | 1076 | break; | 
| 1077 | 1077 | case '_xh': | 
| 1078 | 1078 | case 'xmlrpc_valid_parents': | 
| 1079 | -                $this->logDeprecation('Setting property XMLParser::' . $name . ' is deprecated'); | |
| 1079 | +                $this->logDeprecation('Setting property XMLParser::'.$name.' is deprecated'); | |
| 1080 | 1080 | $this->$name = $value; | 
| 1081 | 1081 | break; | 
| 1082 | 1082 | default: | 
| 1083 | 1083 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 1084 | 1084 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 1085 | -                trigger_error('Undefined property via __set(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 1085 | +                trigger_error('Undefined property via __set(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 1086 | 1086 | } | 
| 1087 | 1087 | } | 
| 1088 | 1088 | |
| @@ -1090,11 +1090,11 @@ discard block | ||
| 1090 | 1090 |      { | 
| 1091 | 1091 |          switch ($name) { | 
| 1092 | 1092 | case 'accept': | 
| 1093 | -                $this->logDeprecation('Checking property XMLParser::' . $name . ' is deprecated'); | |
| 1093 | +                $this->logDeprecation('Checking property XMLParser::'.$name.' is deprecated'); | |
| 1094 | 1094 | return isset($this->current_parsing_options['accept']); | 
| 1095 | 1095 | case '_xh': | 
| 1096 | 1096 | case 'xmlrpc_valid_parents': | 
| 1097 | -                $this->logDeprecation('Checking property XMLParser::' . $name . ' is deprecated'); | |
| 1097 | +                $this->logDeprecation('Checking property XMLParser::'.$name.' is deprecated'); | |
| 1098 | 1098 | return isset($this->$name); | 
| 1099 | 1099 | default: | 
| 1100 | 1100 | return false; | 
| @@ -1106,18 +1106,18 @@ discard block | ||
| 1106 | 1106 |          switch ($name) { | 
| 1107 | 1107 | // q: does this make sense at all? | 
| 1108 | 1108 | case 'accept': | 
| 1109 | -                $this->logDeprecation('Unsetting property XMLParser::' . $name . ' is deprecated'); | |
| 1109 | +                $this->logDeprecation('Unsetting property XMLParser::'.$name.' is deprecated'); | |
| 1110 | 1110 | unset($this->current_parsing_options['accept']); | 
| 1111 | 1111 | break; | 
| 1112 | 1112 | case '_xh': | 
| 1113 | 1113 | case 'xmlrpc_valid_parents': | 
| 1114 | -                $this->logDeprecation('Unsetting property XMLParser::' . $name . ' is deprecated'); | |
| 1114 | +                $this->logDeprecation('Unsetting property XMLParser::'.$name.' is deprecated'); | |
| 1115 | 1115 | unset($this->$name); | 
| 1116 | 1116 | break; | 
| 1117 | 1117 | default: | 
| 1118 | 1118 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 1119 | 1119 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 1120 | -                trigger_error('Undefined property via __unset(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 1120 | +                trigger_error('Undefined property via __unset(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 1121 | 1121 | } | 
| 1122 | 1122 | } | 
| 1123 | 1123 | } | 
| @@ -43,7 +43,7 @@ discard block | ||
| 43 | 43 | $headers['Authorization'] = $_SERVER['REDIRECT_HTTP_AUTHORIZATION']; | 
| 44 | 44 |              } elseif (isset($_SERVER['PHP_AUTH_USER'])) { | 
| 45 | 45 | $basic_pass = isset($_SERVER['PHP_AUTH_PW']) ? $_SERVER['PHP_AUTH_PW'] : ''; | 
| 46 | - $headers['Authorization'] = 'Basic ' . base64_encode($_SERVER['PHP_AUTH_USER'] . ':' . $basic_pass); | |
| 46 | + $headers['Authorization'] = 'Basic '.base64_encode($_SERVER['PHP_AUTH_USER'].':'.$basic_pass); | |
| 47 | 47 |              } elseif (isset($_SERVER['PHP_AUTH_DIGEST'])) { | 
| 48 | 48 | $headers['Authorization'] = $_SERVER['PHP_AUTH_DIGEST']; | 
| 49 | 49 | } | 
| @@ -62,12 +62,12 @@ discard block | ||
| 62 | 62 |      foreach ($cookies as $name => $cookieDesc) { | 
| 63 | 63 |          if (is_array($cookieDesc)) { | 
| 64 | 64 | setcookie($name, | 
| 65 | - isset($cookieDesc['value']) ? (string)$cookieDesc['value'] : '', | |
| 65 | + isset($cookieDesc['value']) ? (string) $cookieDesc['value'] : '', | |
| 66 | 66 | isset($cookieDesc['expires']) ? $cookieDesc['expires'] : 0, | 
| 67 | - isset($cookieDesc['path']) ? (string)$cookieDesc['path'] : '', | |
| 68 | - isset($cookieDesc['domain']) ? (string)$cookieDesc['domain'] : '', | |
| 69 | - isset($cookieDesc['secure']) ? (bool)$cookieDesc['secure'] : false, | |
| 70 | - isset($cookieDesc['httponly']) ? (bool)$cookieDesc['httponly'] : false | |
| 67 | + isset($cookieDesc['path']) ? (string) $cookieDesc['path'] : '', | |
| 68 | + isset($cookieDesc['domain']) ? (string) $cookieDesc['domain'] : '', | |
| 69 | + isset($cookieDesc['secure']) ? (bool) $cookieDesc['secure'] : false, | |
| 70 | + isset($cookieDesc['httponly']) ? (bool) $cookieDesc['httponly'] : false | |
| 71 | 71 | ); | 
| 72 | 72 |          } else { | 
| 73 | 73 | /// @todo what to do? | 
| @@ -104,7 +104,7 @@ discard block | ||
| 104 | 104 | $sleep_sig = array(array(Value::$xmlrpcInt, Value::$xmlrpcInt)); | 
| 105 | 105 | $sleep_doc = 'Sleeps for the requested number of seconds (between 1 and 60), before sending back the response'; | 
| 106 | 106 |  function sleepSeconds($secs) { | 
| 107 | -    if ($secs > 0 && $secs < 61) { | |
| 107 | +    if ($secs>0 && $secs<61) { | |
| 108 | 108 | sleep($secs); | 
| 109 | 109 | } | 
| 110 | 110 | return $secs; | 
| @@ -137,7 +137,7 @@ discard block | ||
| 137 | 137 | |
| 138 | 138 | // Greek word 'kosme'. NB: NOT a valid ISO8859 string! | 
| 139 | 139 | // NB: we can only register this when setting internal encoding to UTF-8, or it will break system.listMethods | 
| 140 | - "tests.utf8methodname." . 'κόσμε' => array( | |
| 140 | + "tests.utf8methodname.".'κόσμε' => array( | |
| 141 | 141 | "function" => "exampleMethods::stringEcho", | 
| 142 | 142 | "signature" => exampleMethods::$stringecho_sig, | 
| 143 | 143 | "docstring" => exampleMethods::$stringecho_doc, | 
| @@ -1,6 +1,6 @@ discard block | ||
| 1 | 1 | <?php | 
| 2 | 2 | |
| 3 | -include_once __DIR__ . '/ServerAwareTestCase.php'; | |
| 3 | +include_once __DIR__.'/ServerAwareTestCase.php'; | |
| 4 | 4 | |
| 5 | 5 | abstract class PhpXmlRpc_WebTestCase extends PhpXmlRpc_ServerAwareTestCase | 
| 6 | 6 |  { | 
| @@ -15,7 +15,7 @@ discard block | ||
| 15 | 15 | */ | 
| 16 | 16 | protected function request($path, $method = 'GET', $payload = '', $emptyPageOk = false) | 
| 17 | 17 |      { | 
| 18 | - $url = $this->baseUrl . $path; | |
| 18 | + $url = $this->baseUrl.$path; | |
| 19 | 19 | |
| 20 | 20 | $ch = curl_init($url); | 
| 21 | 21 | curl_setopt_array($ch, array( | 
| @@ -29,21 +29,21 @@ discard block | ||
| 29 | 29 | CURLOPT_POSTFIELDS => $payload | 
| 30 | 30 | )); | 
| 31 | 31 | } | 
| 32 | - $cookie = 'PHPUNIT_RANDOM_TEST_ID=' . static::$randId; | |
| 32 | + $cookie = 'PHPUNIT_RANDOM_TEST_ID='.static::$randId; | |
| 33 | 33 | if ($this->collectCodeCoverageInformation) | 
| 34 | 34 |          { | 
| 35 | - $cookie .= '; PHPUNIT_SELENIUM_TEST_ID=' . $this->testId; | |
| 35 | + $cookie .= '; PHPUNIT_SELENIUM_TEST_ID='.$this->testId; | |
| 36 | 36 | } | 
| 37 | 37 | curl_setopt($ch, CURLOPT_COOKIE, $cookie); | 
| 38 | 38 | |
| 39 | -        if ($this->args['DEBUG'] > 0) { | |
| 39 | +        if ($this->args['DEBUG']>0) { | |
| 40 | 40 | curl_setopt($ch, CURLOPT_VERBOSE, 1); | 
| 41 | 41 | } | 
| 42 | 42 | $page = curl_exec($ch); | 
| 43 | 43 | $info = curl_getinfo($ch); | 
| 44 | - if (PHP_MAJOR_VERSION < 8) curl_close($ch); | |
| 44 | + if (PHP_MAJOR_VERSION<8) curl_close($ch); | |
| 45 | 45 | |
| 46 | - $this->assertNotFalse($page, 'Curl request should not fail. Url: ' . @$info['url'] . ', Http code: ' . @$info['http_code']); | |
| 46 | + $this->assertNotFalse($page, 'Curl request should not fail. Url: '.@$info['url'].', Http code: '.@$info['http_code']); | |
| 47 | 47 |          if (!$emptyPageOk) { | 
| 48 | 48 |              $this->assertNotEquals('', $page, 'Retrieved web page should not be empty'); | 
| 49 | 49 | } | 
| @@ -62,7 +62,7 @@ discard block | ||
| 62 | 62 | */ | 
| 63 | 63 | protected function newClient($path) | 
| 64 | 64 |      { | 
| 65 | - $client = new \PhpXmlRpc\Client($this->baseUrl . $path); | |
| 65 | + $client = new \PhpXmlRpc\Client($this->baseUrl.$path); | |
| 66 | 66 |          $client->setCookie('PHPUNIT_RANDOM_TEST_ID', static::$randId); | 
| 67 | 67 |          if ($this->collectCodeCoverageInformation) { | 
| 68 | 68 |              $client->setCookie('PHPUNIT_SELENIUM_TEST_ID', $this->testId); | 
| @@ -251,7 +251,7 @@ discard block | ||
| 251 | 251 | public function getOptions() | 
| 252 | 252 |      { | 
| 253 | 253 | $values = array(); | 
| 254 | -        foreach(static::$options as $opt) { | |
| 254 | +        foreach (static::$options as $opt) { | |
| 255 | 255 | $values[$opt] = $this->getOption($opt); | 
| 256 | 256 | } | 
| 257 | 257 | return $values; | 
| @@ -264,7 +264,7 @@ discard block | ||
| 264 | 264 | */ | 
| 265 | 265 | public function setOptions($options) | 
| 266 | 266 |      { | 
| 267 | -        foreach($options as $name => $value) { | |
| 267 | +        foreach ($options as $name => $value) { | |
| 268 | 268 | $this->setOption($name, $value); | 
| 269 | 269 | } | 
| 270 | 270 | |
| @@ -302,7 +302,7 @@ discard block | ||
| 302 | 302 | */ | 
| 303 | 303 | public static function xmlrpc_debugmsg($msg) | 
| 304 | 304 |      { | 
| 305 | - static::$_xmlrpc_debuginfo .= $msg . "\n"; | |
| 305 | + static::$_xmlrpc_debuginfo .= $msg."\n"; | |
| 306 | 306 | } | 
| 307 | 307 | |
| 308 | 308 | /** | 
| @@ -314,7 +314,7 @@ discard block | ||
| 314 | 314 | */ | 
| 315 | 315 | public static function error_occurred($msg) | 
| 316 | 316 |      { | 
| 317 | - static::$_xmlrpcs_occurred_errors .= $msg . "\n"; | |
| 317 | + static::$_xmlrpcs_occurred_errors .= $msg."\n"; | |
| 318 | 318 | } | 
| 319 | 319 | |
| 320 | 320 | /** | 
| @@ -335,10 +335,10 @@ discard block | ||
| 335 | 335 | // user debug info should be encoded by the end user using the INTERNAL_ENCODING | 
| 336 | 336 | $out = ''; | 
| 337 | 337 |          if ($this->debug_info != '') { | 
| 338 | - $out .= "<!-- SERVER DEBUG INFO (BASE64 ENCODED):\n" . base64_encode($this->debug_info) . "\n-->\n"; | |
| 338 | + $out .= "<!-- SERVER DEBUG INFO (BASE64 ENCODED):\n".base64_encode($this->debug_info)."\n-->\n"; | |
| 339 | 339 | } | 
| 340 | 340 |          if (static::$_xmlrpc_debuginfo != '') { | 
| 341 | -            $out .= "<!-- DEBUG INFO:\n" . $this->getCharsetEncoder()->encodeEntities(str_replace('--', '_-', static::$_xmlrpc_debuginfo), PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding) . "\n-->\n"; | |
| 341 | +            $out .= "<!-- DEBUG INFO:\n".$this->getCharsetEncoder()->encodeEntities(str_replace('--', '_-', static::$_xmlrpc_debuginfo), PhpXmlRpc::$xmlrpc_internalencoding, $charsetEncoding)."\n-->\n"; | |
| 342 | 342 | // NB: a better solution MIGHT be to use CDATA, but we need to insert it | 
| 343 | 343 | // into return payload AFTER the beginning tag | 
| 344 | 344 |              //$out .= "<![CDATA[ DEBUG INFO:\n\n" . str_replace(']]>', ']_]_>', static::$_xmlrpc_debuginfo) . "\n]]>\n"; | 
| @@ -367,8 +367,8 @@ discard block | ||
| 367 | 367 | $this->debug_info = ''; | 
| 368 | 368 | |
| 369 | 369 | // Save what we received, before parsing it | 
| 370 | -        if ($this->debug > 1) { | |
| 371 | -            $this->debugMsg("+++GOT+++\n" . $data . "\n+++END+++"); | |
| 370 | +        if ($this->debug>1) { | |
| 371 | +            $this->debugMsg("+++GOT+++\n".$data."\n+++END+++"); | |
| 372 | 372 | } | 
| 373 | 373 | |
| 374 | 374 | $resp = $this->parseRequestHeaders($data, $reqCharset, $respCharset, $respEncoding); | 
| @@ -385,13 +385,13 @@ discard block | ||
| 385 | 385 | $resp->raw_data = $rawData; | 
| 386 | 386 | } | 
| 387 | 387 | |
| 388 | -        if ($this->debug > 2 && static::$_xmlrpcs_occurred_errors != '') { | |
| 389 | -            $this->debugMsg("+++PROCESSING ERRORS AND WARNINGS+++\n" . | |
| 390 | - static::$_xmlrpcs_occurred_errors . "+++END+++"); | |
| 388 | +        if ($this->debug>2 && static::$_xmlrpcs_occurred_errors != '') { | |
| 389 | +            $this->debugMsg("+++PROCESSING ERRORS AND WARNINGS+++\n". | |
| 390 | + static::$_xmlrpcs_occurred_errors."+++END+++"); | |
| 391 | 391 | } | 
| 392 | 392 | |
| 393 | 393 | $header = $resp->xml_header($respCharset); | 
| 394 | -        if ($this->debug > 0) { | |
| 394 | +        if ($this->debug>0) { | |
| 395 | 395 | $header .= $this->serializeDebug($respCharset); | 
| 396 | 396 | } | 
| 397 | 397 | |
| @@ -402,7 +402,7 @@ discard block | ||
| 402 | 402 |          if (empty($payload)) { | 
| 403 | 403 | $payload = $resp->serialize($respCharset); | 
| 404 | 404 | } | 
| 405 | - $payload = $header . $payload; | |
| 405 | + $payload = $header.$payload; | |
| 406 | 406 | |
| 407 | 407 |          if ($returnPayload) { | 
| 408 | 408 | return $payload; | 
| @@ -411,7 +411,7 @@ discard block | ||
| 411 | 411 | // if we get a warning/error that has output some text before here, then we cannot | 
| 412 | 412 | // add a new header. We cannot say we are sending xml, either... | 
| 413 | 413 |          if (!headers_sent()) { | 
| 414 | -            header('Content-Type: ' . $resp->getContentType()); | |
| 414 | +            header('Content-Type: '.$resp->getContentType()); | |
| 415 | 415 | // we do not know if client actually told us an accepted charset, but if it did we have to tell it what we did | 
| 416 | 416 |              header("Vary: Accept-Charset"); | 
| 417 | 417 | |
| @@ -434,12 +434,12 @@ discard block | ||
| 434 | 434 | // Note that Apache/mod_php will add (and even alter!) the Content-Length header on its own, but only for | 
| 435 | 435 | // responses up to 8000 bytes | 
| 436 | 436 |              if ($phpNoSelfCompress) { | 
| 437 | -                header('Content-Length: ' . (int)strlen($payload)); | |
| 437 | +                header('Content-Length: '.(int) strlen($payload)); | |
| 438 | 438 | } | 
| 439 | 439 |          } else { | 
| 440 | 440 | /// @todo allow the user to easily subclass this in a way which allows the resp. headers to be already sent | 
| 441 | 441 | /// by now without flagging it as an error. Possibly check for presence of Content-Type header | 
| 442 | -            $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': http headers already sent before response is fully generated. Check for php warning or error messages'); | |
| 442 | +            $this->getLogger()->error('XML-RPC: '.__METHOD__.': http headers already sent before response is fully generated. Check for php warning or error messages'); | |
| 443 | 443 | } | 
| 444 | 444 | |
| 445 | 445 | print $payload; | 
| @@ -528,9 +528,9 @@ discard block | ||
| 528 | 528 | $numParams = count($in); | 
| 529 | 529 | } | 
| 530 | 530 |          foreach ($sigs as $curSig) { | 
| 531 | -            if (count($curSig) == $numParams + 1) { | |
| 531 | +            if (count($curSig) == $numParams+1) { | |
| 532 | 532 | $itsOK = 1; | 
| 533 | -                for ($n = 0; $n < $numParams; $n++) { | |
| 533 | +                for ($n = 0; $n<$numParams; $n++) { | |
| 534 | 534 |                      if (is_object($in)) { | 
| 535 | 535 | $p = $in->getParam($n); | 
| 536 | 536 |                          if ($p->kindOf() == 'scalar') { | 
| @@ -543,10 +543,10 @@ discard block | ||
| 543 | 543 | } | 
| 544 | 544 | |
| 545 | 545 | // param index is $n+1, as first member of sig is return type | 
| 546 | -                    if ($pt != $curSig[$n + 1] && $curSig[$n + 1] != Value::$xmlrpcValue) { | |
| 546 | +                    if ($pt != $curSig[$n+1] && $curSig[$n+1] != Value::$xmlrpcValue) { | |
| 547 | 547 | $itsOK = 0; | 
| 548 | - $pno = $n + 1; | |
| 549 | - $wanted = $curSig[$n + 1]; | |
| 548 | + $pno = $n+1; | |
| 549 | + $wanted = $curSig[$n+1]; | |
| 550 | 550 | $got = $pt; | 
| 551 | 551 | break; | 
| 552 | 552 | } | 
| @@ -573,10 +573,10 @@ discard block | ||
| 573 | 573 | // check if $_SERVER is populated: it might have been disabled via ini file | 
| 574 | 574 | // (this is true even when in CLI mode) | 
| 575 | 575 |          if (count($_SERVER) == 0) { | 
| 576 | -            $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': cannot parse request headers as $_SERVER is not populated'); | |
| 576 | +            $this->getLogger()->error('XML-RPC: '.__METHOD__.': cannot parse request headers as $_SERVER is not populated'); | |
| 577 | 577 | } | 
| 578 | 578 | |
| 579 | -        if ($this->debug > 1) { | |
| 579 | +        if ($this->debug>1) { | |
| 580 | 580 |              if (function_exists('getallheaders')) { | 
| 581 | 581 |                  $this->debugMsg(''); // empty line | 
| 582 | 582 |                  foreach (getallheaders() as $name => $val) { | 
| @@ -601,13 +601,13 @@ discard block | ||
| 601 | 601 |                  if (function_exists('gzinflate') && in_array($contentEncoding, $this->accepted_compression)) { | 
| 602 | 602 |                      if ($contentEncoding == 'deflate' && $degzdata = @gzuncompress($data)) { | 
| 603 | 603 | $data = $degzdata; | 
| 604 | -                        if ($this->debug > 1) { | |
| 605 | -                            $this->debugMsg("\n+++INFLATED REQUEST+++[" . strlen($data) . " chars]+++\n" . $data . "\n+++END+++"); | |
| 604 | +                        if ($this->debug>1) { | |
| 605 | +                            $this->debugMsg("\n+++INFLATED REQUEST+++[".strlen($data)." chars]+++\n".$data."\n+++END+++"); | |
| 606 | 606 | } | 
| 607 | 607 |                      } elseif ($contentEncoding == 'gzip' && $degzdata = @gzinflate(substr($data, 10))) { | 
| 608 | 608 | $data = $degzdata; | 
| 609 | -                        if ($this->debug > 1) { | |
| 610 | -                            $this->debugMsg("+++INFLATED REQUEST+++[" . strlen($data) . " chars]+++\n" . $data . "\n+++END+++"); | |
| 609 | +                        if ($this->debug>1) { | |
| 610 | +                            $this->debugMsg("+++INFLATED REQUEST+++[".strlen($data)." chars]+++\n".$data."\n+++END+++"); | |
| 611 | 611 | } | 
| 612 | 612 |                      } else { | 
| 613 | 613 | $r = new static::$responseClass(0, PhpXmlRpc::$xmlrpcerr['server_decompress_fail'], | 
| @@ -695,7 +695,7 @@ discard block | ||
| 695 | 695 |                      if ($reqEncoding == 'ISO-8859-1') { | 
| 696 | 696 | $data = utf8_encode($data); | 
| 697 | 697 |                      } else { | 
| 698 | -                        $this->getLogger()->error('XML-RPC: ' . __METHOD__ . ': unsupported charset encoding of received request: ' . $reqEncoding); | |
| 698 | +                        $this->getLogger()->error('XML-RPC: '.__METHOD__.': unsupported charset encoding of received request: '.$reqEncoding); | |
| 699 | 699 | } | 
| 700 | 700 | } | 
| 701 | 701 | } | 
| @@ -729,7 +729,7 @@ discard block | ||
| 729 | 729 |              preg_match('/^XML error ([0-9]+)/', $_xh['isf_reason'], $matches); | 
| 730 | 730 | return new static::$responseClass( | 
| 731 | 731 | 0, | 
| 732 | - PhpXmlRpc::$xmlrpcerrxml + (int)$matches[1], | |
| 732 | + PhpXmlRpc::$xmlrpcerrxml+(int) $matches[1], | |
| 733 | 733 | $_xh['isf_reason']); | 
| 734 | 734 |          } elseif ($_xh['isf']) { | 
| 735 | 735 | /// @todo separate better the various cases, as we have done in Request::parseResponse: invalid xml-rpc vs. | 
| @@ -737,7 +737,7 @@ discard block | ||
| 737 | 737 | return new static::$responseClass( | 
| 738 | 738 | 0, | 
| 739 | 739 | PhpXmlRpc::$xmlrpcerr['invalid_request'], | 
| 740 | - PhpXmlRpc::$xmlrpcstr['invalid_request'] . ' ' . $_xh['isf_reason']); | |
| 740 | + PhpXmlRpc::$xmlrpcstr['invalid_request'].' '.$_xh['isf_reason']); | |
| 741 | 741 |          } else { | 
| 742 | 742 | // small layering violation in favor of speed and memory usage: we should allow the 'execute' method handle | 
| 743 | 743 | // this, but in the most common scenario (xml-rpc values type server with some methods registered as phpvals) | 
| @@ -747,8 +747,8 @@ discard block | ||
| 747 | 747 | ($this->dmap[$_xh['method']]['parameters_type'] != 'xmlrpcvals') | 
| 748 | 748 | ) | 
| 749 | 749 |              ) { | 
| 750 | -                if ($this->debug > 1) { | |
| 751 | -                    $this->debugMsg("\n+++PARSED+++\n" . var_export($_xh['params'], true) . "\n+++END+++"); | |
| 750 | +                if ($this->debug>1) { | |
| 751 | +                    $this->debugMsg("\n+++PARSED+++\n".var_export($_xh['params'], true)."\n+++END+++"); | |
| 752 | 752 | } | 
| 753 | 753 | |
| 754 | 754 | return $this->execute($_xh['method'], $_xh['params'], $_xh['pt']); | 
| @@ -756,12 +756,12 @@ discard block | ||
| 756 | 756 | // build a Request object with data parsed from xml and add parameters in | 
| 757 | 757 | $req = new Request($_xh['method']); | 
| 758 | 758 | /// @todo for more speed, we could just pass in the array to the constructor (and loose the type validation)... | 
| 759 | -                for ($i = 0; $i < count($_xh['params']); $i++) { | |
| 759 | +                for ($i = 0; $i<count($_xh['params']); $i++) { | |
| 760 | 760 | $req->addParam($_xh['params'][$i]); | 
| 761 | 761 | } | 
| 762 | 762 | |
| 763 | -                if ($this->debug > 1) { | |
| 764 | -                    $this->debugMsg("\n+++PARSED+++\n" . var_export($req, true) . "\n+++END+++"); | |
| 763 | +                if ($this->debug>1) { | |
| 764 | +                    $this->debugMsg("\n+++PARSED+++\n".var_export($req, true)."\n+++END+++"); | |
| 765 | 765 | } | 
| 766 | 766 | |
| 767 | 767 | return $this->execute($req); | 
| @@ -811,7 +811,7 @@ discard block | ||
| 811 | 811 | return new static::$responseClass( | 
| 812 | 812 | 0, | 
| 813 | 813 | PhpXmlRpc::$xmlrpcerr['incorrect_params'], | 
| 814 | -                    PhpXmlRpc::$xmlrpcstr['incorrect_params'] . ": {$errStr}" | |
| 814 | +                    PhpXmlRpc::$xmlrpcstr['incorrect_params'].": {$errStr}" | |
| 815 | 815 | ); | 
| 816 | 816 | } | 
| 817 | 817 | } | 
| @@ -826,7 +826,7 @@ discard block | ||
| 826 | 826 | // build string representation of function 'name' | 
| 827 | 827 |          if (is_array($func)) { | 
| 828 | 828 |              if (is_object($func[0])) { | 
| 829 | - $funcName = get_class($func[0]) . '->' . $func[1]; | |
| 829 | + $funcName = get_class($func[0]).'->'.$func[1]; | |
| 830 | 830 |              } else { | 
| 831 | 831 |                  $funcName = implode('::', $func); | 
| 832 | 832 | } | 
| @@ -838,16 +838,16 @@ discard block | ||
| 838 | 838 | |
| 839 | 839 | // verify that function to be invoked is in fact callable | 
| 840 | 840 |          if (!is_callable($func)) { | 
| 841 | -            $this->getLogger()->error("XML-RPC: " . __METHOD__ . ": function '$funcName' registered as method handler is not callable"); | |
| 841 | +            $this->getLogger()->error("XML-RPC: ".__METHOD__.": function '$funcName' registered as method handler is not callable"); | |
| 842 | 842 | return new static::$responseClass( | 
| 843 | 843 | 0, | 
| 844 | 844 | PhpXmlRpc::$xmlrpcerr['server_error'], | 
| 845 | - PhpXmlRpc::$xmlrpcstr['server_error'] . ": no function matches method" | |
| 845 | + PhpXmlRpc::$xmlrpcstr['server_error'].": no function matches method" | |
| 846 | 846 | ); | 
| 847 | 847 | } | 
| 848 | 848 | |
| 849 | 849 |          if (isset($dmap[$methodName]['exception_handling'])) { | 
| 850 | - $exception_handling = (int)$dmap[$methodName]['exception_handling']; | |
| 850 | + $exception_handling = (int) $dmap[$methodName]['exception_handling']; | |
| 851 | 851 |          } else { | 
| 852 | 852 | $exception_handling = $this->exception_handling; | 
| 853 | 853 | } | 
| @@ -868,14 +868,14 @@ discard block | ||
| 868 | 868 | $r = call_user_func($func, $req); | 
| 869 | 869 | } | 
| 870 | 870 |                  if (!is_a($r, 'PhpXmlRpc\Response')) { | 
| 871 | -                    $this->getLogger()->error("XML-RPC: " . __METHOD__ . ": function '$funcName' registered as method handler does not return an xmlrpc response object but a " . gettype($r)); | |
| 871 | +                    $this->getLogger()->error("XML-RPC: ".__METHOD__.": function '$funcName' registered as method handler does not return an xmlrpc response object but a ".gettype($r)); | |
| 872 | 872 |                      if (is_a($r, 'PhpXmlRpc\Value')) { | 
| 873 | 873 | $r = new static::$responseClass($r); | 
| 874 | 874 |                      } else { | 
| 875 | 875 | $r = new static::$responseClass( | 
| 876 | 876 | 0, | 
| 877 | 877 | PhpXmlRpc::$xmlrpcerr['server_error'], | 
| 878 | - PhpXmlRpc::$xmlrpcstr['server_error'] . ": function does not return xmlrpc response object" | |
| 878 | + PhpXmlRpc::$xmlrpcstr['server_error'].": function does not return xmlrpc response object" | |
| 879 | 879 | ); | 
| 880 | 880 | } | 
| 881 | 881 | } | 
| @@ -890,7 +890,7 @@ discard block | ||
| 890 | 890 | $r = call_user_func_array($func, array($methodName, $params, $this->user_data)); | 
| 891 | 891 | // mimic EPI behaviour: if we get an array that looks like an error, make it an error response | 
| 892 | 892 |                          if (is_array($r) && array_key_exists('faultCode', $r) && array_key_exists('faultString', $r)) { | 
| 893 | - $r = new static::$responseClass(0, (int)$r['faultCode'], (string)$r['faultString']); | |
| 893 | + $r = new static::$responseClass(0, (int) $r['faultCode'], (string) $r['faultString']); | |
| 894 | 894 |                          } else { | 
| 895 | 895 | // functions using EPI api should NOT return resp objects, so make sure we encode the | 
| 896 | 896 | // return type correctly | 
| @@ -1021,7 +1021,7 @@ discard block | ||
| 1021 | 1021 | */ | 
| 1022 | 1022 | protected function debugMsg($string) | 
| 1023 | 1023 |      { | 
| 1024 | - $this->debug_info .= $string . "\n"; | |
| 1024 | + $this->debug_info .= $string."\n"; | |
| 1025 | 1025 | } | 
| 1026 | 1026 | |
| 1027 | 1027 | /** | 
| @@ -1313,7 +1313,7 @@ discard block | ||
| 1313 | 1313 | $i++; // for error message, we count params from 1 | 
| 1314 | 1314 | return static::_xmlrpcs_multicall_error(new static::$responseClass(0, | 
| 1315 | 1315 | PhpXmlRpc::$xmlrpcerr['incorrect_params'], | 
| 1316 | - PhpXmlRpc::$xmlrpcstr['incorrect_params'] . ": probable xml error in param " . $i)); | |
| 1316 | + PhpXmlRpc::$xmlrpcstr['incorrect_params'].": probable xml error in param ".$i)); | |
| 1317 | 1317 | } | 
| 1318 | 1318 | } | 
| 1319 | 1319 | |
| @@ -1394,7 +1394,7 @@ discard block | ||
| 1394 | 1394 | } | 
| 1395 | 1395 |          } else { | 
| 1396 | 1396 | $numCalls = count($req); | 
| 1397 | -            for ($i = 0; $i < $numCalls; $i++) { | |
| 1397 | +            for ($i = 0; $i<$numCalls; $i++) { | |
| 1398 | 1398 | $result[$i] = static::_xmlrpcs_multicall_do_call_phpvals($server, $req[$i]); | 
| 1399 | 1399 | } | 
| 1400 | 1400 | } | 
| @@ -1422,7 +1422,7 @@ discard block | ||
| 1422 | 1422 | // From PHP 8.4 the E_STRICT constant has been deprecated and will emit deprecation notices. | 
| 1423 | 1423 | // PHP core and core extensions since PHP 8.0 and later do not emit E_STRICT notices at all. | 
| 1424 | 1424 | // On PHP 7 series before PHP 7.4, some functions conditionally emit E_STRICT notices. | 
| 1425 | -        if (PHP_VERSION_ID >= 70400) { | |
| 1425 | +        if (PHP_VERSION_ID>=70400) { | |
| 1426 | 1426 | static::error_occurred($errString); | 
| 1427 | 1427 |          } elseif ($errCode != E_STRICT) { | 
| 1428 | 1428 | static::error_occurred($errString); | 
| @@ -1463,12 +1463,12 @@ discard block | ||
| 1463 | 1463 | */ | 
| 1464 | 1464 | protected function xml_header($charsetEncoding = '') | 
| 1465 | 1465 |      { | 
| 1466 | -        $this->logDeprecation('Method ' . __METHOD__ . ' is deprecated'); | |
| 1466 | +        $this->logDeprecation('Method '.__METHOD__.' is deprecated'); | |
| 1467 | 1467 | |
| 1468 | 1468 |          if ($charsetEncoding != '') { | 
| 1469 | - return "<?xml version=\"1.0\" encoding=\"$charsetEncoding\"?" . ">\n"; | |
| 1469 | + return "<?xml version=\"1.0\" encoding=\"$charsetEncoding\"?".">\n"; | |
| 1470 | 1470 |          } else { | 
| 1471 | - return "<?xml version=\"1.0\"?" . ">\n"; | |
| 1471 | + return "<?xml version=\"1.0\"?".">\n"; | |
| 1472 | 1472 | } | 
| 1473 | 1473 | } | 
| 1474 | 1474 | |
| @@ -1484,7 +1484,7 @@ discard block | ||
| 1484 | 1484 | case self::OPT_FUNCTIONS_PARAMETERS_TYPE: | 
| 1485 | 1485 | case self::OPT_PHPVALS_ENCODING_OPTIONS: | 
| 1486 | 1486 | case self::OPT_RESPONSE_CHARSET_ENCODING: | 
| 1487 | -                $this->logDeprecation('Getting property Request::' . $name . ' is deprecated'); | |
| 1487 | +                $this->logDeprecation('Getting property Request::'.$name.' is deprecated'); | |
| 1488 | 1488 | return $this->$name; | 
| 1489 | 1489 | case 'accepted_charset_encodings': | 
| 1490 | 1490 | // manually implement the 'protected property' behaviour | 
| @@ -1496,16 +1496,16 @@ discard block | ||
| 1496 | 1496 | } | 
| 1497 | 1497 | } | 
| 1498 | 1498 |                  if ($canAccess) { | 
| 1499 | -                    $this->logDeprecation('Getting property Request::' . $name . ' is deprecated'); | |
| 1499 | +                    $this->logDeprecation('Getting property Request::'.$name.' is deprecated'); | |
| 1500 | 1500 | return $this->accepted_compression; | 
| 1501 | 1501 |                  } else { | 
| 1502 | -                    trigger_error("Cannot access protected property Server::accepted_charset_encodings in " . __FILE__, E_USER_ERROR); | |
| 1502 | +                    trigger_error("Cannot access protected property Server::accepted_charset_encodings in ".__FILE__, E_USER_ERROR); | |
| 1503 | 1503 | } | 
| 1504 | 1504 | break; | 
| 1505 | 1505 | default: | 
| 1506 | 1506 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 1507 | 1507 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 1508 | -                trigger_error('Undefined property via __get(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 1508 | +                trigger_error('Undefined property via __get(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 1509 | 1509 | $result = null; | 
| 1510 | 1510 | return $result; | 
| 1511 | 1511 | } | 
| @@ -1522,7 +1522,7 @@ discard block | ||
| 1522 | 1522 | case self::OPT_FUNCTIONS_PARAMETERS_TYPE: | 
| 1523 | 1523 | case self::OPT_PHPVALS_ENCODING_OPTIONS: | 
| 1524 | 1524 | case self::OPT_RESPONSE_CHARSET_ENCODING: | 
| 1525 | -                $this->logDeprecation('Setting property Request::' . $name . ' is deprecated'); | |
| 1525 | +                $this->logDeprecation('Setting property Request::'.$name.' is deprecated'); | |
| 1526 | 1526 | $this->$name = $value; | 
| 1527 | 1527 | break; | 
| 1528 | 1528 | case 'accepted_charset_encodings': | 
| @@ -1535,16 +1535,16 @@ discard block | ||
| 1535 | 1535 | } | 
| 1536 | 1536 | } | 
| 1537 | 1537 |                  if ($canAccess) { | 
| 1538 | -                    $this->logDeprecation('Setting property Request::' . $name . ' is deprecated'); | |
| 1538 | +                    $this->logDeprecation('Setting property Request::'.$name.' is deprecated'); | |
| 1539 | 1539 | $this->accepted_compression = $value; | 
| 1540 | 1540 |                  } else { | 
| 1541 | -                    trigger_error("Cannot access protected property Server::accepted_charset_encodings in " . __FILE__, E_USER_ERROR); | |
| 1541 | +                    trigger_error("Cannot access protected property Server::accepted_charset_encodings in ".__FILE__, E_USER_ERROR); | |
| 1542 | 1542 | } | 
| 1543 | 1543 | break; | 
| 1544 | 1544 | default: | 
| 1545 | 1545 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 1546 | 1546 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 1547 | -                trigger_error('Undefined property via __set(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 1547 | +                trigger_error('Undefined property via __set(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 1548 | 1548 | } | 
| 1549 | 1549 | } | 
| 1550 | 1550 | |
| @@ -1559,7 +1559,7 @@ discard block | ||
| 1559 | 1559 | case self::OPT_FUNCTIONS_PARAMETERS_TYPE: | 
| 1560 | 1560 | case self::OPT_PHPVALS_ENCODING_OPTIONS: | 
| 1561 | 1561 | case self::OPT_RESPONSE_CHARSET_ENCODING: | 
| 1562 | -                $this->logDeprecation('Checking property Request::' . $name . ' is deprecated'); | |
| 1562 | +                $this->logDeprecation('Checking property Request::'.$name.' is deprecated'); | |
| 1563 | 1563 | return isset($this->$name); | 
| 1564 | 1564 | case 'accepted_charset_encodings': | 
| 1565 | 1565 | // manually implement the 'protected property' behaviour | 
| @@ -1571,7 +1571,7 @@ discard block | ||
| 1571 | 1571 | } | 
| 1572 | 1572 | } | 
| 1573 | 1573 |                  if ($canAccess) { | 
| 1574 | -                    $this->logDeprecation('Checking property Request::' . $name . ' is deprecated'); | |
| 1574 | +                    $this->logDeprecation('Checking property Request::'.$name.' is deprecated'); | |
| 1575 | 1575 | return isset($this->accepted_compression); | 
| 1576 | 1576 | } | 
| 1577 | 1577 | // break through voluntarily | 
| @@ -1591,7 +1591,7 @@ discard block | ||
| 1591 | 1591 | case self::OPT_FUNCTIONS_PARAMETERS_TYPE: | 
| 1592 | 1592 | case self::OPT_PHPVALS_ENCODING_OPTIONS: | 
| 1593 | 1593 | case self::OPT_RESPONSE_CHARSET_ENCODING: | 
| 1594 | -                $this->logDeprecation('Unsetting property Request::' . $name . ' is deprecated'); | |
| 1594 | +                $this->logDeprecation('Unsetting property Request::'.$name.' is deprecated'); | |
| 1595 | 1595 | unset($this->$name); | 
| 1596 | 1596 | break; | 
| 1597 | 1597 | case 'accepted_charset_encodings': | 
| @@ -1604,16 +1604,16 @@ discard block | ||
| 1604 | 1604 | } | 
| 1605 | 1605 | } | 
| 1606 | 1606 |                  if ($canAccess) { | 
| 1607 | -                    $this->logDeprecation('Unsetting property Request::' . $name . ' is deprecated'); | |
| 1607 | +                    $this->logDeprecation('Unsetting property Request::'.$name.' is deprecated'); | |
| 1608 | 1608 | unset($this->accepted_compression); | 
| 1609 | 1609 |                  } else { | 
| 1610 | -                    trigger_error("Cannot access protected property Server::accepted_charset_encodings in " . __FILE__, E_USER_ERROR); | |
| 1610 | +                    trigger_error("Cannot access protected property Server::accepted_charset_encodings in ".__FILE__, E_USER_ERROR); | |
| 1611 | 1611 | } | 
| 1612 | 1612 | break; | 
| 1613 | 1613 | default: | 
| 1614 | 1614 | /// @todo throw instead? There are very few other places where the lib trigger errors which can potentially reach stdout... | 
| 1615 | 1615 | $trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1); | 
| 1616 | -                trigger_error('Undefined property via __unset(): ' . $name . ' in ' . $trace[0]['file'] . ' on line ' . $trace[0]['line'], E_USER_WARNING); | |
| 1616 | +                trigger_error('Undefined property via __unset(): '.$name.' in '.$trace[0]['file'].' on line '.$trace[0]['line'], E_USER_WARNING); | |
| 1617 | 1617 | } | 
| 1618 | 1618 | } | 
| 1619 | 1619 | } | 
| @@ -19,9 +19,9 @@ discard block | ||
| 19 | 19 | use PhpXmlRpc\Encoder; | 
| 20 | 20 | |
| 21 | 21 | /// @todo allow autoloading when the library is installed as dependency | 
| 22 | -include_once __DIR__ . '/../vendor/autoload.php'; | |
| 22 | +include_once __DIR__.'/../vendor/autoload.php'; | |
| 23 | 23 | |
| 24 | -include __DIR__ . '/../tests/parse_args.php'; | |
| 24 | +include __DIR__.'/../tests/parse_args.php'; | |
| 25 | 25 | $args = argParser::getArgs(); | 
| 26 | 26 | |
| 27 | 27 | function begin_test($test_name, $test_case) | 
| @@ -41,7 +41,7 @@ discard block | ||
| 41 | 41 |      if (!isset($test_results[$test_name][$test_case])) { | 
| 42 | 42 |          trigger_error('ending test that was not started'); | 
| 43 | 43 | } | 
| 44 | - $test_results[$test_name][$test_case]['time'] = $end - $test_results[$test_name][$test_case]['time']; | |
| 44 | + $test_results[$test_name][$test_case]['time'] = $end-$test_results[$test_name][$test_case]['time']; | |
| 45 | 45 | $test_results[$test_name][$test_case]['result'] = $test_result; | 
| 46 | 46 | echo '.'; | 
| 47 | 47 | flush(); | 
| @@ -75,24 +75,24 @@ discard block | ||
| 75 | 75 | } | 
| 76 | 76 | |
| 77 | 77 |  if ($is_web) { | 
| 78 | - echo "<h3>Using lib version: " . PhpXmlRpc::$xmlrpcVersion . " on PHP version: " . phpversion() . "</h3>\n"; | |
| 78 | + echo "<h3>Using lib version: ".PhpXmlRpc::$xmlrpcVersion." on PHP version: ".phpversion()."</h3>\n"; | |
| 79 | 79 |      if ($xd) { | 
| 80 | - echo "<h4>XDEBUG profiling enabled: skipping remote tests. Trace file is: " . htmlspecialchars(xdebug_get_profiler_filename()) . "</h4>\n"; | |
| 80 | + echo "<h4>XDEBUG profiling enabled: skipping remote tests. Trace file is: ".htmlspecialchars(xdebug_get_profiler_filename())."</h4>\n"; | |
| 81 | 81 | } | 
| 82 | 82 | flush(); | 
| 83 | 83 | ob_flush(); | 
| 84 | 84 |  } else { | 
| 85 | - echo "Using lib version: " . PhpXmlRpc::$xmlrpcVersion . " on PHP version: " . phpversion() . "\n"; | |
| 85 | + echo "Using lib version: ".PhpXmlRpc::$xmlrpcVersion." on PHP version: ".phpversion()."\n"; | |
| 86 | 86 |      if ($xd) { | 
| 87 | - echo "XDEBUG profiling enabled: skipping remote tests\nTrace file is: " . xdebug_get_profiler_filename() . "\n"; | |
| 87 | + echo "XDEBUG profiling enabled: skipping remote tests\nTrace file is: ".xdebug_get_profiler_filename()."\n"; | |
| 88 | 88 | } | 
| 89 | 89 | } | 
| 90 | 90 | |
| 91 | 91 | // test 'manual style' data encoding vs. 'automatic style' encoding | 
| 92 | 92 |  begin_test('Data encoding (large array)', 'manual encoding'); | 
| 93 | -for ($i = 0; $i < $num_tests; $i++) { | |
| 93 | +for ($i = 0; $i<$num_tests; $i++) { | |
| 94 | 94 | $vals = array(); | 
| 95 | -    for ($j = 0; $j < 10; $j++) { | |
| 95 | +    for ($j = 0; $j<10; $j++) { | |
| 96 | 96 | $valArray = array(); | 
| 97 | 97 |          foreach ($data[$j] as $key => $val) { | 
| 98 | 98 | $values = array(); | 
| @@ -117,7 +117,7 @@ discard block | ||
| 117 | 117 | |
| 118 | 118 |  begin_test('Data encoding (large array)', 'automatic encoding'); | 
| 119 | 119 | $encoder = new Encoder(); | 
| 120 | -for ($i = 0; $i < $num_tests; $i++) { | |
| 120 | +for ($i = 0; $i<$num_tests; $i++) { | |
| 121 | 121 |      $value = $encoder->encode($data, array('auto_dates')); | 
| 122 | 122 | $out = $value->serialize(); | 
| 123 | 123 | } | 
| @@ -125,8 +125,8 @@ discard block | ||
| 125 | 125 | |
| 126 | 126 |  if (function_exists('xmlrpc_set_type')) { | 
| 127 | 127 |      begin_test('Data encoding (large array)', 'xmlrpc-epi encoding'); | 
| 128 | -    for ($i = 0; $i < $num_tests; $i++) { | |
| 129 | -        for ($j = 0; $j < 10; $j++) { | |
| 128 | +    for ($i = 0; $i<$num_tests; $i++) { | |
| 129 | +        for ($j = 0; $j<10; $j++) { | |
| 130 | 130 |              foreach ($keys as $k) { | 
| 131 | 131 | xmlrpc_set_type($data[$j][$k][4], 'datetime'); | 
| 132 | 132 | xmlrpc_set_type($data[$j][$k][8], 'datetime'); | 
| @@ -140,18 +140,18 @@ discard block | ||
| 140 | 140 | // test 'old style' data decoding vs. 'automatic style' decoding | 
| 141 | 141 |  $dummy = new Request(''); | 
| 142 | 142 | $out = new Response($data); | 
| 143 | -$in = '<?xml version="1.0" ?>' . "\n" . $out->serialize(); | |
| 143 | +$in = '<?xml version="1.0" ?>'."\n".$out->serialize(); | |
| 144 | 144 | |
| 145 | 145 |  begin_test('Data decoding (large array)', 'manual decoding'); | 
| 146 | -for ($i = 0; $i < $num_tests; $i++) { | |
| 146 | +for ($i = 0; $i<$num_tests; $i++) { | |
| 147 | 147 | $response = $dummy->parseResponse($in, true); | 
| 148 | 148 | $value = $response->value(); | 
| 149 | 149 | $result = array(); | 
| 150 | -    foreach($value as $val1) { | |
| 150 | +    foreach ($value as $val1) { | |
| 151 | 151 | $out = array(); | 
| 152 | -        foreach($val1 as $name => $val) { | |
| 152 | +        foreach ($val1 as $name => $val) { | |
| 153 | 153 | $out[$name] = array(); | 
| 154 | -            foreach($val as $data) { | |
| 154 | +            foreach ($val as $data) { | |
| 155 | 155 | $out[$name][] = $data->scalarVal(); | 
| 156 | 156 | } | 
| 157 | 157 | } | 
| @@ -161,18 +161,18 @@ discard block | ||
| 161 | 161 |  end_test('Data decoding (large array)', 'manual decoding', $result); | 
| 162 | 162 | |
| 163 | 163 |  begin_test('Data decoding (large array)', 'manual decoding deprecated'); | 
| 164 | -for ($i = 0; $i < $num_tests; $i++) { | |
| 164 | +for ($i = 0; $i<$num_tests; $i++) { | |
| 165 | 165 | $response = $dummy->ParseResponse($in, true); | 
| 166 | 166 | $value = $response->value(); | 
| 167 | 167 | $result = array(); | 
| 168 | 168 | $l = $value->arraySize(); | 
| 169 | -    for ($k = 0; $k < $l; $k++) { | |
| 169 | +    for ($k = 0; $k<$l; $k++) { | |
| 170 | 170 | $val1 = $value->arrayMem($k); | 
| 171 | 171 | $out = array(); | 
| 172 | -        foreach($val1 as $name => $val) { | |
| 172 | +        foreach ($val1 as $name => $val) { | |
| 173 | 173 | $out[$name] = array(); | 
| 174 | 174 | $m = $val->arraySize(); | 
| 175 | -            for ($j = 0; $j < $m; $j++) { | |
| 175 | +            for ($j = 0; $j<$m; $j++) { | |
| 176 | 176 | $data = $val->arrayMem($j); | 
| 177 | 177 | $out[$name][] = $data->scalarVal(); | 
| 178 | 178 | } | 
| @@ -183,7 +183,7 @@ discard block | ||
| 183 | 183 |  end_test('Data decoding (large array)', 'manual decoding deprecated', $result); | 
| 184 | 184 | |
| 185 | 185 |  begin_test('Data decoding (large array)', 'automatic decoding'); | 
| 186 | -for ($i = 0; $i < $num_tests; $i++) { | |
| 186 | +for ($i = 0; $i<$num_tests; $i++) { | |
| 187 | 187 | $response = $dummy->parseResponse($in, true, 'phpvals'); | 
| 188 | 188 | $value = $response->value(); | 
| 189 | 189 | } | 
| @@ -191,7 +191,7 @@ discard block | ||
| 191 | 191 | |
| 192 | 192 |  if (function_exists('xmlrpc_decode')) { | 
| 193 | 193 |      begin_test('Data decoding (large array)', 'xmlrpc-epi decoding'); | 
| 194 | -    for ($i = 0; $i < $num_tests; $i++) { | |
| 194 | +    for ($i = 0; $i<$num_tests; $i++) { | |
| 195 | 195 | $response = $dummy->parseResponse($in, true, 'xml'); | 
| 196 | 196 | $value = xmlrpc_decode($response->value()); | 
| 197 | 197 | } | 
| @@ -208,16 +208,16 @@ discard block | ||
| 208 | 208 |      $value = $encoder->encode($data1, array('auto_dates')); | 
| 209 | 209 |      $req = new Request('interopEchoTests.echoValue', array($value)); | 
| 210 | 210 | $reqs = array(); | 
| 211 | -    for ($i = 0; $i < $num_tests; $i++) { | |
| 211 | +    for ($i = 0; $i<$num_tests; $i++) { | |
| 212 | 212 | $reqs[] = $req; | 
| 213 | 213 | } | 
| 214 | 214 | |
| 215 | 215 |      $server = explode(':', $args['HTTPSERVER']); | 
| 216 | -    if (count($server) > 1) { | |
| 217 | - $srv = 'http://' . $server[0] . '://' . $server[1] . $args['HTTPURI']; | |
| 216 | +    if (count($server)>1) { | |
| 217 | + $srv = 'http://'.$server[0].'://'.$server[1].$args['HTTPURI']; | |
| 218 | 218 | $c = new Client($args['HTTPURI'], $server[0], $server[1]); | 
| 219 | 219 |      } else { | 
| 220 | - $srv = 'http://' . $args['HTTPSERVER'] . $args['HTTPURI']; | |
| 220 | + $srv = 'http://'.$args['HTTPSERVER'].$args['HTTPURI']; | |
| 221 | 221 | $c = new Client($args['HTTPURI'], $args['HTTPSERVER']); | 
| 222 | 222 | } | 
| 223 | 223 | |
| @@ -229,7 +229,7 @@ discard block | ||
| 229 | 229 | |
| 230 | 230 | begin_test($testName, 'http 10'); | 
| 231 | 231 | $response = array(); | 
| 232 | -    for ($i = 0; $i < $num_tests; $i++) { | |
| 232 | +    for ($i = 0; $i<$num_tests; $i++) { | |
| 233 | 233 | $resp = $c->send($req); | 
| 234 | 234 | $response[] = $resp->value(); | 
| 235 | 235 | } | 
| @@ -239,7 +239,7 @@ discard block | ||
| 239 | 239 | $c->setOption(Client::OPT_KEEPALIVE, false); | 
| 240 | 240 | begin_test($testName, 'http 11 no keepalive'); | 
| 241 | 241 | $response = array(); | 
| 242 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 242 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 243 | 243 | $resp = $c->send($req, 10, 'http11'); | 
| 244 | 244 | $response[] = $resp->value(); | 
| 245 | 245 | } | 
| @@ -247,7 +247,7 @@ discard block | ||
| 247 | 247 | |
| 248 | 248 | begin_test($testName, 'http 11 w. keep-alive'); | 
| 249 | 249 | $response = array(); | 
| 250 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 250 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 251 | 251 | $resp = $c->send($req, 10, 'http11'); | 
| 252 | 252 | $response[] = $resp->value(); | 
| 253 | 253 | } | 
| @@ -269,7 +269,7 @@ discard block | ||
| 269 | 269 | |
| 270 | 270 | begin_test($testName, 'http 10 w. compression'); | 
| 271 | 271 | $response = array(); | 
| 272 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 272 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 273 | 273 | $resp = $c->send($req); | 
| 274 | 274 | $response[] = $resp->value(); | 
| 275 | 275 | } | 
| @@ -279,7 +279,7 @@ discard block | ||
| 279 | 279 | $c->setOption(Client::OPT_KEEPALIVE, false); | 
| 280 | 280 | begin_test($testName, 'http 11 w. compression and no keepalive'); | 
| 281 | 281 | $response = array(); | 
| 282 | -            for ($i = 0; $i < $num_tests; $i++) { | |
| 282 | +            for ($i = 0; $i<$num_tests; $i++) { | |
| 283 | 283 | $resp = $c->send($req, 10, 'http11'); | 
| 284 | 284 | $response[] = $resp->value(); | 
| 285 | 285 | } | 
| @@ -288,7 +288,7 @@ discard block | ||
| 288 | 288 | $c->setOption(Client::OPT_KEEPALIVE, true); | 
| 289 | 289 | begin_test($testName, 'http 11 w. keep-alive and compression'); | 
| 290 | 290 | $response = array(); | 
| 291 | -            for ($i = 0; $i < $num_tests; $i++) { | |
| 291 | +            for ($i = 0; $i<$num_tests; $i++) { | |
| 292 | 292 | $resp = $c->send($req, 10, 'http11'); | 
| 293 | 293 | $response[] = $resp->value(); | 
| 294 | 294 | } | 
| @@ -309,11 +309,11 @@ discard block | ||
| 309 | 309 | /// test multicall vs. many calls vs. keep-alives - HTTPS | 
| 310 | 310 | |
| 311 | 311 |          $server = explode(':', $args['HTTPSSERVER']); | 
| 312 | -        if (count($server) > 1) { | |
| 313 | - $srv = 'https://' . $server[0] . ':' . $server[1] . $args['HTTPSURI']; | |
| 312 | +        if (count($server)>1) { | |
| 313 | + $srv = 'https://'.$server[0].':'.$server[1].$args['HTTPSURI']; | |
| 314 | 314 | $c = new Client($args['HTTPSURI'], $server[0], $server[1], 'https'); | 
| 315 | 315 |          } else { | 
| 316 | - $srv = 'https://' . $args['HTTPSSERVER'] . $args['HTTPSURI']; | |
| 316 | + $srv = 'https://'.$args['HTTPSSERVER'].$args['HTTPSURI']; | |
| 317 | 317 | $c = new Client($args['HTTPSURI'], $args['HTTPSSERVER'], 443, 'https'); | 
| 318 | 318 | } | 
| 319 | 319 | $c->setOption(Client::OPT_VERIFY_PEER, !$args['HTTPSIGNOREPEER']); | 
| @@ -327,7 +327,7 @@ discard block | ||
| 327 | 327 | $c->setOption(Client::OPT_KEEPALIVE, false); | 
| 328 | 328 | begin_test($testName, 'https no keep-alive'); | 
| 329 | 329 | $response = array(); | 
| 330 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 330 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 331 | 331 | $resp = $c->send($req); | 
| 332 | 332 | $response[] = $resp->value(); | 
| 333 | 333 | } | 
| @@ -336,7 +336,7 @@ discard block | ||
| 336 | 336 | $c->setOption(Client::OPT_KEEPALIVE, true); | 
| 337 | 337 | begin_test($testName, 'https w. keep-alive'); | 
| 338 | 338 | $response = array(); | 
| 339 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 339 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 340 | 340 | $resp = $c->send($req, 10); | 
| 341 | 341 | $response[] = $resp->value(); | 
| 342 | 342 | } | 
| @@ -357,7 +357,7 @@ discard block | ||
| 357 | 357 | $c->setOption(Client::OPT_KEEPALIVE, false); | 
| 358 | 358 | begin_test($testName, 'https w. compression and no keepalive'); | 
| 359 | 359 | $response = array(); | 
| 360 | -            for ($i = 0; $i < $num_tests; $i++) { | |
| 360 | +            for ($i = 0; $i<$num_tests; $i++) { | |
| 361 | 361 | $resp = $c->send($req); | 
| 362 | 362 | $response[] = $resp->value(); | 
| 363 | 363 | } | 
| @@ -366,7 +366,7 @@ discard block | ||
| 366 | 366 | $c->setOption(Client::OPT_KEEPALIVE, true); | 
| 367 | 367 | begin_test($testName, 'https w. keep-alive and compression'); | 
| 368 | 368 | $response = array(); | 
| 369 | -            for ($i = 0; $i < $num_tests; $i++) { | |
| 369 | +            for ($i = 0; $i<$num_tests; $i++) { | |
| 370 | 370 | $resp = $c->send($req, 10); | 
| 371 | 371 | $response[] = $resp->value(); | 
| 372 | 372 | } | 
| @@ -387,11 +387,11 @@ discard block | ||
| 387 | 387 | /// test multicall vs. many calls vs. keep-alives - HTTP/2 | 
| 388 | 388 | |
| 389 | 389 |          $server = explode(':', $args['HTTPSSERVER']); | 
| 390 | -        if (count($server) > 1) { | |
| 391 | - $srv = 'https://' . $server[0] . ':' . $server[1] . $args['HTTPSURI']; | |
| 390 | +        if (count($server)>1) { | |
| 391 | + $srv = 'https://'.$server[0].':'.$server[1].$args['HTTPSURI']; | |
| 392 | 392 | $c = new Client($args['HTTPSURI'], $server[0], $server[1], 'https'); | 
| 393 | 393 |          } else { | 
| 394 | - $srv = 'https://' . $args['HTTPSSERVER'] . $args['HTTPSURI']; | |
| 394 | + $srv = 'https://'.$args['HTTPSSERVER'].$args['HTTPSURI']; | |
| 395 | 395 | $c = new Client($args['HTTPSURI'], $args['HTTPSSERVER'], 443, 'h2'); | 
| 396 | 396 | } | 
| 397 | 397 | $c->setOption(Client::OPT_VERIFY_PEER, !$args['HTTPSIGNOREPEER']); | 
| @@ -405,7 +405,7 @@ discard block | ||
| 405 | 405 | $c->setOption(Client::OPT_KEEPALIVE, false); | 
| 406 | 406 | begin_test($testName, 'http2 no keep-alive'); | 
| 407 | 407 | $response = array(); | 
| 408 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 408 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 409 | 409 | $resp = $c->send($req); | 
| 410 | 410 | $response[] = $resp->value(); | 
| 411 | 411 | } | 
| @@ -414,7 +414,7 @@ discard block | ||
| 414 | 414 | $c->setOption(Client::OPT_KEEPALIVE, true); | 
| 415 | 415 | begin_test($testName, 'http2 w. keep-alive'); | 
| 416 | 416 | $response = array(); | 
| 417 | -        for ($i = 0; $i < $num_tests; $i++) { | |
| 417 | +        for ($i = 0; $i<$num_tests; $i++) { | |
| 418 | 418 | $resp = $c->send($req, 10); | 
| 419 | 419 | $response[] = $resp->value(); | 
| 420 | 420 | } | 
| @@ -435,7 +435,7 @@ discard block | ||
| 435 | 435 | $c->setOption(Client::OPT_KEEPALIVE, false); | 
| 436 | 436 | begin_test($testName, 'http2 w. compression and no keepalive'); | 
| 437 | 437 | $response = array(); | 
| 438 | -            for ($i = 0; $i < $num_tests; $i++) { | |
| 438 | +            for ($i = 0; $i<$num_tests; $i++) { | |
| 439 | 439 | $resp = $c->send($req); | 
| 440 | 440 | $response[] = $resp->value(); | 
| 441 | 441 | } | 
| @@ -444,7 +444,7 @@ discard block | ||
| 444 | 444 | $c->setOption(Client::OPT_KEEPALIVE, true); | 
| 445 | 445 | begin_test($testName, 'http2 w. keep-alive and compression'); | 
| 446 | 446 | $response = array(); | 
| 447 | -            for ($i = 0; $i < $num_tests; $i++) { | |
| 447 | +            for ($i = 0; $i<$num_tests; $i++) { | |
| 448 | 448 | $resp = $c->send($req, 10); | 
| 449 | 449 | $response[] = $resp->value(); | 
| 450 | 450 | } | 
| @@ -466,7 +466,7 @@ discard block | ||
| 466 | 466 |  foreach ($test_results as $test => $results) { | 
| 467 | 467 | echo "\nTEST: $test\n"; | 
| 468 | 468 |      foreach ($results as $case => $data) { | 
| 469 | -        echo "  $case: {$data['time']} secs - Output data CRC: " . crc32(serialize($data['result'])) . "\n"; | |
| 469 | +        echo "  $case: {$data['time']} secs - Output data CRC: ".crc32(serialize($data['result']))."\n"; | |
| 470 | 470 | } | 
| 471 | 471 | } | 
| 472 | 472 | |