Thursday, September 1, 2022

[SOLVED] Getting no result via PHP CURL from Polygon.io API (getting successful response via Postman)

Issue

I having been using various Polygon.io API endpoints successfully via a PHP CURL request. However, today when I tried to run an endpoint, I got no results. I have not been able to debug why.

I tried a simple endpoint with no parameters to test:

function callAPI($url) {
    $curl = curl_init();
    // Options
    curl_setopt($curl, CURLOPT_URL, $url);
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, true);
    curl_setopt($curl, CURLOPT_HEADER, false);
    curl_setopt($curl, CURLOPT_HTTPHEADER, array(
        'Content-Type:application/json', 
        'Accept:application/json', 
        'Authorization: Bearer APIKEYasdf1234'
    ));
    // Execute
    $result = curl_exec($curl);
    if(!$result){
        if($_GET) {
            die('Connection Failure');
        }
        else {
            die('No result');
        }
    }
    curl_close($curl);
    return $result;
}
$url = 'https://api.polygon.io/v1/marketstatus/now';

// Execute Query
$get_data = callAPI($url);
$response = json_decode($get_data);

var_dump($response);

This gives me a No Result. It made a successful connection and got nothing back.

When I try with Postman, I get the expected result.

enter image description here

Here is the Polygon documentation for this endpoint: https://polygon.io/docs/stocks/get_v1_marketstatus_now

Running PHP 8.0.13 on WAMPserver. Executed via command prompt

I did a var_dump of curl_getinfo($curl)) and here is what I got:

array(37) {
  ["url"]=>
  string(42) "https://api.polygon.io/v1/marketstatus/now"
  ["content_type"]=>
  NULL
  ["http_code"]=>
  int(0)
  ["header_size"]=>
  int(0)
  ["request_size"]=>
  int(0)
  ["filetime"]=>
  int(-1)
  ["ssl_verify_result"]=>
  int(20)
  ["redirect_count"]=>
  int(0)
  ["total_time"]=>
  float(0.069412)
  ["namelookup_time"]=>
  float(0.003393)
  ["connect_time"]=>
  float(0.033544)
  ["pretransfer_time"]=>
  float(0)
  ["size_upload"]=>
  float(0)
  ["size_download"]=>
  float(0)
  ["speed_download"]=>
  float(0)
  ["speed_upload"]=>
  float(0)
  ["download_content_length"]=>
  float(-1)
  ["upload_content_length"]=>
  float(-1)
  ["starttransfer_time"]=>
  float(0)
  ["redirect_time"]=>
  float(0)
  ["redirect_url"]=>
  string(0) ""
  ["primary_ip"]=>
  string(13) "[ip_address]"
  ["certinfo"]=>
  array(0) {
  }
  ["primary_port"]=>
  int(443)
  ["local_ip"]=>
  string(14) "[ip_address]"
  ["local_port"]=>
  int(60549)
  ["http_version"]=>
  int(0)
  ["protocol"]=>
  int(2)
  ["ssl_verifyresult"]=>
  int(0)
  ["scheme"]=>
  string(5) "HTTPS"
  ["appconnect_time_us"]=>
  int(0)
  ["connect_time_us"]=>
  int(33544)
  ["namelookup_time_us"]=>
  int(3393)
  ["pretransfer_time_us"]=>
  int(0)
  ["redirect_time_us"]=>
  int(0)
  ["starttransfer_time_us"]=>
  int(0)
  ["total_time_us"]=>
  int(69412)
}

I tried using the PHP - cURL code that Postman generates (and is successful with). Here is my updated function:

function callAPI($url) {
    $curl = curl_init();
    // Options
    curl_setopt_array($curl, array(
      CURLOPT_URL => $url,
      CURLOPT_RETURNTRANSFER => true,
      CURLOPT_ENCODING => '',
      CURLOPT_MAXREDIRS => 10,
      CURLOPT_TIMEOUT => 0,
      CURLOPT_FOLLOWLOCATION => true,
      CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
      CURLOPT_CUSTOMREQUEST => 'GET',
      CURLOPT_HTTPHEADER => array(
        'Content-Type:application/json', 
            'Accept:application/json',
        'Authorization: Bearer APIKEYasdf1234'
      ),
    ));
    // Execute
    $result = curl_exec($curl);
    if(!$result){
        if($_GET) {
            die('Connection Failure');
        }
        else {
            die('No result');
        }
    }
    curl_close($curl);
    return $result;
}

Unfortunately no change.


Solution

I am not sure what caused the issue. But I did the following to solve it:

  1. I installed composer and guzzle
  2. used guzzle to make the request
  3. added a SSL cert

Here is the updated code:

function getGuzzleClient(array $options = [])
{
    $options = array_merge_recursive([
         'allow_redirects' => [
             'max' => 10,
         ],
         'base_uri' => 'https://api.polygon.io/',
         'verify'       => __DIR__.'/cacert.pem',
         'headers' => [
             'Accept' => 'application/json',
             'Authorization' => 'Bearer APIKEYasdf1234',
             'Content-Type' => 'application/json',
         ],
     ], $options);

    return new GuzzleHttp\Client($options);
}
$client = getGuzzleClient();

$response = $client->get('v1/marketstatus/now');

var_dump(
    json_decode($response->getBody(), true)
);


Answered By - Alexnl
Answer Checked By - Clifford M. (WPSolving Volunteer)