📦 Stlite Sandbox
Submitted by Lukas Masuch
Summary
Execute untrusted Streamlit code in a sandboxed environment.
Functions
sandbox
Execute untrusted Streamlit code in a sandboxed environment.
This function allows you to execute untrusted Streamlit code inside the user's web browser by using stlite (https://github.com/whitphx/stlite) instead of the App server. This is useful for apps that generate and execute Streamlit (or Python) code at runtime based on some user instructions. Doing this inside the main Streamlit app would be unsafe since the user could execute arbitrary code on the server.
There are a few limitations to this approach: * stlite does not support the full set of Streamlit features. See the stlite documentation for more details on limitations: https://github.com/whitphx/stlite#limitations * Since the code is executed inside the user's browser, it cannot access any files, session state, or other functionalities of the server. * The available compute resource depend on the user's machine. So, this is not suited for heavy computations.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
code |
str | Callable[[], None]
|
The code to execute. This can either be a string containing the code or a function. If a function is passed, the source code will be extracted automatically. The function is required to be fully self-contained and not reference any variables outside of its scope. |
required |
stlite_version |
str | None
|
The version of stlite to use. If None, the latest version will be used.. Defaults to None. |
None
|
requirements |
List[str] | None
|
A list of Python packages to install before executing the code. If None, the following packages will be installed: pandas, numpy, plotly, altair. |
None
|
height |
int
|
The height of the embedded app in pixels. Defaults to 700. |
700
|
scrolling |
bool
|
Whether to allow scrolling inside the embedded app. Defaults to False. |
False
|
Source code in src/streamlit_extras/sandbox/__init__.py
12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 |
|
Import:
Examples
example
def example():
def embedded_app():
import numpy as np
import pandas as pd
import plotly.express as px
import streamlit as st
@st.cache_data
def get_data():
dates = pd.date_range(start="01-01-2020", end="01-01-2023")
data = np.random.randn(len(dates), 1).cumsum(axis=0)
return pd.DataFrame(data, index=dates, columns=["Value"])
data = get_data()
value = st.slider(
"Select a range of values",
int(data.min()),
int(data.max()),
(int(data.min()), int(data.max())),
)
filtered_data = data[(data["Value"] >= value[0]) & (data["Value"] <= value[1])]
st.plotly_chart(px.line(filtered_data, y="Value"))
sandbox(embedded_app)