inst/endpoints/api.R

#---------------------------------------------#
# DO NOT EDIT THIS FILE OR ADD ANYTHING TO IT #
#---------------------------------------------#

# Importing internal shiny function
http_response <- utils::getFromNamespace("httpResponse", "shiny")

#' Retrieve the Default Serialiser
#' 
#' Retrieves the `LEPRECHAUN_SERIALISER` option,
#' if not defined, it returns `default_json_serialiser`.
#' 
#' @keywords internal
get_json_serialiser <- function(){
	getOption("LEPRECHAUN_SERIALISER", default_json_serialiser)
}

#' Default Serialiser
#' 
#' Default serialiser used by leprechaun.
#' To change this serialiser set the
#' `LEPRECHAUN_SERLIASER` option to the function
#' you want to use. This function must accept a
#' single argument, the dataset to serialise.
#' 
#' @param data Dataset to serialise.
#' 
#' @importFrom jsonlite toJSON
#' 
#' @keywords internal
default_json_serialiser <- function(data){
	if(missing(data))
		stop("Missing data", call. = FALSE)
	
	toJSON(data, dataframe = "rows", auto_unbox = TRUE)
}

#' Return a JSON Response
#' 
#' Return a json response, used for `session$registerDataObj`.
#' 
#' @keywords internal
http_response_json <- function(content, headers = list()){
	serialise <- get_json_serialiser()

  http_response(
    content = serialise(content),
		status = 200L, 
    content_type = "application/json",
		headers = headers
  )
}

# create a random name for the endpoint
random_endpoint_name <- function(){
	paste0(sample(letters, 26), collapse = "")
}

#' Register an Endpoint
#' 
#' Register an endpoint to make data accessible from the
#' session's browser.
#' 
#' @param data Dataset to expose/reprocess by `fn`.
#' @param fn Function to preprocess `data`. This function
#' must accept 1) the `data` and 2) the `request` from
#' the browser. This function must return a response,
#' see [http_response_json].
#' @param session A valid shiny session object.
#' 
#' @keywords internal
register_endpoint <- function(
	data, 
	fn, 
	session = shiny::getDefaultReactiveDomain()
){
	session$registerDataObj(
		random_endpoint_name(),
		data,
		filterFunc = fn
	)
}

#' Register a JSON Endpoint
#' 
#' Register an endpoint to make data accessible from the
#' session's browser.
#' 
#' @param data Dataset to expose/reprocess by `fn`.
#' @param fn Function to preprocess `data`. This function
#' must accept 1) the `data` and 2) the `request` from
#' the browser. This function must return a dataset,
#' to serialise to JSON [http_response_json].
#' @param session A valid shiny session object.
#' 
#' @keywords internal
register_endpoint_json <- function(
	data, 
	fn, 
	session = shiny::getDefaultReactiveDomain()
){
	fun <- function(data, req){
		data <- fn(data, req)
		http_response_json(data)
	}

	session$registerDataObj(
		random_endpoint_name(),
		data,
		filterFunc = fun
	)
}

#---------------------------------------------#
# DO NOT EDIT THIS FILE OR ADD ANYTHING TO IT #
#---------------------------------------------#

Try the leprechaun package in your browser

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

leprechaun documentation built on Jan. 19, 2022, 5:08 p.m.