1
0
Fork 0
mirror of https://github.com/sensebox/opensensmapr synced 2025-10-24 22:50:41 +02:00

no download progress for non-interactive sessions

also add option to disable progress info manually to
- osem_measurements()
- osem_boxes()

fixes #11
This commit is contained in:
Norwin 2018-01-05 00:03:04 +01:00
parent 185f668ca8
commit 628825c7f4
Signed by: norwin
GPG key ID: 24BC059DE24C43A3
6 changed files with 39 additions and 15 deletions

View file

@ -25,3 +25,11 @@ dplyr_class_wrapper = function(callback) {
function(.data, ..., .dots) callback(NextMethod()) function(.data, ..., .dots) callback(NextMethod())
} }
#' Checks for an interactive session using interactive() and a knitr process in
#' the callstack. See https://stackoverflow.com/a/33108841
#'
#' @noRd
isNonInteractive = function () {
ff <- sapply(sys.calls(), function(f) as.character(f[1]))
any(ff %in% c("knit2html", "render")) || !interactive()
}

10
R/api.R
View file

@ -22,7 +22,7 @@ get_boxes_ = function (..., endpoint) {
} }
get_box_ = function (boxId, endpoint) { get_box_ = function (boxId, endpoint) {
osem_request_(endpoint, path = c('boxes', boxId)) %>% osem_request_(endpoint, path = c('boxes', boxId), progress = F) %>%
parse_senseboxdata() parse_senseboxdata()
} }
@ -46,14 +46,14 @@ get_measurements_ = function (..., endpoint) {
} }
get_stats_ = function (endpoint) { get_stats_ = function (endpoint) {
result = osem_request_(endpoint, path = c('stats')) result = osem_request_(endpoint, path = c('stats'), progress = F)
names(result) = c('boxes', 'measurements', 'measurements_per_minute') names(result) = c('boxes', 'measurements', 'measurements_per_minute')
result result
} }
osem_request_ = function (host, path, ..., type = 'parsed') { osem_request_ = function (host, path, ..., type = 'parsed', progress) {
res = httr::GET(host, httr::progress(), path = path, query = list(...)) progress = if (progress && !isNonInteractive()) httr::progress() else NULL
#print(res$url) res = httr::GET(host, progress, path = path, query = list(...))
if (httr::http_error(res)) { if (httr::http_error(res)) {
content = httr::content(res, 'parsed', encoding = 'UTF-8') content = httr::content(res, 'parsed', encoding = 'UTF-8')

View file

@ -19,6 +19,7 @@
#' @param phenomenon Only return boxes that measured the given phenomenon in the #' @param phenomenon Only return boxes that measured the given phenomenon in the
#' time interval as specified through \code{date} or \code{from / to} #' time interval as specified through \code{date} or \code{from / to}
#' @param endpoint The URL of the openSenseMap API instance #' @param endpoint The URL of the openSenseMap API instance
#' @param progress Whether to print download progress information
#' @return A \code{sensebox data.frame} containing a box in each row #' @return A \code{sensebox data.frame} containing a box in each row
#' #'
#' @seealso \href{https://docs.opensensemap.org/#api-Measurements-findAllBoxes}{openSenseMap API documentation (web)} #' @seealso \href{https://docs.opensensemap.org/#api-Measurements-findAllBoxes}{openSenseMap API documentation (web)}
@ -37,7 +38,8 @@
#' #'
osem_boxes = function (exposure = NA, model = NA, grouptag = NA, osem_boxes = function (exposure = NA, model = NA, grouptag = NA,
date = NA, from = NA, to = NA, phenomenon = NA, date = NA, from = NA, to = NA, phenomenon = NA,
endpoint = 'https://api.opensensemap.org') { endpoint = 'https://api.opensensemap.org',
progress = T) {
# error, if phenomenon, but no time given # error, if phenomenon, but no time given
if (!is.na(phenomenon) && is.na(date) && is.na(to) && is.na(from)) if (!is.na(phenomenon) && is.na(date) && is.na(to) && is.na(from))
@ -55,7 +57,7 @@ osem_boxes = function (exposure = NA, model = NA, grouptag = NA,
stop('Parameter "from"/"to" must be used together') stop('Parameter "from"/"to" must be used together')
} }
query = list(endpoint = endpoint) query = list(endpoint = endpoint, progress = progress)
if (!is.na(exposure)) query$exposure = exposure if (!is.na(exposure)) query$exposure = exposure
if (!is.na(model)) query$model = model if (!is.na(model)) query$model = model
if (!is.na(grouptag)) query$grouptag = grouptag if (!is.na(grouptag)) query$grouptag = grouptag

View file

@ -20,6 +20,7 @@
#' @param to A \code{POSIXt} like object to select a time interval #' @param to A \code{POSIXt} like object to select a time interval
#' @param columns Select specific column in the output (see oSeM documentation) #' @param columns Select specific column in the output (see oSeM documentation)
#' @param endpoint The URL of the openSenseMap API #' @param endpoint The URL of the openSenseMap API
#' @param progress Whether to print download progress information
#' #'
#' @return An \code{osem_measurements data.frame} containing the #' @return An \code{osem_measurements data.frame} containing the
#' requested measurements #' requested measurements
@ -60,7 +61,8 @@ osem_measurements.default = function (x, ...) {
osem_measurements.bbox = function (x, phenomenon, exposure = NA, osem_measurements.bbox = function (x, phenomenon, exposure = NA,
from = NA, to = NA, columns = NA, from = NA, to = NA, columns = NA,
..., ...,
endpoint = 'https://api.opensensemap.org') { endpoint = 'https://api.opensensemap.org',
progress = T) {
bbox = x bbox = x
environment() %>% environment() %>%
as.list() %>% as.list() %>%
@ -84,7 +86,8 @@ osem_measurements.bbox = function (x, phenomenon, exposure = NA,
osem_measurements.sensebox = function (x, phenomenon, exposure = NA, osem_measurements.sensebox = function (x, phenomenon, exposure = NA,
from = NA, to = NA, columns = NA, from = NA, to = NA, columns = NA,
..., ...,
endpoint = 'https://api.opensensemap.org') { endpoint = 'https://api.opensensemap.org',
progress = T) {
boxes = x boxes = x
environment() %>% environment() %>%
as.list() %>% as.list() %>%
@ -113,7 +116,11 @@ parse_get_measurements_params = function (params) {
(is.null(params$bbox) && is.null(params$boxes)) (is.null(params$bbox) && is.null(params$boxes))
) stop('Specify either "bbox" or "boxes"') ) stop('Specify either "bbox" or "boxes"')
query = list(endpoint = params$endpoint, phenomenon = params$phenomenon) query = list(
endpoint = params$endpoint,
phenomenon = params$phenomenon,
progress = params$progress
)
if (!is.null(params$boxes)) query$boxId = paste(params$boxes$X_id, collapse = ',') if (!is.null(params$boxes)) query$boxId = paste(params$boxes$X_id, collapse = ',')
if (!is.null(params$bbox)) query$bbox = paste(params$bbox, collapse = ',') if (!is.null(params$bbox)) query$bbox = paste(params$bbox, collapse = ',')
@ -154,8 +161,10 @@ paged_measurements_req = function (query) {
query$`from-date` = date_as_isostring(page$from) query$`from-date` = date_as_isostring(page$from)
query$`to-date` = date_as_isostring(page$to) query$`to-date` = date_as_isostring(page$to)
res = do.call(get_measurements_, query) res = do.call(get_measurements_, query)
cat(paste(query$`from-date`, query$`to-date`, sep = ' - '))
cat('\n') if (query$progress && !isNonInteractive())
cat(paste(query$`from-date`, query$`to-date`, sep = ' - '), '\n')
res res
}) %>% }) %>%
dplyr::bind_rows() dplyr::bind_rows()

View file

@ -6,7 +6,7 @@
\usage{ \usage{
osem_boxes(exposure = NA, model = NA, grouptag = NA, date = NA, osem_boxes(exposure = NA, model = NA, grouptag = NA, date = NA,
from = NA, to = NA, phenomenon = NA, from = NA, to = NA, phenomenon = NA,
endpoint = "https://api.opensensemap.org") endpoint = "https://api.opensensemap.org", progress = T)
} }
\arguments{ \arguments{
\item{exposure}{Only return boxes with the given exposure ('indoor', 'outdoor', 'mobile')} \item{exposure}{Only return boxes with the given exposure ('indoor', 'outdoor', 'mobile')}
@ -25,6 +25,8 @@ osem_boxes(exposure = NA, model = NA, grouptag = NA, date = NA,
time interval as specified through \code{date} or \code{from / to}} time interval as specified through \code{date} or \code{from / to}}
\item{endpoint}{The URL of the openSenseMap API instance} \item{endpoint}{The URL of the openSenseMap API instance}
\item{progress}{Whether to print download progress information}
} }
\value{ \value{
A \code{sensebox data.frame} containing a box in each row A \code{sensebox data.frame} containing a box in each row

View file

@ -12,11 +12,12 @@ osem_measurements(x, ...)
\method{osem_measurements}{default}(x, ...) \method{osem_measurements}{default}(x, ...)
\method{osem_measurements}{bbox}(x, phenomenon, exposure = NA, from = NA, \method{osem_measurements}{bbox}(x, phenomenon, exposure = NA, from = NA,
to = NA, columns = NA, ..., endpoint = "https://api.opensensemap.org") to = NA, columns = NA, ..., endpoint = "https://api.opensensemap.org",
progress = T)
\method{osem_measurements}{sensebox}(x, phenomenon, exposure = NA, \method{osem_measurements}{sensebox}(x, phenomenon, exposure = NA,
from = NA, to = NA, columns = NA, ..., from = NA, to = NA, columns = NA, ...,
endpoint = "https://api.opensensemap.org") endpoint = "https://api.opensensemap.org", progress = T)
} }
\arguments{ \arguments{
\item{x}{Depending on the method, either \item{x}{Depending on the method, either
@ -40,6 +41,8 @@ osem_measurements(x, ...)
\item{columns}{Select specific column in the output (see oSeM documentation)} \item{columns}{Select specific column in the output (see oSeM documentation)}
\item{endpoint}{The URL of the openSenseMap API} \item{endpoint}{The URL of the openSenseMap API}
\item{progress}{Whether to print download progress information}
} }
\value{ \value{
An \code{osem_measurements data.frame} containing the An \code{osem_measurements data.frame} containing the