Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/genai_hackathon/models/user_query.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,5 @@

class UserQuery(BaseModel):
prompt: str
temperature: float = Field(None, ge=0.0, le=1.0)
temperature: float = Field(0.0, ge=0.0, le=1.0)
# optional params
17 changes: 17 additions & 0 deletions src/genai_hackathon/pages/azurepromptflow.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
import streamlit as st

from genai_hackathon.models.user_query import UserQuery
from genai_hackathon.providers.chat_provider import ChatProvider
from genai_hackathon.utils.environment import get_env_var

st.title("Azure Prompt Flow")

text = st.text_input(
"Prompt", value="Tell me about London", max_chars=None)

if st.button(label='Execute'):
q = UserQuery(prompt=text)

provider = ChatProvider()
result = provider.get_response(user_query=q, model=get_env_var("AZURE_DEPLOYMENT_NAME"))
st.subheader(f"Reponse from API: {result}")
64 changes: 64 additions & 0 deletions src/genai_hackathon/providers/azure_prompt_flow_provider.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,64 @@
import urllib.request
import json
import os
import ssl

from genai_hackathon.models.prompt.assistant import BasicAssistant
from genai_hackathon.models.user_query import UserQuery
from genai_hackathon.services.azure_openai_service import AzureOpenAIService
from genai_hackathon.utils.environment import get_env_var
from genai_hackathon.utils.logger import app_logger

def allowSelfSignedHttps(allowed):
# bypass the server certificate verification on client side
if allowed and not os.environ.get('PYTHONHTTPSVERIFY', '') and getattr(ssl, '_create_unverified_context', None):
ssl._create_default_https_context = ssl._create_unverified_context

allowSelfSignedHttps(True) # this line is needed if you use self-signed certificate in your scoring service.

class AzureProvider:
def __init__(self) -> None:

self._service = AzureOpenAIService(
api_key=get_env_var("AZURE_OPENAI_API_KEY"),
api_version=get_env_var("AZURE_API_VERSION"),
azure_endpoint=get_env_var("AZURE_ENDPOINT"),
)
self.promptflow_endpoint=get_env_var("AZURE_PROMPTFLOW_URL")
self.promptflow_key=get_env_var("AZURE_PROMPTFLOW_KEY")


def get_response(self, user_query: UserQuery, model: str):

app_logger.debug(user_query.prompt)

assitant = BasicAssistant()
data = {user_query.prompt}

body = str.encode(json.dumps(data))

url = self.promptflow_endpoint
# Replace this with the primary/secondary key, AMLToken, or Microsoft Entra ID token for the endpoint
api_key = self.promptflow_key
if not api_key:
raise Exception("A key should be provided to invoke the endpoint")

headers = {'Content-Type':'application/json', 'Authorization':('Bearer '+ api_key)}

req = urllib.request.Request(url, body, headers)

try:
response = urllib.request.urlopen(req)

result = response.read()
print(result)
except urllib.error.HTTPError as error:
print("The request failed with status code: " + str(error.code))

# Print the headers - they include the requert ID and the timestamp, which are useful for debugging the failure
print(error.info())
print(error.read().decode("utf8", 'ignore'))

app_logger.debug(response.choices[0].message.content)

return response.choices[0].message.content