Skip to content
format_request.R 1.2 KiB
Newer Older
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
#' API query for SDMX output
#'
#' @param url url to query
#'
#' @return dataframe response
sdmx_request <- function(url) {
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
  as.data.frame(rsdmx::readSDMX(url))
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
#' API query for JSON output
#'
#' @param url url to query
#'
#' @return response: dataframe or list of dataframes
json_request <- function(url) {
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
  jsonlite::fromJSON(rawToChar(httr::GET(url)$content))
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
#' API query for CSV output
#'
#' @param url url to query
#' @importFrom utils read.csv
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
#'
#' @return dataframe response
csv_request <- function(url) {
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
}

# Request function based on expected response
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
REQUEST_FUNCTION_MAPPING <- list(
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
  "SDMX-ML" = sdmx_request,
  "JSON" = json_request,
  "CSV" = csv_request
)
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
#' Transform a list into a string of parameters
#' list("a" = list("1"), "b" = list("2", "3"))
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
#' becomes "a=1&b=2&b=3"
#' @param filters named list
#'
#' @return formatted string of parameters
Pauline Maury Laribière's avatar
Pauline Maury Laribière committed
list_to_string <- function(filters) {
  string <- ""
  for (prop in ls(filters)) {
    for (value in filters[[prop]]) {
      if (string == "") {
        string <- glue::glue("{prop}={value}")
      } else {
        string <- paste(string, glue::glue("{prop}={value}"), sep = "&")
      }
    }
  }
  string