forked from loafle/openapi-generator-original
		
	
		
			
				
	
	
		
			349 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			349 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * ApiClient
 | |
|  *
 | |
|  * PHP version 5
 | |
|  *
 | |
|  * @category Class
 | |
|  * @package  Swagger\Client
 | |
|  * @author   http://github.com/swagger-api/swagger-codegen
 | |
|  * @license  http://www.apache.org/licenses/LICENSE-2.0 Apache Licene v2
 | |
|  * @link     https://github.com/swagger-api/swagger-codegen
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * Swagger Petstore
 | |
|  *
 | |
|  * This spec is mainly for testing Petstore server and contains fake endpoints, models. Please do not use this for any other purpose. Special characters: \" \\
 | |
|  *
 | |
|  * OpenAPI spec version: 1.0.0
 | |
|  * Contact: apiteam@swagger.io
 | |
|  * Generated by: https://github.com/swagger-api/swagger-codegen.git
 | |
|  *
 | |
|  * Licensed under the Apache License, Version 2.0 (the "License");
 | |
|  * you may not use this file except in compliance with the License.
 | |
|  * You may obtain a copy of the License at
 | |
|  *
 | |
|  *      http://www.apache.org/licenses/LICENSE-2.0
 | |
|  *
 | |
|  * Unless required by applicable law or agreed to in writing, software
 | |
|  * distributed under the License is distributed on an "AS IS" BASIS,
 | |
|  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
|  * See the License for the specific language governing permissions and
 | |
|  * limitations under the License.
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * NOTE: This class is auto generated by the swagger code generator program.
 | |
|  * https://github.com/swagger-api/swagger-codegen
 | |
|  * Do not edit the class manually.
 | |
|  */
 | |
| 
 | |
| namespace Swagger\Client;
 | |
| 
 | |
| /**
 | |
|  * ApiClient Class Doc Comment
 | |
|  *
 | |
|  * @category Class
 | |
|  * @package  Swagger\Client
 | |
|  * @author   http://github.com/swagger-api/swagger-codegen
 | |
|  * @license  http://www.apache.org/licenses/LICENSE-2.0 Apache Licene v2
 | |
|  * @link     https://github.com/swagger-api/swagger-codegen
 | |
|  */
 | |
| class ApiClient
 | |
