R/BiodbUrl.R

#' Class URL.
#'
#' This class represents a URL object that can be used in requests.
#'
#' @seealso \code{\link{BiodbRequestScheduler}}, \code{\link{BiodbRequest}}.
#'
#' @examples
#' # Create a URL object
#' u <- c("https://www.uniprot.org", "uniprot")
#' p <- c(query="reviewed:yes+AND+organism:9606",
#'        columns='id,entry name,protein names',
#'        format="tab")
#' url <- BiodbUrl$new(url=u, params=p)
#' url$toString()
#'
#' @import R6
#' @export
BiodbUrl <- R6::R6Class("BiodbUrl",

public=list(

#' @description
#' Initializer.
#' @param url The URL to access, as a character vector.
#' @param params The list of parameters to append to this URL.
#' @param chompExtraSlashes If set to TRUE, then slashes at the end and the
#' beginning of each element of the url vector parameter will be removed before
#' proper concatenation.
#' @return Nothing.
initialize=function(url=character(), params=character(),
    chompExtraSlashes=TRUE) {

    chk::chk_character(url)
    chk::chk_not_any_na(url)
    chk::chk_flag(chompExtraSlashes)
    # params is not necessarily named, and may contain strings as well as
    # numbers. TODO How to test its content?
    #chk::chk_named(params)

    private$url <- url
    private$chompExtraSlashes <- chompExtraSlashes

    # Set parameters
    if (is.list(params))
        params <- unlist(params)
    if ( ! is.character(params)) {
        names <- names(params)
        params <- as.character(params)
        names(params) <- names
    }
    private$params <- params

    return(invisible(NULL))
},

#' @description
#' Gets the domain.
#' @return The domain.
getDomain=function() {

    domain <- sub('^.+://([^/]+)(/.*)?$', '\\1', private$url[[1]], perl=TRUE)

    return(domain)
},

#' @description
#' Sets the base URL string.
#' @param url The base URL string.
#' @return Nothing.
setUrl=function(url) {

    private$url <- url

    return(invisible(NULL))
},

#' @description
#' Sets a parameter.
#' @param key The parameter name. 
#' @param value  The value of the parameter.
#' @return Nothing.
setParam=function(key, value) {

    private$params[[key]] <- value

    return(invisible(NULL))
},

#' @description
#' Displays information about this instance.
#' @return self as invisible. 
print=function() {
    cat(self$toString(), "\n", sep='')
    return(invisible(self))
},

#' @description
#' Gets the URL as a string representation.
#' @param encode If set to TRUE, then encodes the URL.
#' @return The URL as a string, with all parameters and values set.
toString=function(encode=TRUE) {

    u <- private$url

    # Remove '/' at start and end of each element of the URL
    if (private$chompExtraSlashes)
        u <- gsub('^/*([^/].*[^/])/*$', '\\1', u)

    # Concatenate URL elements together
    u <- paste(u, collapse='/')
    
    # Encode URL part
    if (encode)
        u <- utils::URLencode(u)

    # Add parameters to URL
    if (length(private$params) > 0) {

        pn <- names(private$params)
        pv <- unname(private$params)

        # Build parameters string
        fct <- function(i) {
            if (is.null(pn) || nchar(pn[[i]]) == 0)
                if (encode) utils::URLencode(pv[[i]], reserved=TRUE) else
                    pv[[i]]
            else
                if (encode) paste(utils::URLencode(pn[[i]], reserved=TRUE),
                    utils::URLencode(pv[[i]], reserved=TRUE),
                    sep='=') else paste(pn[[i]], pv[[i]], sep='=')
        }
        kv.list <- vapply(seq_along(pv), fct, FUN.VALUE='')
        params.str <- paste(kv.list, collapse='&')

        # Concatenate URL with parameters
        u <- paste(u, params.str, sep='?')
    }

    return(u)
}
),

private=list(
    url=NULL,
    params=NULL,
    chompExtraSlashes=NULL
))
pkrog/biodb documentation built on Nov. 29, 2022, 4:24 a.m.