diff --git a/lib/Request.php b/lib/Request.php index 3442c53..e3191d9 100644 --- a/lib/Request.php +++ b/lib/Request.php @@ -9,7 +9,7 @@ abstract class Request { private static $validOutputFormats = array("json", "xml"); private static $requestAcceptType = ""; - + private static $requestAcceptEncoding = ""; /** * Sends GET request and returns output in specified format. * @@ -52,7 +52,10 @@ public static function request($request, $output_format = "xml", $decode_json = "Accept: ".$accept, "Authorization: Bearer ".$token ); - + /// enable GZIP compression for post MLSGRID Api + if(self::$requestAcceptEncoding) { + $headers[] = "Accept-Encoding:".self::$requestAcceptEncoding; + } // Send request $response = $curl->request("get", $url, $headers, null, false); if(!$response || !is_array($response) || $response[1] != 200) { @@ -112,6 +115,9 @@ public static function requestPost($request, $params = array()) "Accept: ".$accept, "Authorization: Bearer ".$token ); + if(self::$requestAcceptEncoding) { + $headers[] = "Accept-Encoding:".$requestAcceptEncoding; + } // Send request $response = $curl->request("post", $url, $headers, $params, false); @@ -192,7 +198,7 @@ public static function setAcceptType($type = "") { self::$requestAcceptType = $type; } } - + /** * Formats request parameters to compatible string * @@ -215,4 +221,14 @@ public static function formatRequestParameters($parameters_string) { return implode("&", $params); } + + /** + * Sets accep encoding + * + * @param string + */ + public static function setAcceptEncoding($encoding = "") { + self::$requestAcceptEncoding = $encoding; + } + }