ShinyServicebot
This package integrates the servicebot payment ( stripe ) framework for R shiny
Install / Use
/learn @capiaas/ShinyServicebotREADME
ShinyServicebot <img src="man/figures/logo.png" align="right" width=120 height=139 alt="" />
shinyservicebot Create in-app purchasing and subscriptions through 'Servicebot' payment using the 'Stripe' framework.
What is Servicebot and Stripe
Servicebot
"Servicebot provides a user interface (UI) on top of Stripe. Stripe will remain the single source of truth for all things billing which makes Servicebot the easiest & fastest way to launch with Stripe."
Click here for more information about servicebot.
Stripe
Online payment processing for internet businesses. Stripe is a suite of payment APIs that powers commerce for online businesses
Click here for more information about stripe.
Installation
To install the stable version from CRAN, simply run the following from an R console:
install.packages("shinyservicebot")
To install the latest development builds directly from GitHub, run this instead:
if (!require("remotes")) install.packages("remotes")
remotes::install_github("capiaas/shinyservicebot")
Getting Started
To learn more we highly recommend you check out the servicebot docs. The site will explain in depths the setup of Servicebot.
Servicebot setup
- Setup Servicebot account: https://dashboard.servicebot.io/signup
- Available config parameters Click here.
In use
Initialize servicebot
Initialize servicebot by running the init command.
Development mode
# -------
# FOR DEVELOPMENT
# -------
shinyservicebot::init(dev_mode = TRUE)
Live mode
# -------
# FOR LIVE PRODUCTION
# -------
shinyservicebot::init(
servicebot_secret = "Your servicebot secret",
secure_setup = TRUE
)
Example: Pricing embed:
library(shinyservicebot)
# init servicebot pr user login
shinyservicebot::init(dev_mode = TRUE)
# Config
servicebot_config = list(
servicebot_id = "E0OQN0P0Dort", # // LIVE & TEST MODE IDs ARE DIFFERENT
service = "Flat Subscription",
email = "shinyservicebot36io3ejbyf1pea7g61mxki@yopmail.com"
)
# Render the shinyservoicebot pricing
shinyservicebot::shinyservicebotOutput("servicebot")

Example: Pricing embed in Shiny app
library(shiny)
library(shinyservicebot)
# init servicebot pr user login
shinyservicebot::init(dev_mode = TRUE)
# Config
servicebot_config = list(
servicebot_id = "E0OQN0P0Dort", # // LIVE & TEST MODE IDs ARE DIFFERENT
service = "Flat Subscription",
email = "shinyservicebot36io3ejbyf1pea7g61mxkh@yopmail.com"
)
# UI ----
ui <- fluidPage(
# App title ----
titlePanel("SERVICEBOT PRICING PAGE"),
shinyservicebot::shinyservicebotOutput("servicebot")
)
# SERVER ----
server <- function(input, output) {
output$servicebot <- shinyservicebot::renderShinyservicebot(
shinyservicebot::shinyservicebot(servicebot_config, width = "auto")
)
}
# Create Shiny app ----
shinyApp(ui = ui, server = server)

Example: Portal embed in Shiny app
library(shiny)
library(shinyservicebot)
# -------
# FOR LIVE PRODUCTION
# -------
# shinyservicebot::init(
# servicebot_secret = "Your servicebot secret",
# secure_setup = TRUE
# )
# -------
# FOR DEVELOPMENT
# -------
shinyservicebot::init(dev_mode = TRUE)
# Config
servicebot_config = list(
servicebot_id = "E0OQN0P0Dort", # // LIVE & TEST MODE IDs ARE DIFFERENT
service = "Flat Subscription",
email = "shinyservicebot36io3ejbyf1pea7g61mxki@yopmail.com",
options = list(
i18n = list(defaultLng = "en") # // SET DEFAULT LANGUAGE
)
)
# UI ----
ui <- fluidPage(
# App title ----
titlePanel("SERVICEBOT PORTAL PAGE"),
shinyservicebot::shinyservicebotOutput("servicebot")
)
# SERVER ----
server <- function(input, output) {
output$servicebot <- shinyservicebot::renderShinyservicebot(
shinyservicebot::shinyservicebot(servicebot_config, width = "auto")
)
}
# Create Shiny app ----
shinyApp(ui = ui, server = server)

Examples
You can run examples directly from the package
# Test pricing embed in shiny app
shinyservicebot::runPricingExample()
# Test portal embed in shiny app
shinyservicebot::runPortalExample()
# Test signup embed in shiny app
shinyservicebot::runSignupExample()
Disclaimer
This package is not affiliated with any of the service providers it supports.
Related Skills
node-connect
342.5kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
frontend-design
85.3kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
openai-whisper-api
342.5kTranscribe audio via OpenAI Audio Transcriptions API (Whisper).
qqbot-media
342.5kQQBot 富媒体收发能力。使用 <qqmedia> 标签,系统根据文件扩展名自动识别类型(图片/语音/视频/文件)。
