Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tpitale/legato

Google Analytics Reporting API Client for Ruby
https://github.com/tpitale/legato

analytics google-analytics ruby

Last synced: about 10 hours ago
JSON representation

Google Analytics Reporting API Client for Ruby

Awesome Lists containing this project

README

        

# Legato: Ruby Client for the Google Analytics Core Reporting and Management API #

[![Gem Version](https://badge.fury.io/rb/legato.png)](http://badge.fury.io/rb/legato)
[![Build Status](https://travis-ci.org/tpitale/legato.png)](https://travis-ci.org/tpitale/legato)
[![Code Climate](https://codeclimate.com/github/tpitale/legato.png)](https://codeclimate.com/github/tpitale/legato)

## [Check out the Wiki!](https://github.com/tpitale/legato/wiki) ##

**Feel free to open an issue if you have a question that is not answered in the [Wiki](https://github.com/tpitale/legato/wiki)**

If you've come here from Garb, welcome! There are a few changes from Garb, so you'll want to check out:

* [Model Data](https://github.com/tpitale/legato/wiki/Model-Data)
* [Query Parameters](https://github.com/tpitale/legato/wiki/Query-Parameters)
* And the biggest difference: [Filtering](https://github.com/tpitale/legato/wiki/Filtering)

If you're not able to upgrade quite yet, Garb has been maintained https://github.com/Sija/garb

## Google Analytics Management ##

1. Get an OAuth2 Access Token from Google, Read about [OAuth2](https://github.com/tpitale/legato/wiki/OAuth2-and-Google)

```ruby
access_token = OAuth2 Access Token # from Google
```

2. Create a New User with the Access Token

```ruby
user = Legato::User.new(access_token)
```

3. List the Accounts and Profiles of the first Account

```ruby
user.accounts
user.accounts.first.profiles
```

4. List all the Profiles the User has Access to

```ruby
user.profiles
```

5. Get a Profile

```ruby
profile = user.profiles.first
```

6. The Profile Carries the User

```ruby
profile.user == user #=> true
```

7. The profile can also lookup its "parent" Web Property

```ruby
profile.web_property
```

## Google Analytics Model ##

```ruby
class Exit
extend Legato::Model

metrics :exits, :pageviews
dimensions :page_path, :operating_system, :browser
end

profile.exit #=> returns a Legato::Query
profile.exit.each {} #=> any enumerable kicks off the request to GA
```

## Metrics & Dimensions ##

http://code.google.com/apis/analytics/docs/gdata/dimsmets/dimsmets.html

```ruby
metrics :exits, :pageviews
dimensions :page_path, :operating_system, :browser
```

## Filtering ##

Create named filters to wrap query filters.

Here's what google has to say: http://code.google.com/apis/analytics/docs/gdata/v3/reference.html#filters

### Examples ###

Inside of any `Legato::Model` class, the method `filter` is available (like `metrics` and `dimensions`).

Return entries with exits counts greater than or equal to 2000

```ruby
filter(:high_exits) {gte(:exits, 2000)}

# or ...

filter :high_exits, &lambda {gte(:exits, 2000)}
```

Return entries with pageview metric less than or equal to 200

```ruby
filter(:low_pageviews) {lte(:pageviews, 200)}
```

Filters with dimensions

```ruby
filter(:for_browser) {|browser| matches(:browser, browser)}
```

Filters with OR

```ruby
filter(:browsers) {|*browsers| browsers.map {|browser| matches(:browser, browser)}}
```

## Using and Chaining Filters ##

Pass the profile as the first or last parameter into any filter.

```ruby
Exit.for_browser("Safari", profile)
```

Chain two filters.

```ruby
Exit.high_exits.low_pageviews(profile)
```

Profile gets a method for each class extended by Legato::Model

```ruby
Exit.results(profile) == profile.exit
```

We can chain off of that method, too.

```ruby
profile.exit.high_exits.low_pageviews.by_pageviews
```

Chaining order doesn't matter. Profile can be given to any filter.

```ruby
Exit.high_exits(profile).low_pageviews == Exit.low_pageviews(profile).high_exits
```

Be sure to pass the appropriate number of arguments matching the lambda for your filter.

For a filter defined like this:

```ruby
filter(:browsers) {|*browsers| browsers.map {|browser| matches(:browser, browser)}}
```

We can use it like this, passing any number of arguments:

```ruby
Exit.browsers("Firefox", "Safari", profile)
```

## Google Analytics Supported Filtering Methods ##

Google Analytics supports a significant number of filtering options.

Here is what we can do currently:
(the operator is a method available in filters for the appropriate metric or dimension)

Operators on metrics (method => GA equivalent):

eql => '==',
not_eql => '!=',
gt => '>',
gte => '>=',
lt => '<',
lte => '<='

Operators on dimensions:

matches => '==',
does_not_match => '!=',
contains => '=~',
does_not_contain => '!~',
substring => '=@',
not_substring => '!@'

## Session-level Segments

Your query can have a session-level segment, which works with filter expressions. It
works like an [advanced
segment](https://support.google.com/analytics/answer/1033017?hl=en), except you
don't have to create it beforehand, you can just specify it at query time.

Some of the numbers you'll get will be different from using a filter, since
[the subset of visits matched happens before dimensions and metrics are
calculated](http://ga-dev-tools.appspot.com/explorer/) (hover on the `segment`
parameter to see).

Some metrics and dimensions are not allowed for segments, see the [API
documentation](https://developers.google.com/analytics/devguides/reporting/core/v3/reference#segment)
for more details.

**Note**: Legato does _not_ support [Users vs Sessions](https://developers.google.com/analytics/devguides/reporting/core/v3/segments#users-vs-sessions), yet. The default will be sessions (the equivalent of the earlier, now removed, dynamic segments).

### Defining, using and chaining segments

Return entries with exits counts greater than or equal to 2000

```ruby
segment :high_exits do
gte(:exits, 2000)
end
```

Return entries with pageview metric less than or equal to 200

```ruby
segment :low_pageviews do
lte(:pageviews, 200)
end
```

You can chain them

```ruby
Exit.high_exits.low_pageviews(profile)
```

and call them directly on the profile

```ruby
profile.exit.high_exits.low_pageviews
```
## Accounts, WebProperties, Profiles, and Goals ##

```ruby
Legato::Management::Account.all(user)
Legato::Management::WebProperty.all(user)
Legato::Management::Profile.all(user)
Legato::Management::Goal.all(user)
```
## Other Parameters Can be Passed to a call to #results ##

* :start_date - The date of the period you would like this report to start
* :end_date - The date to end, inclusive
* :limit - The maximum number of results to be returned
* :offset - The starting index
* :sort - metric/dimension to sort by
* :quota_user - any arbitrary string that uniquely identifies a user (40 characters max)
* :sampling_level - 'FASTER' or 'HIGHER_PRECISION' https://developers.google.com/analytics/devguides/reporting/core/v3/reference#samplingLevel
* :segment_id - this will supersede any segments chained to the query

## Real Time Reporting ##

https://developers.google.com/analytics/devguides/reporting/realtime/v3/
https://developers.google.com/analytics/devguides/reporting/realtime/dimsmets/

GA provides an endpoint to do **basic** reporting in near-realtime. Please read the above documentation to know which features (and dimentsion/metrics) are or are _not_ available. It is also only available in **beta** so you must already have access.

Inside of Legato, you can simply add `realtime` to your query (`#results` returns a `Query` instance), like this:

```ruby
Exit.results(profile).realtime
```
The results you iterate over (with `.each`, etc) will be from the realtime reporting API.

You can also call `realtime` on your model to get a new `Query` instance with realtime API set.

```ruby
query = Exit.realtime
query.realtime? #=> true
query.tracking_scope #=> 'rt'
```

## Managing Quotas ##

Assigning a `quota_user` or `user_ip` on a user instance will be used by management and query requests.

```ruby
user = Legato::User.new(access_token)
user.quota_user = 'some_unique_user_identifier'
# OR
user.user_ip = ip_address_from_a_web_user_or_something
```