| {
 | |
| 
 | |
|     public static $PATCH = "PATCH";
 | |
|     public static $POST = "POST";
 | |
|     public static $GET = "GET";
 | |
|     public static $HEAD = "HEAD";
 | |
|     public static $OPTIONS = "OPTIONS";
 | |
|     public static $PUT = "PUT";
 | |
|     public static $DELETE = "DELETE";
 | |
| 
 | |
|     /**
 | |
|      * Configuration
 | |
|      *
 | |
|      * @var Configuration
 | |
|      */
 | |
|     protected $config;
 | |
| 
 | |
|     /**
 | |
|      * Object Serializer
 | |
|      *
 | |
|      * @var ObjectSerializer
 | |
|      */
 | |
|     protected $serializer;
 | |
| 
 | |
|     /**
 | |
|      * Constructor of the class
 | |
|      *
 | |
|      * @param Configuration $config config for this ApiClient
 | |
|      */
 | |
|     public function __construct(\Swagger\Client\Configuration $config = null)
 | |
|     {
 | |
|         if ($config == null) {
 | |
|             $config = Configuration::getDefaultConfiguration();
 | |
|         }
 | |
| 
 | |
|         $this->config = $config;
 | |
|         $this->serializer = new ObjectSerializer();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the config
 | |
|      *
 | |
|      * @return Configuration
 | |
|      */
 | |
|     public function getConfig()
 | |
|     {
 | |
|         return $this->config;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the serializer
 | |
|      *
 | |
|      * @return ObjectSerializer
 | |
|      */
 | |
|     public function getSerializer()
 | |
|     {
 | |
|         return $this->serializer;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get API key (with prefix if set)
 | |
|      *
 | |
|      * @param  string $apiKeyIdentifier name of apikey
 | |
|      *
 | |
|      * @return string API key with the prefix
 | |
|      */
 | |
|     public function getApiKeyWithPrefix($apiKeyIdentifier)
 | |
|     {
 | |
|         $prefix = $this->config->getApiKeyPrefix($apiKeyIdentifier);
 | |
|         $apiKey = $this->config->getApiKey($apiKeyIdentifier);
 | |
| 
 | |
|         if (!isset($apiKey)) {
 | |
|             return null;
 | |
|         }
 | |
| 
 | |
|         if (isset($prefix)) {
 | |
|             $keyWithPrefix = $prefix." ".$apiKey;
 | |
|         } else {
 | |
|             $keyWithPrefix = $apiKey;
 | |
|         }
 | |
| 
 | |
|         return $keyWithPrefix;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Make the HTTP call (Sync)
 | |
|      *
 | |
|      * @param string $resourcePath path to method endpoint
 | |
|      * @param string $method       method to call
 | |
|      * @param array  $queryParams  parameters to be place in query URL
 | |
|      * @param array  $postData     parameters to be placed in POST body
 | |
|      * @param array  $headerParams parameters to be place in request header
 | |
|      * @param string $responseType expected response type of the endpoint
 | |
|      *
 | |
|      * @throws \Swagger\Client\ApiException on a non 2xx response
 | |
|      * @return mixed
 | |
|      */
 | |
|     public function callApi($resourcePath, $method, $queryParams, $postData, $headerParams, $responseType = null)
 | |
|     {
 | |
| 
 | |
|         $headers = array();
 | |
| 
 | |
|         // construct the http header
 | |
|         $headerParams = array_merge(
 | |
|             (array)$this->config->getDefaultHeaders(),
 | |
|             (array)$headerParams
 | |
|         );
 | |
| 
 | |
|         foreach ($headerParams as $key => $val) {
 | |
|             $headers[] = "$key: $val";
 | |
|         }
 | |
| 
 | |
|         // form data
 | |
|         if ($postData and in_array('Content-Type: application/x-www-form-urlencoded', $headers)) {
 | |
|             $postData = http_build_query($postData);
 | |
|         } elseif ((is_object($postData) or is_array($postData)) and !in_array('Content-Type: multipart/form-data', $headers)) { // json model
 | |
|             $postData = json_encode(\Swagger\Client\ObjectSerializer::sanitizeForSerialization($postData));
 | |
|         }
 | |
| 
 | |
|         $url = $this->config->getHost() . $resourcePath;
 | |
| 
 | |
|         $curl = curl_init();
 | |
|         // set timeout, if needed
 | |
|         if ($this->config->getCurlTimeout() != 0) {
 | |
|             curl_setopt($curl, CURLOPT_TIMEOUT, $this->config->getCurlTimeout());
 | |
|         }
 | |
|         // return the result on success, rather than just true
 | |
|         curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
 | |
| 
 | |
|         curl_setopt($curl, CURLOPT_HTTPHEADER, $headers);
 | |
| 
 | |
|         // disable SSL verification, if needed
 | |
|         if ($this->config->getSSLVerification() == false) {
 | |
|             curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);
 | |
|             curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0);
 | |
|         }
 | |
| 
 | |
|         if (!empty($queryParams)) {
 | |
|             $url = ($url . '?' . http_build_query($queryParams));
 | |
|         }
 | |
| 
 | |
|         if ($method == self::$POST) {
 | |
|             curl_setopt($curl, CURLOPT_POST, true);
 | |
|             curl_setopt($curl, CURLOPT_POSTFIELDS, $postData);
 | |
|         } elseif ($method == self::$HEAD) {
 | |
|             curl_setopt($curl, CURLOPT_NOBODY, true);
 | |
|         } elseif ($method == self::$OPTIONS) {
 | |
|             curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "OPTIONS");
 | |
|             curl_setopt($curl, CURLOPT_POSTFIELDS, $postData);
 | |
|         } elseif ($method == self::$PATCH) {
 | |
|             curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "PATCH");
 | |
|             curl_setopt($curl, CURLOPT_POSTFIELDS, $postData);
 | |
|         } elseif ($method == self::$PUT) {
 | |
|             curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "PUT");
 | |
|             curl_setopt($curl, CURLOPT_POSTFIELDS, $postData);
 | |
|         } elseif ($method == self::$DELETE) {
 | |
|             curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "DELETE");
 | |
|             curl_setopt($curl, CURLOPT_POSTFIELDS, $postData);
 | |
|         } elseif ($method != self::$GET) {
 | |
|             throw new ApiException('Method ' . $method . ' is not recognized.');
 | |
|         }
 | |
|         curl_setopt($curl, CURLOPT_URL, $url);
 | |
| 
 | |
|         // Set user agent
 | |
|         curl_setopt($curl, CURLOPT_USERAGENT, $this->config->getUserAgent());
 | |
| 
 | |
|         // debugging for curl
 | |
|         if ($this->config->getDebug()) {
 | |
|             error_log("[DEBUG] HTTP Request body  ~BEGIN~".PHP_EOL.print_r($postData, true).PHP_EOL."~END~".PHP_EOL, 3, $this->config->getDebugFile());
 | |
| 
 | |
|             curl_setopt($curl, CURLOPT_VERBOSE, 1);
 | |
|             curl_setopt($curl, CURLOPT_STDERR, fopen($this->config->getDebugFile(), 'a'));
 | |
|         } else {
 | |
|             curl_setopt($curl, CURLOPT_VERBOSE, 0);
 | |
|         }
 | |
| 
 | |
|         // obtain the HTTP response headers
 | |
|         curl_setopt($curl, CURLOPT_HEADER, 1);
 | |
| 
 | |
|         // Make the request
 | |
|         $response = curl_exec($curl);
 | |
