Title: | A Simple HTTP Server to Serve Static Files or Dynamic Documents |
---|---|
Description: | Start an HTTP server in R to serve static files, or dynamic documents that can be converted to HTML files (e.g., R Markdown) under a given directory. |
Authors: | Yihui Xie [aut, cre] , Carson Sievert [ctb], Jesse Anderson [ctb], Ramnath Vaidyanathan [ctb], Romain Lesur [ctb], Posit Software, PBC [cph, fnd] |
Maintainer: | Yihui Xie <[email protected]> |
License: | GPL |
Version: | 0.32.1 |
Built: | 2024-12-03 05:27:03 UTC |
Source: | https://github.com/yihui/servr |
Combine usernames with passwords with colons, and generate base64-encoded strings to be used for user authentication.
auth_basic(user, password)
auth_basic(user, password)
user |
A vector of usernames. |
password |
A vector of passwords. |
A character vector of encoded credentials.
servr::auth_basic("foo", "B@R")
servr::auth_basic("foo", "B@R")
If you have launched a page in the browser via servr but closed it later, you may call this function to reopen it.
browse_last(open = TRUE)
browse_last(open = TRUE)
open |
Whether to reopen the lastly browsed page. If |
servr::browse_last()
servr::browse_last()
Create a server with a custom handler to handle the HTTP request.
create_server(..., handler, ws_open = function(ws) NULL)
create_server(..., handler, ws_open = function(ws) NULL)
... |
Arguments to be passed to |
handler |
A function that takes the HTTP request and returns a response. |
ws_open |
A function to be called back when a WebSocket connection is
established (see |
# always return 'Success:' followed by the requested path s = servr::create_server(handler = function(req) { list(status = 200L, body = paste("Success:", req$PATH_INFO)) }) s$url browseURL(paste0(s$url, "/hello")) browseURL(paste0(s$url, "/world")) s$stop_server()
# always return 'Success:' followed by the requested path s = servr::create_server(handler = function(req) { list(status = 200L, body = paste("Success:", req$PATH_INFO)) }) s$url browseURL(paste0(s$url, "/hello")) browseURL(paste0(s$url, "/world")) s$stop_server()
daemon_list()
returns IDs of servers, which can be used to stop the
daemonized servers.
daemon_stop(which = daemon_list()) daemon_list()
daemon_stop(which = daemon_list()) daemon_list()
which |
A integer vector of the server IDs; by default, IDs of all
existing servers in the current R session obtained from
|
The function daemon_list()
returns a list of existing server
IDs, and daemon_stop()
returns an invisible NULL
.
If there is an ‘index.html’ under this directory, it will be displayed; otherwise the list of files is displayed, with links on their names. After we run this function, we can go to ‘http://localhost:port’ to browse the web pages either created from R or read from HTML files.
httd(dir = ".", ..., response = NULL) httr(dir = ".", ...) httw( dir = ".", watch = ".", pattern = NULL, all_files = FALSE, filter = NULL, handler = NULL, ... )
httd(dir = ".", ..., response = NULL) httr(dir = ".", ...) httw( dir = ".", watch = ".", pattern = NULL, all_files = FALSE, filter = NULL, handler = NULL, ... )
dir |
The root directory to serve. |
... |
Server configurations passed to |
response |
A function of the form |
watch |
A directory under which |
pattern |
A regular expression passed to |
all_files |
Whether to watch all files including the hidden files. |
filter |
A function to filter the file paths returned from
|
handler |
A function to be called every time any files are changed or added under the directory; its argument is a character vector of the filenames of the files modified or added. |
httd()
is a static file server by default (its response
argument can turn it into a dynamic file server).
httr()
is based on httd()
with a custom
response
function that executes R files via xfun::record()
,
so that you will see the output of an R script as an HTML page. The page
will be automatically updated when the R script is modified and saved.
httw()
is similar to httd()
but watches for changes
under the directory: if an HTML file is being viewed in the browser, and
any files are modified under the directory, the HTML page will be
automatically refreshed.
https://github.com/yihui/servr
servr::httd()
servr::httd()
R Markdown documents (with the filename extension ‘.Rmd’) are re-compiled using knitr or rmarkdown when necessary (source files are newer than output files), and the HTML pages will be automatically refreshed in the web browser accordingly.
jekyll( dir = ".", input = c(".", "_source", "_posts"), output = c(".", "_posts", "_posts"), script = c("Makefile", "build.R"), serve = TRUE, command = "jekyll build", ... ) rmdv2(dir = ".", script = c("Makefile", "build.R"), in_session = FALSE, ...) rmdv1(dir = ".", script = c("Makefile", "build.R"), in_session = FALSE, ...)
jekyll( dir = ".", input = c(".", "_source", "_posts"), output = c(".", "_posts", "_posts"), script = c("Makefile", "build.R"), serve = TRUE, command = "jekyll build", ... ) rmdv2(dir = ".", script = c("Makefile", "build.R"), in_session = FALSE, ...) rmdv1(dir = ".", script = c("Makefile", "build.R"), in_session = FALSE, ...)
dir |
the root directory of the website |
input |
the input directories that contain R Markdown documents (the
directories must be relative instead of absolute; same for |
output |
the output directories corresponding to |
script |
a Makefile (see |
serve |
whether to serve the website; if |
command |
a command to build the Jekyll website; by default, it is
|
... |
Server configurations passed to |
in_session |
whether to render the R Markdown documents in the current R
session ( |
The function jekyll()
sets up a web server to serve a Jekyll-based
website. A connection is established between R and the HTML pages through
WebSockets so that R can notify the HTML pages to refresh themselves if any R
Markdown documents have been re-compiled.
The functions rmdv1()
and rmdv2()
are similar to
jekyll()
, and the only difference is the way to compile R Markdown
documents: rmdv1()
uses the markdown package (a.k.a R Markdown
v1) via knit2html()
, and rmdv2()
calls
render()
in the rmarkdown package (a.k.a R
Markdown v2).
Apparently jekyll()
and rmdv1()
require the knitr
package, and rmdv2()
requires rmarkdown. You have to install
them before calling the server functions here.
All R Markdown documents are compiled in separate R sessions by default. If you have any R Markdown documents that should not be compiled as standalone documents (e.g. child documents), you can use different filename extensions, such as ‘.Rmarkdown’.
The baseurl
argument does not work in jekyll()
, and the base
URL setting will be read from ‘_config.yml’ (the ‘baseurl’ field)
of the website if present. You should not pass baseurl
to the
function jekyll()
directly.
For the sake of reproducibility, you are recommended to compile each
source document in a separate R session (i.e., use the default
in_session = FALSE
) to make sure they can compile on their own,
otherwise the current workspace may affect the evaluation of the code
chunks in these source documents. Sometimes it might be useful to compile a
document in the current R session. For example, if reading data is
time-consuming and it is not convenient to cache it (using the knitr
chunk option cache = TRUE
), you may read the data once, temporarily
turn off the evaluation of that code chunk, and keep on working on the rest
of code chunks so that data will not be read over and over again.
R Markdown v1: https://cran.r-project.org/package=markdown. R
Markdown v2: https://rmarkdown.rstudio.com. For Jekyll, see
https://jekyllrb.com. The GitHub repository
https://github.com/yihui/blogdown-jekyll is an example of serving Jekyll
websites with servr::jekyll()
.
The blogdown package (based on Hugo and R Markdown v2) is a better alternative to Jekyll: https://github.com/rstudio/blogdown/. I strongly recommend you to try it.
if (interactive()) servr::rmdv1() # serve the current dir with R Markdown v1 if (interactive()) servr::rmdv2() # or R Markdown v2 # built-in examples servr::serve_example("rmd", servr::rmdv1) servr::serve_example("rmd", servr::rmdv2)
if (interactive()) servr::rmdv1() # serve the current dir with R Markdown v1 if (interactive()) servr::rmdv2() # or R Markdown v2 # built-in examples servr::serve_example("rmd", servr::rmdv1) servr::serve_example("rmd", servr::rmdv2)
You can define how and when to rebuild files (such as R Markdown files) using
Make rules, e.g. a rule _posts/%.md: _source/%.Rmd
with a command
to build ‘.Rmd’ to ‘.md’ will be executed if and only if
‘foo.Rmd’ is newer than ‘foo.md’. The exit status of the command
make -q
will decide whether to rebuild files: rebuilding occurs
only when the exit code is not 0
. When an HTML file has been rebuilt,
it will be automatically refreshed in the web browser.
make(dir = ".", ...)
make(dir = ".", ...)
dir |
The root directory to serve. |
... |
Server configurations passed to |
You must have installed GNU Make to use this function. This is normally not a problem for Linux and OS X users (it should be available by default). For Windows users, you can either install GNU Make, or just install Rtools, which also contains GNU Make.
# some built-in examples (if you are not familiar with make, you can take a # look at the Makefile of each example) servr::serve_example("make1", servr::make) servr::serve_example("make2", servr::make)
# some built-in examples (if you are not familiar with make, you can take a # look at the Makefile of each example) servr::serve_example("make1", servr::make) servr::serve_example("make2", servr::make)
Test a series of random TCP ports from 3000 to 8000 (excluding a few that are considered unsafe by Chrome) and return the first available one. A web server can be later started on this port.
random_port( port = 4321L, host = getOption("servr.host", "127.0.0.1"), n = 20, exclude = NULL )
random_port( port = 4321L, host = getOption("servr.host", "127.0.0.1"), n = 20, exclude = NULL )
port |
The preferred port(s). |
host |
A string that is a valid IPv4 address that is owned by this
server, or |
n |
The maximum number of random ports to be tested. |
exclude |
A vector of port numbers not to be considered. |
A port number, or an error if no ports are available.
Create a response to redirect to a destination.
redirect(dest, status = 301L)
redirect(dest, status = 301L)
dest |
A destination path. |
status |
The status code (usually |
servr::redirect("https://www.r-project.org")
servr::redirect("https://www.r-project.org")
Use server functions to serve built-in examples of this package.
serve_example(name, FUN, ..., run = interactive())
serve_example(name, FUN, ..., run = interactive())
name |
the directory name of the example under the directory
|
FUN |
a server function that takes the example path as its first
argument, e.g. |
... |
other arguments passed to |
run |
whether to run the example (this is mainly for |
NULL
if run = FALSE
, otherwise the value returned from
FUN()
.
# R Markdown v1 or v2 servr::serve_example("rmd", servr::rmdv1) servr::serve_example("rmd", servr::rmdv2) # GNU Make servr::serve_example("make1", servr::make) servr::serve_example("make2", servr::make)
# R Markdown v1 or v2 servr::serve_example("rmd", servr::rmdv1) servr::serve_example("rmd", servr::rmdv2) # GNU Make servr::serve_example("make1", servr::make) servr::serve_example("make2", servr::make)
The server functions in this package are configured through this function.
server_config( dir = ".", host = getOption("servr.host", "127.0.0.1"), port, browser, daemon, interval = getOption("servr.interval", 1), baseurl = "", initpath = "", hosturl = identity, auth = getOption("servr.auth"), verbose = TRUE )
server_config( dir = ".", host = getOption("servr.host", "127.0.0.1"), port, browser, daemon, interval = getOption("servr.interval", 1), baseurl = "", initpath = "", hosturl = identity, auth = getOption("servr.auth"), verbose = TRUE )
dir |
The root directory to serve. |
host |
A string that is a valid IPv4 address that is owned by this
server, or |
port |
The TCP port number. If it is not explicitly set, the default
value will be looked up in this order: First, the command line argument of
the form |
browser |
Whether to launch the default web browser. By default, it is
|
daemon |
Whether to launch a daemonized server (the server does not
block the current R session) or a blocking server. By default, it is the
global option |
interval |
The time interval used to check if an HTML page needs to be rebuilt (by default, it is checked every second). |
baseurl |
The base URL (the full URL will be
|
initpath |
The initial path in the URL (e.g. you can open a specific HTML file initially). |
hosturl |
A function that takes the host address and returns a character
string to be used in the URL, e.g., |
auth |
A list of the form |
verbose |
Whether to print messages when launching the server. |
A list of configuration information of the form list(host,
port, start_server = function(app) {}, ...)
.
# an example of authentication servr::httd(auth = list(scheme = "Basic", creds = servr::auth_basic("john", "pa$s!")))
# an example of authentication servr::httd(auth = list(scheme = "Basic", creds = servr::auth_basic("john", "pa$s!")))
Serve package vignettes under the ‘vignettes/’ directory. Because the HTML output files should not be included in the source package, this function renders R Markdown/HTML vignettes, displays them in the web browser, and deletes the HTML output files. You will see the HTML output when you click the links on the ‘.Rmd’ or ‘.Rhtml’ files (unlike the static HTTP server, the compiled output instead of the source document is displayed).
vign(dir = ".", ...)
vign(dir = ".", ...)
dir |
The root directory to serve. |
... |
Server configurations passed to |
When developing R packages, you may want to preview your vignettes once in a
while. You can certainly click the button in RStudio to do it, but that
requires you to install the package and rebuild the vignettes. With this
function, your vignette will be rebuilt automatically when you update the
source document. Moreover, because the compilation takes place in the current
R session, you can take advantage of devtools::load_all()
(which has a
keyboard shortcut in the RStudio IDE) to reload your package and see the
updated vignette in the web browser.
You are supposed to call this function from the root directory of your
package. If that is not the case, you should provide the correct path to
the ‘vignettes/’ directory of your package to the dir
argument.