diff options
Diffstat (limited to 'php_http_client')
-rw-r--r-- | php_http_client/client.php | 186 | ||||
-rw-r--r-- | php_http_client/config.php | 0 |
2 files changed, 186 insertions, 0 deletions
diff --git a/php_http_client/client.php b/php_http_client/client.php new file mode 100644 index 0000000..7ce72be --- /dev/null +++ b/php_http_client/client.php @@ -0,0 +1,186 @@ +<?php +class Client { + + function __construct($host, $request_headers= [], $version=null){ + /* + @param host: Base URL for the api. (e.g. https://api.sendgrid.com) + @type host: string + + @param request_headers: A dictionary of the headers you want applied on all calls + @type request_headers: dictionary + + @param version: The version number of the API. + @type integer: + */ + + $this->host = $host; + $this->request_headers = $request_headers; + $this->version = $version; + + # _count and _url_path keep track of the dynamically built url + $this->_count = 0; + $this->_methods = ['delete', 'get', 'patch', 'post', 'put']; + $this->_url_path = {}; + $this->_status_code = null; + $this->_response_body = null; + $this->_response_headers = null; + $this->_response = null; + } + + /* + Resets the URL builder, so you can make a fresh new dynamic call. + */ + private function _reset(self) { + $this->_count = 0 + $this->_url_path = {} + $this->_response = None + } + + /** + * Takes the method chained call and adds to the url path. + * @param name: The name of the method call + * @type name: string + */ + private function _add_to_url_path($name) { + $this->_url_path[$this->_count] = $name; + $this->_count += 1; + } + + /** + * Subclass this function for your own needs. + * Or just pass the version as part of the URL + * (e.g. client._('/v3')) + * @param url: URI portion of the full URL being requested + * @type url: string + * @return: string + */ + private function _build_versioned_url($url) { + return sprintf("%s/v%d%s", $this->host, $this->_version, $url); + } + + /** + * Build the final URL to be passed + * @param query_params: A dictionary of all the query parameters + * @type query_params: dictionary + * @return: + */ + private function _build_url($query_params = null) { + + $url = ''; + $count = 0; + + while ($count < count($this->_url_path)) { + $url += sprintf("/%s", $this->_url_path[count]); + count+=1; + } + + if (isset($query_params)) { + $url_values = urlencode(asort(query_params)); + $url = sprintf('%s?%s', $url, $url_values); + } + + if ($this->_version) { + $url = $this->_build_versioned_url($url); + } else { + $url = $this->host + url; + } + + return $url; + } + + /** + * Build the API call's response + * :param response: The response object from the API call from urllib + * :type response: urllib.Request object + */ + private function _set_response($response) { + + // @todo fix this to handle the response from guzzle + + $this->_status_code = ""; + $this->_response_body = ""; + $this->_response_headers = ""; + } + /** + * Build the headers for the request + * @param request_headers: headers to set for the API call + * @type response: dict + * @return: + */ + private function _set_headers($request_headers) { + $this->request_headers = array_merge($this->request_headers, $request_headers); + } + + /** + * Make the API call and return the response. This is separated into it's own function, so we can mock it easily for testing. + * @param opener: + * @type opener: + * @param request: url payload to request + * @type request: urllib.Request object + * @return: + */ + private function _make_request($opener, $request) { + //@todo make the call using guzzle, and fix the return value + + return null; + } + + /** + * Add variable values to the URL + * (e.g. /your/api/{variable_value}/call) + */ + public function _($value){ + $this->_add_to_url_path($value); + return $this; + } + + /** + * Dynamically add method calls to the url, then call a method. + * (e.g. client.name.name.method()) + */ + public function __call($name, $args){ + + if (in_array($name, $this->_methods)) { + $this->_make_request();d + return $this; + } + + $this->cache[$this->count] = $name; + $this->count = $this->count + 1; + return $this; + } + + /** + * @return: integer, status code of API call + */ + public function status_code() { + return $this->status_code; + } + + /** + * @return: response from the API + */ + public function response_body() { + return $this->response_body; + } + + /** + * @return: dict of response headers + */ + public function response_headers() { + return $this->response_headers; + } + + /** + * Add the version to the path + */ + public function version($version) { + $this->_version = $version; + } + + private function _get_version() { + return $this->_version; + } + +} +?> diff --git a/php_http_client/config.php b/php_http_client/config.php new file mode 100644 index 0000000..e69de29 --- /dev/null +++ b/php_http_client/config.php |