|         $http_header_size = curl_getinfo($curl, CURLINFO_HEADER_SIZE);
 | |
|         $http_header = $this->httpParseHeaders(substr($response, 0, $http_header_size));
 | |
|         $http_body = substr($response, $http_header_size);
 | |
|         $response_info = curl_getinfo($curl);
 | |
| 
 | |
|         // debug HTTP response body
 | |
|         if ($this->config->getDebug()) {
 | |
|             error_log("[DEBUG] HTTP Response body ~BEGIN~".PHP_EOL.print_r($http_body, true).PHP_EOL."~END~".PHP_EOL, 3, $this->config->getDebugFile());
 | |
|         }
 | |
| 
 | |
|         // Handle the response
 | |
|         if ($response_info['http_code'] == 0) {
 | |
|             throw new ApiException("API call to $url timed out: ".serialize($response_info), 0, null, null);
 | |
|         } elseif ($response_info['http_code'] >= 200 && $response_info['http_code'] <= 299) {
 | |
|             // return raw body if response is a file
 | |
|             if ($responseType == '\SplFileObject' || $responseType == 'string') {
 | |
|                 return array($http_body, $response_info['http_code'], $http_header);
 | |
|             }
 | |
| 
 | |
|             $data = json_decode($http_body);
 | |
|             if (json_last_error() > 0) { // if response is a string
 | |
|                 $data = $http_body;
 | |
|             }
 | |
|         } else {
 | |
|             $data = json_decode($http_body);
 | |
|             if (json_last_error() > 0) { // if response is a string
 | |
|                 $data = $http_body;
 | |
|             }
 | |
| 
 | |
|             throw new ApiException(
 | |
|                 "[".$response_info['http_code']."] Error connecting to the API ($url)",
 | |
|                 $response_info['http_code'],
 | |
|                 $http_header,
 | |
|                 $data
 | |
|             );
 | |
|         }
 | |
|         return array($data, $response_info['http_code'], $http_header);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the header 'Accept' based on an array of Accept provided
 | |
|      *
 | |
|      * @param string[] $accept Array of header
 | |
|      *
 | |
|      * @return string Accept (e.g. application/json)
 | |
|      */
 | |
|     public function selectHeaderAccept($accept)
 | |
|     {
 | |
|         if (count($accept) === 0 or (count($accept) === 1 and $accept[0] === '')) {
 | |
|             return null;
 | |
|         } elseif (preg_grep("/application\/json/i", $accept)) {
 | |
|             return 'application/json';
 | |
|         } else {
 | |
|             return implode(',', $accept);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the content type based on an array of content-type provided
 | |
|      *
 | |
|      * @param string[] $content_type Array fo content-type
 | |
|      *
 | |
|      * @return string Content-Type (e.g. application/json)
 | |
|      */
 | |
|     public function selectHeaderContentType($content_type)
 | |
|     {
 | |
|         if (count($content_type) === 0 or (count($content_type) === 1 and $content_type[0] === '')) {
 | |
|             return 'application/json';
 | |
|         } elseif (preg_grep("/application\/json/i", $content_type)) {
 | |
|             return 'application/json';
 | |
|         } else {
 | |
|             return implode(',', $content_type);
 | |
|         }
 | |
|     }
 | |
| 
 | |
|    /**
 | |
|     * Return an array of HTTP response headers
 | |
|     *
 | |
|     * @param string $raw_headers A string of raw HTTP response headers
 | |
|     *
 | |
|     * @return string[] Array of HTTP response heaers
 | |
|     */
 | |
|     protected function httpParseHeaders($raw_headers)
 | |
|     {
 | |
|         // ref/credit: http://php.net/manual/en/function.http-parse-headers.php#112986
 | |
|         $headers = array();
 | |
|         $key = '';
 | |
| 
 | |
|         foreach (explode("\n", $raw_headers) as $h) {
 | |
|             $h = explode(':', $h, 2);
 | |
| 
 | |
|             if (isset($h[1])) {
 | |
|                 if (!isset($headers[$h[0]])) {
 | |
|                     $headers[$h[0]] = trim($h[1]);
 | |
|                 } elseif (is_array($headers[$h[0]])) {
 | |
|                     $headers[$h[0]] = array_merge($headers[$h[0]], array(trim($h[1])));
 | |
|                 } else {
 | |
|                     $headers[$h[0]] = array_merge(array($headers[$h[0]]), array(trim($h[1])));
 | |
|                 }
 | |
| 
 | |
|                 $key = $h[0];
 | |
|             } else {
 | |
|                 if (substr($h[0], 0, 1) == "\t") {
 | |
|                     $headers[$key] .= "\r\n\t".trim($h[0]);
 | |
|                 } elseif (!$key) {
 | |
|                     $headers[0] = trim($h[0]);
 | |
|                 }
 | |
|                 trim($h[0]);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return $headers;
 | |
|     }
 | |
| }
 |