-
Notifications
You must be signed in to change notification settings - Fork 89
/
Copy pathapp.py
121 lines (103 loc) · 4.36 KB
/
app.py
1
2
3
4
5
6
7
8
9
10
11
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
120
121
import streamlit as st
from snowflake.connector import DatabaseError
from snowflake.connector.connection import SnowflakeConnection
# set_page_config must be run as the first Streamlit command on the page, before any other streamlit imports.
st.set_page_config(layout="wide", page_icon="💬", page_title="Semantic Model Generator")
from app_utils.shared_utils import ( # noqa: E402
GeneratorAppScreen,
get_snowflake_connection,
set_account_name,
set_host_name,
set_sit_query_tag,
set_snowpark_session,
set_streamlit_location,
set_user_name,
)
from semantic_model_generator.snowflake_utils.env_vars import ( # noqa: E402
SNOWFLAKE_ACCOUNT_LOCATOR,
SNOWFLAKE_HOST,
SNOWFLAKE_USER,
)
@st.experimental_dialog(title="Connection Error")
def failed_connection_popup() -> None:
"""
Renders a dialog box detailing that the credentials provided could not be used to connect to Snowflake.
"""
st.markdown(
"""It looks like the credentials provided could not be used to connect to the account."""
)
st.stop()
def verify_environment_setup() -> SnowflakeConnection:
"""
Ensures that the correct environment variables are set before proceeding.
"""
# Instantiate the Snowflake connection that gets reused throughout the app.
try:
with st.spinner(
"Validating your connection to Snowflake. If you are using MFA, please check your authenticator app for a push notification."
):
return get_snowflake_connection()
except DatabaseError:
failed_connection_popup()
if __name__ == "__main__":
from journeys import builder, iteration, partner
st.session_state["sis"] = set_streamlit_location()
def onboarding_dialog() -> None:
"""
Renders the initial screen where users can choose to create a new semantic model or edit an existing one.
"""
# Direct to specific page based instead of default onboarding if user comes from successful partner setup
st.markdown(
"""
<div style="text-align: center;">
<h1>Welcome to the Snowflake Semantic Model Generator! ❄️</h1>
<p>⚠️ Heads up! The Streamlit app is no longer supported for semantic model creation.
<p>👉 Please use the Snowsight UI in Snowflake to create and update semantic models — it’s newer and works better! </p>
<p>✅ Once your model is created in Snowsight, come back here to run evaluations, which still work best in this app.</p>
</div>
""",
unsafe_allow_html=True,
)
st.markdown("<div style='margin: 60px;'></div>", unsafe_allow_html=True)
_, center, _ = st.columns([1, 2, 1])
with center:
if st.button(
"**[⚠️ Deprecated]🛠 Create a new semantic model**",
use_container_width=True,
type="primary",
):
builder.show()
st.markdown("")
if st.button(
"**✏️ Edit an existing semantic model**",
use_container_width=True,
type="primary",
):
iteration.show()
st.markdown("")
if st.button(
"**[⚠️ Deprecated]📦 Start with partner semantic model**",
use_container_width=True,
type="primary",
):
set_sit_query_tag(
get_snowflake_connection(),
vendor="",
action="start",
)
partner.show()
conn = verify_environment_setup()
set_snowpark_session(conn)
# Populating common state between builder and iteration apps.
set_account_name(conn, SNOWFLAKE_ACCOUNT_LOCATOR)
set_host_name(conn, SNOWFLAKE_HOST)
set_user_name(conn, SNOWFLAKE_USER)
# When the app first loads, show the onboarding screen.
if "page" not in st.session_state:
st.session_state["page"] = GeneratorAppScreen.ONBOARDING
# Depending on the page state, we either show the onboarding menu or the chat app flow.
# The builder flow is simply an intermediate dialog before the iteration flow.
if st.session_state["page"] == GeneratorAppScreen.ITERATION:
iteration.show()
else:
onboarding_dialog()