R/rym_get_ga.R

Defines functions rym_get_ga

Documented in rym_get_ga

rym_get_ga <-
  function(start.date = "10daysAgo",
           end.date = "today",
           counter = NULL,
           dimensions = "ga:date,ga:sourceMedium",
           metrics = "ga:sessions,ga:bounces,ga:users",
           filters = NULL,
           sort = NULL,
           sampling.level = "HIGHER_PRECISION",
           login = getOption("rym.user"),
           token.path = getOption("rym.token_path")) {

    # check path
    if (is.null(token.path)) {
      token.path <- getwd()
    }

    # check args
    if (is.null(counter)) {
      stop("Argument counter is require!")
    }

    token <- rym_auth(login = login, token.path = token.path)$access_token

    # create df
    result <- data.frame(stringsAsFactors = F)

    # variables for offse
    max_results <- 4000
    start_index <- 1
    last_query <- FALSE

    packageStartupMessage("Processing", appendLF = F)

    while (last_query == FALSE) {

      # send query
      answer <- GET("https://api-metrika.yandex.ru/analytics/v3/data/ga",
        query = list(
          `start-date` = start.date,
          `end-date` = end.date,
          metrics = gsub("[\\s\\n\\t]", "", metrics, perl = TRUE),
          dimensions = gsub(" ", "", dimensions),
          filters = filters,
          sort = sort,
          samplingLevel = sampling.level,
          ids = counter,
          `max-results` = max_results,
          `start-index` = start_index
        ),
        add_headers(Authorization = paste0("OAuth ", token))
      )

      # parsing result
      rawData <- content(answer, "parsed", "application/json")

      # check result
      if (!is.null(rawData$error)) {
        stop(paste0(rawData$error$errors[[1]]$reason, " - ", rawData$error$errors[[1]]$message, ", location - ", rawData$error$errors[[1]]$location))
      }

      # get field names
      column_names <- unlist(lapply(rawData$columnHeader, function(x) {
        return(x$name)
      }))

      # get rows
      rows <- lapply(rawData$rows, function(x) {
        return(x)
      })
      for (rows_i in 1:length(rows)) {
        result <- rbind(result, unlist(rows[[rows_i]]))
      }
      # point
      packageStartupMessage(".", appendLF = F)
      # next page
      start_index <- start_index + max_results

      # last page or not
      if (rawData$totalResults < start_index) {
        last_query <- TRUE
      }
    }

    # col names
    colnames(result) <- column_names

    # data types change
    for (tape_i in 1:length(rawData$columnHeaders)) {
      if (rawData$columnHeaders[[tape_i]]$columnType == "METRIC") {
        result[, tape_i] <- as.numeric(result[, tape_i])
      }
    }

    # message
    packageStartupMessage("Done", appendLF = T)

    # total info
    if (rawData$containsSampledData == TRUE) {
      packageStartupMessage("You get data with sampling.", appendLF = T)
      packageStartupMessage(paste0("sample size on which the report is compiled: ", rawData$sampleSize), appendLF = T)
      packageStartupMessage(paste0("reportbuild on ", as.integer(rawData$sampleSize) / as.integer(rawData$sampleSpace) * 100, "% of all data"), appendLF = T)
      packageStartupMessage(paste0("Total results: ", rawData$totalResults), appendLF = T)
    } else {
      packageStartupMessage("Sampling was not used to collect data.", appendLF = T)
      packageStartupMessage(paste0("Total results: ", rawData$totalResults), appendLF = T)
    }
    # return result
    return(result)
  }

Try the rym package in your browser

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

rym documentation built on March 31, 2023, 10:31 p.m.