Spaces:
Sleeping
Sleeping
import streamlit as st | |
import google.generativeai as genai | |
import os | |
from dotenv import load_dotenv | |
load_dotenv() | |
# Configure the API key | |
genai.configure(api_key=os.getenv("GOOGLE_API_KEY")) | |
safety_settings = [ | |
{"category": "HARM_CATEGORY_HARASSMENT", "threshold": "BLOCK_NONE"}, | |
{"category": "HARM_CATEGORY_HATE_SPEECH", "threshold": "BLOCK_NONE"}, | |
{"category": "HARM_CATEGORY_SEXUALLY_EXPLICIT", "threshold": "BLOCK_NONE"}, | |
{"category": "HARM_CATEGORY_DANGEROUS_CONTENT", "threshold": "BLOCK_NONE"}, | |
] | |
genai.configure(api_key=os.getenv("GOOGLE_API_KEY")) | |
model = genai.GenerativeModel('gemini-1.5-flash',safety_settings=safety_settings, | |
system_instruction="Tu es un assistant intelligent. ton but est d'assister au mieux que tu peux. tu as été créé par Aenir et tu t'appelles Mariam") | |
# Function to get response from the model | |
# Gemini uses 'model' for assistant; Streamlit uses 'assistant' | |
def role_to_streamlit(role): | |
if role == "model": | |
return "assistant" | |
else: | |
return role | |
# Add a Gemini Chat history object to Streamlit session state | |
if "chat" not in st.session_state: | |
st.session_state.chat = model.start_chat(history=[]) | |
# Display Form Title | |
st.title("Mariam AI!") | |
# Display chat messages from history above current input box | |
for message in st.session_state.chat.history: | |
with st.chat_message(role_to_streamlit(message.role)): | |
st.markdown(message.parts[0].text) | |
# Accept user's next message, add to context, resubmit context to Gemini | |
if prompt := st.chat_input("Hey?"): | |
# Display user's last message | |
st.chat_message("user").markdown(prompt) | |
# Send user entry to Gemini and read the response | |
response = st.session_state.chat.send_message(prompt) | |
# Display last | |
with st.chat_message("assistant"): | |
st.markdown(response.text) |