Authorize trackdown to view and manage your trackdown files. This function is a
wrapper around gargle::token_fetch()
.
By default, you are directed to a web browser, asked to sign in to your Google account, and to grant trackdown permission to operate on your behalf with trackdown. By default, with your permission, these user credentials are cached in a folder below your home directory, from where they can be automatically refreshed, as necessary. Storage at the user level means the same token can be used across multiple projects and tokens are less likely to be synced to the cloud by accident.
If you are interacting with R within a browser (applies to RStudio Server,
Posit Workbench, and Posit Cloud), you need a variant of this flow,
known as out-of-band auth ("oob"). If this does not happen
automatically, you can request it yourself with use_oob = TRUE
or,
more persistently, by setting an option via
options(gargle_oob_default = TRUE)
.
Usage
trackdown_auth(
email = gargle::gargle_oauth_email(),
path = NULL,
scopes = "https://www.googleapis.com/auth/drive",
cache = gargle::gargle_oauth_cache(),
use_oob = gargle::gargle_oob_default(),
token = NULL
)
Arguments
Optional. Allows user to target a specific Google identity. If specified, this is used for token lookup, i.e. to determine if a suitable token is already available in the cache. If no such token is found,
email
is used to pre-select the targetted Google identity in the OAuth chooser. Note, however, that the email associated with a token when it's cached is always determined from the token itself, never from this argument. UseNA
orFALSE
to match nothing and force the OAuth dance in the browser. UseTRUE
to allow email auto-discovery, if exactly one matching token is found in the cache. Specify just the domain with a glob pattern, e.g."*@example.com"
, to create code that "just works" for bothalice@example.com
andbob@example.com
. Defaults to the option named "gargle_oauth_email", retrieved bygargle_oauth_email()
.- path
JSON identifying the service account, in one of the forms supported for the
txt
argument ofjsonlite::fromJSON()
(typically, a file path or JSON string).- scopes
A character vector of scopes to request. Pick from those listed at https://developers.google.com/identity/protocols/oauth2/scopes.
For certain token flows, the
"https://www.googleapis.com/auth/userinfo.email"
scope is unconditionally included. This grants permission to retrieve the email address associated with a token; gargle uses this to index cached OAuth tokens. This grants no permission to view or send email and is generally considered a low-value scope.- cache
Specifies the OAuth token cache. Defaults to the option named
"gargle_oauth_cache"
, retrieved viagargle_oauth_cache()
.- use_oob
Whether to prefer out-of-band authentication. Defaults to the value returned by
gargle_oob_default()
.- token
A token with class Token2.0 or an object of httr's class
request
, i.e. a token that has been prepared withhttr::config()
and has a Token2.0 in theauth_token
component.
Details
Most users, most of the time, do not need to call trackdown_auth()
explicitly -- it is triggered by the first action that requires
authorization. Even when called, the default arguments often suffice.
However, when necessary, this function allows the user to explicitly:
Declare which Google identity to use, via an email address. If there are multiple cached tokens, this can clarify which one to use. It can also force trackdown to switch from one identity to another. If there's no cached token for the email, this triggers a return to the browser to choose the identity and give consent. You can specify just the domain by using a glob pattern. This means that a script containing
email = "*@example.com"
can be run without further tweaks on the machine of eitheralice@example.com
orbob@example.com
.Use a service account token or workload identity federation.
Bring their own Token2.0.
Specify non-default behavior re: token caching and out-of-bound authentication.
Customize scopes.
For details on the many ways to find a token, see
gargle::token_fetch()
. For deeper control over auth, use
trackdown_auth_configure()
to bring your own OAuth client or API key.
Read more about gargle options, see gargle::gargle_options.
See also
Other auth functions:
trackdown_auth_configure()
,
trackdown_deauth()
Examples
if (FALSE) {
# load/refresh existing credentials, if available
# otherwise, go to browser for authentication and authorization
trackdown_auth()
# see user associated with current token
trackdown_user()
# force use of a token associated with a specific email
trackdown_auth(email = "myemail@example.com")
trackdown_user()
# force a menu where you can choose from existing tokens or
# choose to get a new one
trackdown_auth(email = NA)
# use a 'read only' scope, so it's impossible to edit or delete files
# NOTE thaat this will allow only to download files from the drive
trackdown_auth(
scopes = "https://www.googleapis.com/auth/drive.readonly"
)
# use a service account token
trackdown_auth(path = "foofy-83ee9e7c9c48.json")
}