3 HttpRequest <- R6::R6Class(
9 validContentTypes = NULL,
12 initialize = function()
14 self$validContentTypes <- c("text", "raw")
15 self$validVerbs <- c("GET", "POST", "PUT", "DELETE", "PROPFIND", "MOVE")
18 execute = function(verb, url, headers = NULL, body = NULL, query = NULL,
19 limit = NULL, offset = NULL, retryTimes = 0)
21 if(!(verb %in% self$validVerbs))
22 stop("Http verb is not valid.")
24 headers <- httr::add_headers(unlist(headers))
25 urlQuery <- self$createQuery(query, limit, offset)
26 url <- paste0(url, urlQuery)
28 # times = 1 regular call + numberOfRetries
29 response <- httr::RETRY(verb, url = url, body = body,
30 config = headers, times = retryTimes + 1)
33 createQuery = function(filters, limit, offset)
37 finalQuery <- c(finalQuery, private$createFiltersQuery(filters))
38 finalQuery <- c(finalQuery, private$createLimitQuery(limit))
39 finalQuery <- c(finalQuery, private$createOffsetQuery(offset))
41 finalQuery <- finalQuery[!is.null(finalQuery)]
42 finalQuery <- paste0(finalQuery, collapse = "&")
45 finalQuery <- paste0("/?", finalQuery)
53 createFiltersQuery = function(filters)
57 filters <- RListToPythonList(filters, ",")
58 encodedQuery <- URLencode(filters, reserved = T, repeated = T)
60 return(paste0("filters=", encodedQuery))
66 createLimitQuery = function(limit)
70 limit <- suppressWarnings(as.numeric(limit))
73 stop("Limit must be a numeric type.")
75 return(paste0("limit=", limit))
81 createOffsetQuery = function(offset)
85 offset <- suppressWarnings(as.numeric(offset))
88 stop("Offset must be a numeric type.")
90 return(paste0("offset=", offset))