php version 02

This commit is contained in:
Mashaper
2011-04-20 14:20:51 -07:00
parent 45b36f9a3e
commit a3ba45fe92
5 changed files with 35 additions and 29 deletions

2
README
View File

@@ -1,4 +1,4 @@
Mashape PHP client library v0.1 Mashape PHP client library v0.2
Copyright (C) 2011 Mashape, Inc. Copyright (C) 2011 Mashape, Inc.
For the documentation, please visit http://www.mashape.com/guide/consume/php For the documentation, please visit http://www.mashape.com/guide/consume/php

View File

@@ -30,6 +30,6 @@ define("EXCEPTION_NOTSUPPORTED_HTTPMETHOD", "HTTP method not supported. Only DEL
define("EXCEPTION_SYSTEM_ERROR_CODE", 2000); define("EXCEPTION_SYSTEM_ERROR_CODE", 2000);
define("EXCEPTION_EMPTY_REQUEST", "A request attempt was made to the component, but the response was empty. The component's URL may be wrong or the firewall may be blocking your outbound HTTP requests."); define("EXCEPTION_EMPTY_REQUEST", "A request attempt was made to the component, but the response was empty. The component's URL may be wrong or the firewall may be blocking your outbound HTTP requests.");
define("EXCEPTION_JSONDECODE_REQUEST", "Can't deserialize the response JSON from the component. The json_decode function is missing on your server or the method returned an invalid JSON value."); define("EXCEPTION_JSONDECODE_REQUEST", "Can't deserialize the response JSON from the component. The json_decode function is missing on your server or the method returned an invalid JSON value: %s");
?> ?>

View File

@@ -26,11 +26,7 @@
require_once(dirname(__FILE__) . "/../init/init.php"); require_once(dirname(__FILE__) . "/../init/init.php");
require_once(dirname(__FILE__) . "/../exceptions/mashapeClientException.php"); require_once(dirname(__FILE__) . "/../exceptions/mashapeClientException.php");
require_once(dirname(__FILE__) . "/urlUtils.php");
define("METHOD", "_method");
define("TOKEN", "_token");
define("LANGUAGE", "_language");
define("VERSION", "_version");
class HttpMethod class HttpMethod
{ {
@@ -42,7 +38,7 @@ class HttpMethod
class HttpClient { class HttpClient {
public static function call($baseUrl, $httpMethod, $method, $token, $parameters) { public static function call($url, $httpMethod, $token, $parameters) {
if (empty($parameters)) { if (empty($parameters)) {
$parameters = array(); $parameters = array();
} else { } else {
@@ -59,24 +55,25 @@ class HttpClient {
} }
} }
$parameters[METHOD] = $method;
$parameters[TOKEN] = $token; $parameters[TOKEN] = $token;
$parameters[LANGUAGE] = CLIENT_LIBRARY_LANGUAGE; $parameters[LANGUAGE] = CLIENT_LIBRARY_LANGUAGE;
$parameters[VERSION] = CLIENT_LIBRARY_VERSION; $parameters[VERSION] = CLIENT_LIBRARY_VERSION;
$url = UrlUtils::addClientParameters($url);
$response; $response;
switch($httpMethod) { switch($httpMethod) {
case HttpMethod::DELETE: case HttpMethod::DELETE:
$response = self::doDelete($baseUrl, $parameters); $response = self::doDelete($url, $parameters);
break; break;
case HttpMethod::GET: case HttpMethod::GET:
$response = self::doGet($baseUrl, $parameters); $response = self::doGet($url, $parameters);
break; break;
case HttpMethod::POST: case HttpMethod::POST:
$response = self::doPost($baseUrl, $parameters); $response = self::doPost($url, $parameters);
break; break;
case HttpMethod::PUT: case HttpMethod::PUT:
$response = self::doPut($baseUrl, $parameters); $response = self::doPut($url, $parameters);
break; break;
default: default:
throw new MashapeClientException(EXCEPTION_NOTSUPPORTED_HTTPMETHOD, EXCEPTION_NOTSUPPORTED_HTTPMETHOD_CODE); throw new MashapeClientException(EXCEPTION_NOTSUPPORTED_HTTPMETHOD, EXCEPTION_NOTSUPPORTED_HTTPMETHOD_CODE);
@@ -86,29 +83,30 @@ class HttpClient {
} }
$responseObject = json_decode($response); $responseObject = json_decode($response);
if (empty($responseObject)) { if (empty($responseObject)) {
throw new MashapeClientException(EXCEPTION_JSONDECODE_REQUEST, EXCEPTION_SYSTEM_ERROR_CODE); throw new MashapeClientException(sprintf(EXCEPTION_JSONDECODE_REQUEST, $response), EXCEPTION_SYSTEM_ERROR_CODE);
} }
return $responseObject; return $responseObject;
} }
public static function doGet($url, $parameters) { private static function replaceParameters($url, $parameters) {
$queryString = ""; $finalUrl = UrlUtils::getCleanUrl($url, $parameters);
if (!empty($parameters)) { if (!empty($parameters)) {
$keys = array_keys($parameters); $keys = array_keys($parameters);
for ($i = 0;$i<count($keys);$i++) { for ($i = 0;$i<count($keys);$i++) {
$key = $keys[$i]; $key = $keys[$i];
if ($i != 0) { $finalUrl = str_replace("{" . $key . "}", urlencode($parameters[$key]), $finalUrl);
$queryString .= "&";
} }
$queryString .= $key . "=" . urlencode($parameters[$key]);
} }
return $finalUrl;
} }
$response = self::makeRequest($url . "?" . $queryString, "GET", null); private static function doGet($url, $parameters) {
$finalUrl = self::replaceParameters($url, $parameters);
$response = self::makeRequest($finalUrl, "GET", null);
return $response; return $response;
} }
private static function doPost($url, $parameters) { public static function doPost($url, $parameters) {
$response = self::makeRequest($url, "POST", $parameters); $response = self::makeRequest($url, "POST", $parameters);
return $response; return $response;
} }
@@ -125,8 +123,12 @@ class HttpClient {
private static function makeRequest($url, $httpMethod, $parameters) { private static function makeRequest($url, $httpMethod, $parameters) {
$data = null; $data = null;
$finalUrl = $url;
if (!(empty($parameters))) { if (!(empty($parameters))) {
$data = http_build_query($parameters); // It's a POST/PUT/DELETE request
$data = http_build_query(array_merge($parameters, UrlUtils::getQueryStringParameters($url)));
$finalUrl = self::replaceParameters($url, $parameters);
$finalUrl = UrlUtils::removeQueryString($finalUrl);
} }
$opts = array('http' => $opts = array('http' =>
@@ -138,7 +140,7 @@ class HttpClient {
); );
$context = stream_context_create($opts); $context = stream_context_create($opts);
$response = @file_get_contents($url, false, $context); $response = @file_get_contents($finalUrl, false, $context);
return $response; return $response;
} }

View File

@@ -31,10 +31,10 @@ define("TOKEN_URL", "https://api.mashape.com/requestToken");
class TokenUtil { class TokenUtil {
public static function requestToken($apiKey) { public static function requestToken($devKey) {
$parameters = array("apikey"=>$apiKey); $parameters = array("devkey"=>$devKey);
$response = HttpClient::doGet(TOKEN_URL, $parameters); $response = HttpClient::doPost(TOKEN_URL, $parameters);
$jsonResponse = json_decode($response); $jsonResponse = json_decode($response);
if (empty($jsonResponse->errors)) { if (empty($jsonResponse->errors)) {

View File

@@ -27,5 +27,9 @@
require_once(dirname(__FILE__) . "/json.php"); require_once(dirname(__FILE__) . "/json.php");
define("CLIENT_LIBRARY_LANGUAGE", "PHP"); define("CLIENT_LIBRARY_LANGUAGE", "PHP");
define("CLIENT_LIBRARY_VERSION", "V01"); define("CLIENT_LIBRARY_VERSION", "V02");
define("TOKEN", "_token");
define("LANGUAGE", "_language");
define("VERSION", "_version");
?> ?>