A wrapper for gar_auth and gar_auth_service
An existing token or file location of a token to authenticate with
An existing cached email to authenticate with or
Authentication service key you have downloaded from your Google Project - an alternative to OAuth2 email authentication
Run this function first time to authenticate with Google in your browser.
After initial authentication, your authentication details will be kept globally for use later, tied to your email, and the next time you authenticate you will be given a prompt to choose which email to authentcate from. Set
email="firstname.lastname@example.org" to skip the interactive prompt.
Invisibly, the token that has been saved to the session
You can authenticate with a new email for each account. Supply a different email to use those details for your session.
If you use the service account JSON, you will need to add the service account email
to your Google Analytics users to see data e.g.
You can choose to auto-authenticate by creating a Google OAuth service account JSON file.
Specify an environment variable in R via a
.Renviron file or using Sys.setenv which points to the file location of your chosen authentication file. See Startup
Once you have set the environment variable
GA_AUTH_FILE to a valid file location,
the function will look there for authentication details upon loading the library meaning
you will not need to call
ga_auth() yourself as you would normally.
.Renviron file is below:
GA_AUTH_FILE = "/Users/bob/auth/googleAnalyticsR.json"
GA_AUTH_FILE can be a service account JSON ending with file extension
.json. Make sure to give the service account email access to your Google Analytics account as mentioned above.
Be default the Google Project used is shared by all users, so you may find it runs out of API calls. To mitigate that, create your own Google Project and turn on the Analytics APIs.
The best way to do this is to use gar_set_client by downloading your JSON client credentials and setting them to be found on package startup via the
GAR_CLIENT_JSON environment argument. See
?googleAuthR::gar_set_client function help pages for details.
Or you can then copy your Google Cloud Project's client ID and client secret, to place in options or environment arguments (whichever is easiest)
The environment args are below. Similar to auto-authentication, you can place your entries in an
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
## Not run: # to use default package credentials (for testing) library(googleAnalyticsR) ga_auth() # to use your own Google Cloud Project credentials # go to GCP console and download client credentials JSON # ideally set this in .Renviron file, not here but just for demonstration Sys.setenv("GAR_CLIENT_JSON" = "location/of/file.json") library(googleAnalyticsR) # should now be able to log in via your own GCP project ga_auth() # reauthentication # Once you have authenticated, set email to skip the interactive message ga_auth(email = "email@example.com") # or leave unset to bring up menu on which email to auth with ga_auth() # The googleAnalyticsR package is requesting access to your Google account. # Select a pre-authorised account or enter '0' to obtain a new token. # Press Esc/Ctrl + C to abort. #1: firstname.lastname@example.org #2: email@example.com # you can set authentication for many emails, then switch between them e.g. ga_auth(email = "firstname.lastname@example.org") ga_account_list() # lists one set of accounts ga_auth(email = "email@example.com") ga_account_list() # lists second set of accounts # or authenticate via the service key, that has been added to the GA as a user ga_auth(json_file = "service-key.json") ## End(Not run)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.