R/google_analytics.R

Defines functions queryGA

Documented in queryGA

####################################################################
#' Queries on Google Analytics
#'
#' This function lets the user query Google Analytics with its API.
#' More about the documentation and parameters in
#' \code{googleAnalyticsR::google_analytics()} or Google Analytics'
#' \href{https://ga-dev-tools.appspot.com/dimensions-metrics-explorer/}{API}
#'
#' @family Credentials
#' @family Google
#' @family API
#' @param account Character. Personal named accounts
#' @param creds Character. Credential's user (see \code{get_creds()})
#' @param token_dir Character. Credential's directory (see \code{get_creds()})
#' @param metrics Character. Which metrics we wish to bring
#' @param dimensions Character. Which dimensions we wish to bring
#' @param met_filters,dim_filters A \code{filter_clause_ga4} for filtering
#' metrics/dimensions. Check \code{googleAnalyticsR::google_analytics()}.
#' @param start Date. Start date for the report
#' @param end Date. End date for the report
#' @return data.frame with the API GET request tabulated results.
#' @export
queryGA <- function(account, creds = NA, token_dir = NA,
                    metrics = "sessions",
                    dimensions = "date",
                    met_filters = NULL,
                    dim_filters = NULL,
                    start = lubridate::floor_date(Sys.Date(), "month"),
                    end = Sys.Date()) {
  try_require("googleAnalyticsR")
  try_require("googleAuthR")

  # FIRST TIME
  # options(googleAuthR.scopes.selected = "https://www.googleapis.com/auth/analytics",
  #         googleAuthR.client_id = "XXX",
  #         googleAuthR.client_secret = "XXX")
  # gar_auth()

  account <- paste("google_analytics", account, sep = "_")
  vars <- get_credentials(from = account, dir = creds)
  options(
    "googleAuthR.scopes.selected" = "https://www.googleapis.com/auth/analytics",
    "googleAuthR.client_id" = vars$client_id,
    "googleAuthR.client_secret" = vars$client_secret
  )

  # Authenticate with local file
  if (!is.na(token_dir)) {
    token <- paste0(token_dir, "/", vars$token_name)
  } else {
    token <- vars$token_name
  }
  message(paste("Token:", token))
  gar_auth(token) # From googleAuthR

  # Query on Google Analytics
  google_analytics(
    vars$ga_id,
    date_range = c(start, end),
    metrics = metrics,
    dimensions = dimensions,
    met_filters = met_filters,
    dim_filters = dim_filters
  )
}

Try the lares package in your browser

Any scripts or data that you put into this service are public.

lares documentation built on Nov. 5, 2023, 1:09 a.m.