Travis build status version cranlogs cran checks Project Status: Active – The project has reached a stable, usable state and is being actively developed.

Simple and secure authentification mechanism for single ‘Shiny’ applications. Credentials are stored in an encrypted ‘SQLite’ database. Source code of main application is protected until authentication is successful.

Live demo:

You can authenticate with: * user: shiny / password: shiny * user: shinymanager / password: shinymanager (Admin)


Install from CRAN with :


Or install development version from GitHub :



Secure your Shiny app to control who can access it :

# define some credentials
credentials <- data.frame(
  user = c("shiny", "shinymanager"),
  password = c("azerty", "12345"),
  stringsAsFactors = FALSE


ui <- fluidPage(
  tags$h2("My secure application"),

# Wrap your UI with secure_app
ui <- secure_app(ui)

server <- function(input, output, session) {
  # call the server part
  # check_credentials returns a function to authenticate users
  res_auth <- secure_server(
    check_credentials = check_credentials(credentials)
  output$auth_output <- renderPrint({
  # your classic server logic

shinyApp(ui, server)

Starting page of the application will be :

Once logged, the application will be launched and a button added to navigate between the app and the admin panel (if user is authorized to access it), and to logout from the application :

Admin mode

An admin mode is available to manage access to the application, features included are

HTTP request

shinymanager use http request and sha256 tokens to grant access to the application, like this the source code is protected without having the need to change your UI or server code.

Secure database

Store your credentials data in SQL database protected with a symmetric AES encryption from openssl :

# Credentials data
credentials <- data.frame(
  user = c("shiny", "shinymanager"),
  password = c("azerty", "12345"),
  stringsAsFactors = FALSE

# you can use keyring package to set database key
key_set("R-shinymanager-key", "obiwankenobi")

# Create the database
  credentials_data = credentials,
  sqlite_path = "path/to/database.sqlite", # will be created
  passphrase = key_get("R-shinymanager-key", "obiwankenobi")

About security

The credentials database is secured with a pass phrase and the openssl package. If you have concern about method we use, please fill an issue.

Package shinyauthr provides a nice shiny module to add an authentication layer to your shiny apps.