From fbdc896b378cf75966a14ec02717c5ad6c401905 Mon Sep 17 00:00:00 2001 From: David Kegley Date: Wed, 6 Mar 2024 11:44:06 -0500 Subject: [PATCH] Update streamlit example and readmes --- examples/connect/shiny-python/README.md | 2 + examples/connect/streamlit/README.md | 42 ++++++++++---- .../streamlit/{sample-content.py => app.py} | 27 +++------ examples/connect/streamlit/requirements.txt | 56 +------------------ 4 files changed, 44 insertions(+), 83 deletions(-) rename examples/connect/streamlit/{sample-content.py => app.py} (51%) diff --git a/examples/connect/shiny-python/README.md b/examples/connect/shiny-python/README.md index a6e5fe02..e03d1217 100644 --- a/examples/connect/shiny-python/README.md +++ b/examples/connect/shiny-python/README.md @@ -3,6 +3,8 @@ ## Start the app locally ```bash +export DATABRICKS_HOST="" +export DATABRICKS_PATH="" shiny run app.py ``` diff --git a/examples/connect/streamlit/README.md b/examples/connect/streamlit/README.md index fb1c223f..6d7a5121 100644 --- a/examples/connect/streamlit/README.md +++ b/examples/connect/streamlit/README.md @@ -1,19 +1,39 @@ +# Streamlit Example + +## Start the app locally + ```bash -# start streamlit locally -DATABRICKS_TOKEN= \ -streamlit run ./sample-content.py +export DATABRICKS_HOST="" +export DATABRICKS_PATH="" +streamlit run app.py +``` -# deploy the app the first time -publisher deploy -a localhost:3939 -n databricks ./ +## Deploy to Posit Connect -# re-deploy the databricks app -publisher redeploy databricks +Validate that `rsconnect-python` is installed: + +```bash +rsconnect version ``` -TODO: Test this content with databricks-connect - +Or install it as documented in the [installation](https://docs.posit.co/rsconnect-python/#installation) section of the documentation. + +To publish, make sure `CONNECT_SERVER`, `CONNECT_API_KEY`, `DATABRICKS_HOST`, `DATABRICKS_PATH` have valid values. Then, on a terminal session, enter the following command: +```bash +rsconnect deploy streamlit . \ + --server "${CONNECT_SERVER}" \ + --api-key "${CONNECT_API_KEY}" \ + --environment DATABRICKS_HOST \ + --environment DATABRICKS_PATH ``` -# install the sdk from this branch -pip install git+https://github.com/posit-dev/posit-sdk-py.git@kegs/databricks-oauth-2 + +Note that the Databricks environment variables do not need to be resolved by the shell, so they do not include the `$` prefix. + +The Databricks environment variables only need to be set once, unless a change needs to be made. If the values have not changed, you don’t need to provide them again when you publish updates to the document. + +```bash +rsconnect deploy streamlit . \ + --server "${CONNECT_SERVER}" \ + --api-key "${CONNECT_API_KEY}" ``` diff --git a/examples/connect/streamlit/sample-content.py b/examples/connect/streamlit/app.py similarity index 51% rename from examples/connect/streamlit/sample-content.py rename to examples/connect/streamlit/app.py index a4a79daa..8edd67a4 100644 --- a/examples/connect/streamlit/sample-content.py +++ b/examples/connect/streamlit/app.py @@ -12,36 +12,27 @@ import streamlit as st from streamlit.web.server.websocket_headers import _get_websocket_headers -DB_PAT = os.getenv("DATABRICKS_TOKEN") +DATABRICKS_HOST = os.getenv("DATABRICKS_HOST") +DATABRICKS_HOST_URL = f"https://{DATABRICKS_HOST}" +SQL_HTTP_PATH = os.getenv("DATABRICKS_PATH") -DB_HOST = os.getenv("DB_HOST") -DB_HOST_URL = f"https://{DB_HOST}" -SQL_HTTP_PATH = os.getenv("SQL_HTTP_PATH") +session_token = _get_websocket_headers().get("Posit-Connect-User-Session-Token") -USER_SESSION_TOKEN = None +credentials_provider = viewer_credentials_provider(user_session_token=session_token) -# Read the viewer's user session token from the streamlit ws header. -headers = _get_websocket_headers() -if headers: - USER_SESSION_TOKEN = headers.get("Posit-Connect-User-Session-Token") - -credentials_provider = viewer_credentials_provider( - user_session_token=USER_SESSION_TOKEN +cfg = Config( + host=DATABRICKS_HOST_URL, credentials_provider=credentials_provider ) -cfg = Config(host=DB_HOST_URL, credentials_provider=credentials_provider) -# cfg = Config(host=DB_HOST_URL, token=DB_PAT) - databricks_user = CurrentUserAPI(ApiClient(cfg)).me() st.write(f"Hello, {databricks_user.display_name}!") with sql.connect( - server_hostname=DB_HOST, + server_hostname=DATABRICKS_HOST, http_path=SQL_HTTP_PATH, - # access_token=DB_PAT) as connection: auth_type="databricks-oauth", credentials_provider=credentials_provider, ) as connection: with connection.cursor() as cursor: - cursor.execute("SELECT * FROM samples.nyctaxi.trips") + cursor.execute("SELECT * FROM samples.nyctaxi.trips LIMIT 10;") result = cursor.fetchall() st.table(pd.DataFrame(result)) diff --git a/examples/connect/streamlit/requirements.txt b/examples/connect/streamlit/requirements.txt index 53d0cc3b..63ccd077 100644 --- a/examples/connect/streamlit/requirements.txt +++ b/examples/connect/streamlit/requirements.txt @@ -1,56 +1,4 @@ -altair==5.2.0 -attrs==23.2.0 -blinker==1.7.0 -cachetools==5.3.2 -certifi==2024.2.2 -charset-normalizer==3.3.2 -click==8.1.7 +databricks-sql-connector==3.0.1 databricks-sdk==0.20.0 -databricks-sql-connector==3.1.0 -et-xmlfile==1.1.0 -gitdb==4.0.11 -GitPython==3.1.42 -google-auth==2.28.0 -idna==3.6 -importlib-metadata==7.0.1 -Jinja2==3.1.3 -jsonschema==4.21.1 -jsonschema-specifications==2023.12.1 -lz4==4.3.3 -markdown-it-py==3.0.0 -MarkupSafe==2.1.5 -mdurl==0.1.2 -numpy==1.26.4 -oauthlib==3.2.2 -openpyxl==3.1.2 -packaging==23.2 -pandas==2.1.4 -pillow==10.2.0 -posit-sdk @ git+https://github.com/posit-dev/posit-sdk-py.git@cec7f78a1bdee9e5fd7580011bfa0bcef58cd64b -protobuf==4.25.3 -pyarrow==14.0.2 -pyasn1==0.5.1 -pyasn1-modules==0.3.0 -pydeck==0.8.1b0 -Pygments==2.17.2 -python-dateutil==2.8.2 -pytz==2024.1 -referencing==0.33.0 -requests==2.31.0 -rich==13.7.0 -rpds-py==0.18.0 -rsa==4.9 -six==1.16.0 -smmap==5.0.1 streamlit==1.31.1 -tenacity==8.2.3 -thrift==0.16.0 -toml==0.10.2 -toolz==0.12.1 -tornado==6.4 -typing_extensions==4.9.0 -tzdata==2024.1 -tzlocal==5.2 -urllib3==2.2.1 -validators==0.22.0 -zipp==3.17.0 +git+https://github.com/posit-dev/posit-sdk-py.git