#Google Analytics API PHP
Simple class to set up Oauth 2.0 with Google and query the Google Analytics API v3 with PHP. Curl is required!
##1. Basic Setup
- Create a Project in the Google APIs Console: https://code.google.com/apis/console/
- Enable the Analytics API under Services
- Under API Access: create an Oauth 2.0 Client-ID
- Give a Product-Name, choose "Web-Application"
- Set a redirect-uri in the Project which points to your App's Url
##2. Set up Auth
include('GoogleAnalyticsAPI.class.php');
$ga = new GoogleAnalyticsAPI();
$ga->auth->setClientId('your_client_id');
$ga->auth->setClientSecret('your_client_secret');
$ga->auth->setRedirectUri('redirect_uri');
//Get the Auth-Url
$url = $ga->auth->buildAuthUrl();
Provide a link to the Auth-Url. The user has to log in with his Google Account, accept that your App will access the Analytics Data. After completing this steps, the user will be redirected back to the redirect-uri along with a code. This code is needed to get the tokens.
$code = $_GET['code'];
$auth = $ga->auth->getAccessToken($code);
//Try to get the AccessToken
if ($auth['http_code'] == 200) {
$accessToken = $auth['access_token'];
$refreshToken = $auth['refresh_token'];
$tokenExpires = $auth['expires_in'];
$tokenCreated = time();
} else {
//error...
}
With the accessToken you can query the API for the given time (seconds) in $tokenExpires. If you need to query the API beyond this time, you should store the refreshToken along with a timestamp in the Database / Session. If the accessToken expires, you can get a new one with the refreshToken.
//Check if the accessToken is expired
if ((time() - $tokenCreated) >= $tokenExpires) {
$auth = $ga->auth->refreshAccessToken($refreshToken);
//Get the accessToken as above and save it into the Database / Session
}
##3. Find the Account-ID
Before you can query the API, you need the ID of the Account you want to query the data. The ID can be found like this:
$profiles = $ga->getProfiles();
$accounts = array();
foreach ($profiles['items'] as $item) {
$id = "ga:{$item['id']}";
$name = $item['name'];
$accounts[$id] = $name;
}
//Print out the Accounts with Id => Name, the array-key of one Account is the ID you have to remember
print_r($accounts);
##4. Query the Google Analytics API
Once you have a valid accessToken and an Account-ID, you can query the Google Analytics API. You can set some default Query Parameters that will be executed with every query.
//Set the accessToken and Account-Id
$ga->setAccessToken($accessToken);
$ga->setAccountId('ga:xxxxxxx');
//Set the default params. For example the start/end dates and max-results
$defaults = array(
'start-date' => date('Y-m-d', strtotime('-1 month')),
'end-date' => date('Y-m-d'),
);
$ga->setDefaultQueryParams($defaults);
//Example1: Get visits by date
$params = array(
'metrics' => 'ga:visits',
'dimensions' => 'ga:date',
);
$visits = $ga->query($params);
//Example2: Get visits by country
$params = array(
'metrics' => 'ga:visits',
'dimensions' => 'ga:country',
'sort' => '-ga:visits',
'max-results' => 30,
'start-date' => '2013-01-01' //Overwrite this from the defaultQueryParams
);
$visitsByCountry = $ga->query($params);
//Example3: Same data as Example1 but with the built in method:
$visits = $ga->getVisitsByDate();
//Example4: Get visits by Operating Systems and return max. 100 results
$visitsByOs = $ga->getVisitsBySystemOs(array('max-results' => 100));
###Metrics & Dimensions Reference: https://developers.google.com/analytics/devguides/reporting/core/dimsmets
###Google Analytics Query Explorer for testing queries and results: http://ga-dev-tools.appspot.com/explorer/