R/currency.R

Defines functions fetch_currency fetch_currency_info

Documented in fetch_currency fetch_currency_info

#' Fetches currency series from DataHub
#'
#' @param code the code of the currency series
#' @param source_code the source code of the currency series
#' @param query optional, availible list(from = yyyy-mm-dd, to = yyyy-mm-dd)
#'
#' @return dataframe \describe{
#'   \item{code}{currency code}
#'   \item{source_code}{source code}
#'   \item{date}{series date}
#'   \item{ask_rate}{currency ask rate if availible}
#'   \item{bid_rate}{currency bid rate if availible}
#'   \item{mid_rate}{currency mid rate}
#' }
#'
#' @examples
#' fetch_currency('DKK-ISK', 'SI')
#' fetch_currency('DKK-ISK', 'SI', query = list(from = '2019-01-01', to = '2019-02-01'))
#'
#' @export
fetch_currency <- function(code, source_code, query = list()) {

  # Check input arguments
  collection <- checkmate::makeAssertCollection()
  checkmate::assertString(code, na.ok = FALSE, min.chars = 1, add = collection)
  checkmate::assertString(source_code, na.ok = FALSE, min.chars = 1, add = collection)
  checkmate::assertList(query, add = collection)
  checkmate::reportAssertions(collection)

  # Create url
  url <- paste0(
    getOption("base_path", default = "https://api.datahub.is"),
    "/currency/",
    toupper(code),
    "/source/",
    toupper(source_code),
    "/rate")

  # Make API call and parse
  resp <- httr::GET(
    url,
    httr::add_headers("Authorization" = getOption("authentication_key", default = "")),
    httr::accept_json(),
    query = query)

  parsed <- jsonlite::fromJSON(httr::content(resp, "text", encoding = "UTF-8"))

  #* Stop if errors
  if (httr::http_error(resp)) {
    stop(
      sprintf(
        "DataHub API request failed [%s]\n%s\n<%s>",
        httr::status_code(resp),
        parsed$message,
        parsed$errors
      ),
      call. = FALSE
    )
  }

  tryCatch({
    parsed$date = as.Date(parsed$date)
    return(parsed)
  },
    error=function(error_message) {
      return(setNames(data.frame(matrix(ncol = 6, nrow = 0)), c("code", "source_code", "date", "ask_rate", "bid_rate", "mid_rate")))
  })
}


#' Fetches all available currencies
#'
#' @return dataframe \describe{
#'   \item{code}{currency code}
#'   \item{name}{currency name}
#'   \item{source_code}{source code}
#'   \item{source_name}{source name, use this for caption}
#'   \item{description}{description of this series}
#'   \item{last_update}{date this series was last updated}
#'   \item{usage}{code example on how to call for the dataseries}
#' }
#'
#' @examples
#' fetch_currnecy_info()
#' fetch_currency_info() %>%
#'    filter(stringr::str_detect(name, stringr::fixed('dönsk', ignore_case = T)))
#'
#' @export
fetch_currency_info <- function(.x = NULL) {
  # Create url
  url <- paste0(
    getOption("base_path", default = "https://api.datahub.is"),
    "/currency")

  # Make API call and parse
  resp <- httr::GET(
    url,
    httr::add_headers("Authorization" = getOption("authentication_key", default = "")),
    httr::accept_json())

  parsed <- jsonlite::fromJSON(httr::content(resp, "text", encoding = "UTF-8"))

  #* Stop if errors
  if (httr::http_error(resp)) {
    stop(
      sprintf(
        "DataHub API request failed [%s]\n%s\n<%s>",
        httr::status_code(resp),
        parsed$message,
        parsed$errors
      ),
      call. = FALSE
    )
  }

  parsed <- parsed %>%
    select(code, name, source_code, source_name, description, last_update) %>%
    mutate(usage = paste0("fetch_currency('", code, "','", source_code, "')"))

  if (is.data.frame(.x)) rbind(.x, parsed)
  else parsed
}
palmargisla/datahub-r documentation built on Sept. 18, 2019, 9:50 p.m.