aseo / api
Analytics SEO Api Client
Installs: 74 181
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 9
Forks: 2
Open Issues: 0
Requires
- php: >=5.3.0
- guzzle/guzzle: *
This package is not auto-updated.
Last update: 2025-01-18 18:10:30 UTC
README
Installation
Via Composer
- Run the command:
composer require "aseo/api:*"
Manual Installation
- Clone this repository:
git clone git@github.com:analyticsseo/php-api-client.git
- Change to the cloned folder, e.g.:
cd php-api-client
- Run command
composer install
Testing Your Installation
- Browse to folder
tests\functional
- Edit file
serps.php
, add your credentials, and save. - Run
php serps.php
Do not forget to edit the
serps.php
file and add your credentials, or all tests will fail
Sample Usage
<?php // Uncomment the following if you run this file directly, any modern framework // deals with autoloading out of the box. // include '<PATH TO COMPOSER AUTOLOAD FILE'; // Initialize the HTTP Transport Layer. $guzzle = new Guzzle\Http\Client('http://v3.api.analyticsseo.com'); // Setup Request Authentication. $auth = new Aseo\Api\Auth\KeyAuth; // Do not forget to change API_KEY, API_SECRET, and SALT with // the values provided by Analytics SEO. $auth->setApiKey(API_KEY); $auth->setApiSecret(API_SECRET); $auth->setSalt(SALT); // The V3 SERPs Client. $serps = new Aseo\Api\V3\Serps\SerpsApiClient($guzzle, $auth); // Set to true to output raw http requests. $serps->debug = false; // Define query paramaters, as per documentation. $query = array( 'region'=>'global', 'search_engine' => 'google', 'phrase' => 'abc', 'language' => 'en', ); // Create a SERPs request object. $data = new Aseo\Api\V3\Serps\SerpsRequest($query); // Make the call. $searchResultsResponse = $serps->searchResults($data); // Store the job id, this will be used to fetch the data as soon as the job is // done. $jobId = $searchResultsResponse['jid']; // Check to see if job is ready. If not, try again later. You can also execute // all queries, store the job ids, and later query to see each job id is ready. while (true) { $fetchJobResponse = $serps->fetchJobData($jobId); if (false == $fetchJobResponse['ready']) { sleep(60); continue; } var_export($fetchJobResponse); break; }