R/find-requester.R

Defines functions get_current_requester requester_from_packages default_requester set_requester

Documented in get_current_requester set_requester

#' Set a request preprocessor
#'
#' @param FUN A function or expression that modifies `request` objects.
#' Specifically, a valid input is one of:
#' * A function taking a single argument, the `request`, and returning a valid
#' `request` object.
#' * A formula as shorthand for an anonymous function with `.` as the
#' "request" argument, as in the `purrr` package.
#' * A list of functions/formulas, which will be executed
#' in sequence on the request.
#' * `NULL`, to override the default `redact_auth()`.
#' @return Invisibly, `FUN`, validated and perhaps modified.
#' @export
#' @seealso [set_redactor()]
set_requester <- function(FUN) {
  FUN <- prepare_redactor(FUN)
  options(
    httptest.requester = FUN,
    # Because we're directly setting a redactor, remove any record that
    # a previous redactor was set by reading from packages
    httptest.requester.packages = NULL
  )
  invisible(FUN)
}

default_requester <- function(packages = get_attached_packages()) {
  # Look for package-defined requesters
  func <- requester_from_packages(packages)
  # Record what packages we considered here
  options(httptest.requester.packages = packages)
  return(func)
}

requester_from_packages <- function(packages) {
  funcs <- find_package_functions(packages, "request.R")
  if (length(funcs)) {
    out <- prepare_redactor(funcs)
  } else {
    # Default
    out <- force
  }
  return(out)
}

#' Fetch the active requesting function
#'
#' Called inside [capture_requests()]. If using the default requester, it checks
#' each time it is called to see if any new packages have been attached, in case
#' there are package requesters in them.
#' @return A requesting function.
#' @export
#' @keywords internal
#' @seealso [get_current_redactor()]
get_current_requester <- function() {
  # First, check where we've cached the current one
  out <- getOption("httptest.requester")
  if (is.null(out)) {
    # Set the default
    out <- default_requester()
    options(httptest.requester = out)
  } else {
    # See if default is based on packages and needs refreshing
    pkgs <- getOption("httptest.requester.packages")
    if (!is.null(pkgs)) {
      # We're using the result of default_requester(). Let's see if any
      # new packages have been loaded
      current_packages <- get_attached_packages()
      if (!identical(current_packages, pkgs)) {
        # Re-evaluate
        out <- default_requester(current_packages)
        options(httptest.requester = out)
      }
    }
  }
  return(out)
}

Try the httptest package in your browser

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

httptest documentation built on July 9, 2023, 7:45 p.m.