Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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
- Host: GitHub
- URL: https://github.com/tpitale/legato
- Owner: tpitale
- License: mit
- Created: 2011-12-11T03:37:26.000Z (about 13 years ago)
- Default Branch: master
- Last Pushed: 2023-05-10T02:42:16.000Z (over 1 year ago)
- Last Synced: 2025-01-04T05:14:52.659Z (7 days ago)
- Topics: analytics, google-analytics, ruby
- Language: Ruby
- Homepage:
- Size: 281 KB
- Stars: 400
- Watchers: 16
- Forks: 48
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
- awesome-ruby-toolbox - legato - Access the Google Analytics Core Reporting and Management APIs with Ruby. Create models for metrics and dimensions. Filter your data to tell you what you need. (Web Apps, Services & Interaction / Web Analytics)
- awesome-ruby - Legato - Model analytics reports and queries against the official Google Analytics Reporting API. (Analytics)
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::Modelmetrics :exits, :pageviews
dimensions :page_path, :operating_system, :browser
endprofile.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
```