From 0ca4b5a60b6facbd3d2cf478ac177c31226ee984 Mon Sep 17 00:00:00 2001 From: Dayenne Souza Date: Tue, 10 Dec 2024 17:27:02 -0300 Subject: [PATCH] add azure deploy to marketplace files (#83) * add terraform files * fix gitignore and files * terraform script * fix terraform script * fix terraform script * fix terraform script * fix terraform script * fix terraform script * fix terraform script * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * fix sh * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * fix main tf * add example bicep * fix bicep * add latest templates ARM * add openai instructions * add app reg on readme * fix * add warning for version update * fix authDisabled and plan * fix * fix version * add tf file back * fix gitgnore * fix * fix embedding default * change default models * fix template --- .gitignore | 2 +- DEPLOYING.md | 68 -------- DEVELOPING.md | 4 +- OPENAI.md | 60 +++++++ README.md | 22 ++- app/Home.py | 17 +- app/util/ui_components.py | 6 +- deploy/azure/README.md | 81 +++++++++ deploy/azure/createUiDefinition.json | 132 +++++++++++++++ deploy/azure/main.tf | 2 +- deploy/azure/mainTemplate.json | 238 +++++++++++++++++++++++++++ intelligence_toolkit/AI/defaults.py | 2 +- pyproject.toml | 2 +- 13 files changed, 549 insertions(+), 87 deletions(-) create mode 100644 OPENAI.md create mode 100644 deploy/azure/README.md create mode 100644 deploy/azure/createUiDefinition.json create mode 100644 deploy/azure/mainTemplate.json diff --git a/.gitignore b/.gitignore index 233f6386..c0142fec 100644 --- a/.gitignore +++ b/.gitignore @@ -55,4 +55,4 @@ app/wkhtmltox/*.exe **/studio_tests/ .venv -**/dist/* \ No newline at end of file +**/dist/* diff --git a/DEPLOYING.md b/DEPLOYING.md index 16e31866..ce18d516 100644 --- a/DEPLOYING.md +++ b/DEPLOYING.md @@ -2,15 +2,12 @@ Deploying your app effectively is crucial for making it accessible to users. We present three robust options that cater to different requirements and preferences, whether you're looking for simplicity, scalability, or specific infrastructure. -- **Using Streamlit Cloud:** Ideal for those who prefer a straightforward and cost-effective deployment solution. Streamlit Cloud is perfect for quickly deploying Streamlit apps with minimal setup and no need for managing infrastructure. - - **Using Azure:** A powerful option for those who are already integrated into the Microsoft ecosystem or need advanced cloud services. Azure offers robust performance, scalability, and a suite of tools that are beneficial for apps requiring Microsoft-specific integrations or high availability. - **Using AWS:** Known for its versatility and comprehensive cloud solutions, AWS is suitable for developers seeking a highly scalable and flexible deployment environment. It is apt for those with diverse app requirements and offers a range of services, from simple hosting to complex machine learning models. Each of these options has its own strengths, and your choice will depend on the specific needs and constraints of your project. The following sections provide detailed guides on deploying your app using each of these platforms. - # Requirements for the app To deploy your app, you will need: @@ -18,71 +15,6 @@ To deploy your app, you will need: 1. An active OpenAI account ([create here](https://platform.openai.com/login)). 2. An OpenAI API key ([create here](https://platform.openai.com/account/api-keys)). -# Streamlit Cloud -This guide will walk you through deploying our app that uses [Streamlit](https://streamlit.io/), a Python package for building web apps. You can host your Streamlit apps for free with [Streamlit Community Cloud](https://streamlit.io/cloud). - -## Security: - -Streamlit prioritizes security by hosting data in secure cloud facilities and using encryption for data protection. Permission management follows GitHub rules, and regular vulnerability scans ensure the platform remains secure and up to date. - -[Read more](https://docs.streamlit.io/deploy/streamlit-community-cloud/get-started/trust-and-security) - -## Resource Limits - -While Streamlit Community Cloud is free to use, it has resource limits that apply to all users. Exceeding these limits may result in throttling or app nonfunctionality. As of February 2024, the approximate limits are: - -- **CPU:** 0.078 cores minimum, 2 cores maximum -- **Memory:** 690MB minimum, 2.7GB maximum -- **Storage:** No minimum, 50GB maximum - -For optimal performance, especially with high concurrent usage, a higher allocation of CPU and memory may be beneficial. - -[Read more](https://docs.streamlit.io/deploy/streamlit-community-cloud/manage-your-app#app-resources-and-limits) - - -## Increased Resources for NGOs - -If you're part of an NGO, you might be eligible for increased resources by applying [here](https://info.snowflake.com/streamlit-resource-increase-request.html). Eligible apps often serve educational institutions, are part of open-source projects, or provide societal benefits. For-profit companies are generally not eligible. - -## Requirement for Streamlit Cloud - - - A [github account](https://github.com) - - A Forked GitHub repository: - - Fork [github.com/intelligence-toolkit](https://github.com/microsoft/intelligence-toolkit) - - Ensure you keep your repository updated with the main repository to incorporate new code and bug fixes. - - -## Deployment Steps - -1. **Streamlit Setup:** - - [Create or sign in to your Streamlit account](https://share.streamlit.io/signup). - - Click on `Create an app` in the top right corner. - - Choose to deploy a public app from GitHub and configure it with the following: - - - **Repository:** `{your_forked_one}` - - **Branch:** `main` - - **Main file path:** `app/Home.py` - - **App URL (optional):** Customize the URL for accessing your app. - -2. **Advanced Settings:** - - Add the following secrets: - ```plaintext - OPENAI_API_KEY="your-key" - - HIDE_SETTINGS="TRUE" # Hides settings page to prevent changes affecting all users. - - AUTH_ENABLED="TRUE" # Allows access only to authorized users. - - [passwords] - "username" = "user_pwd" - "username2" = "user_pwd2" - ... - ``` - -3. **Deploy:** - - After setting up, click deploy. The deployment process takes a few minutes, and your app will be ready for access. - - # Azure #### Recommended configuration: diff --git a/DEVELOPING.md b/DEVELOPING.md index 2c0bd813..27d04bf7 100644 --- a/DEVELOPING.md +++ b/DEVELOPING.md @@ -21,10 +21,10 @@ You can configure your OpenAI access when running the app via `Settings page`, o #### Default values: ``` -OPENAI_API_MODEL="gpt-4o" +OPENAI_API_MODEL="gpt-4o-mini" OPENAI_TYPE="OpenAI" ## Other option available: Azure OpenAI AZURE_AUTH_TYPE="Azure Key" # if OPENAI_TYPE==Azure OpenAI -DEFAULT_EMBEDDING_MODEL = "text-embedding-ada-002" +DEFAULT_EMBEDDING_MODEL = "text-embedding-3-small" ``` ### OpenAI diff --git a/OPENAI.md b/OPENAI.md new file mode 100644 index 00000000..93443dfa --- /dev/null +++ b/OPENAI.md @@ -0,0 +1,60 @@ +# OpenAI or Azure OpenAI Instance +Before you can deploy the application, you need to have an OpenAI or Azure OpenAI instance. This instance will provide the AI capabilities required by the application. Below are the steps to create an OpenAI or Azure OpenAI instance. + +## Creating an OpenAI Instance +See pricing details [here](https://openai.com/api/pricing/) +1. **Sign Up for OpenAI**: + - Go to the [OpenAI website](https://platform.openai.com/login/). + - Login or sign in (you can use your ChatGPT account) + - You will need a phone number to confirm your account. + +2. **Create the project** + - Click on Create a new project. + - Give it an identifiable name and click create. + +3. **Add billing details** + - On the top bar on the right, click on your profile. + - Click on `Billing` on the left panel. + - Add your payment details. + +4. **Get API Key**: + - On the top bar on the right, click on your profile. + - Click on `API keys` on the left panel. + - Click on `+ Create new secret key` on the top right. + - Give it an identifiable name and select the project you created. + - Click `Create secret key`. + - Copy your key and store it safely. It won't show again and if lost you'll need to create a new one. + - Use these to configure your access when deploying intelligence-toolkit app or using the `Settings` page. + + + + +## Creating an Azure OpenAI Instance +See pricing details [here](https://azure.microsoft.com/en-us/pricing/details/cognitive-services/openai-service/) + +1. **Log in to the Azure portal**: + - Go to the [Azure portal](https://portal.azure.com). + - If you don't have an account, click on "Create one" and follow the steps to set up your account. + +2. **Create the resource**: + - Click on "Create a resource" and search for "Azure OpenAI". + - Select "Azure OpenAI Service" and click "Create". + - Fill in the required details (subscription, resource group, region, etc.). + - Click next until the Review + submit step. + - If validation passes, click create. + +3. **Deploy the models**: + - Go to the resource page. + - Click on `Go to Azure AI Foundry portal` + - Click on `Deployments` on the left panel. + - Create the AI model + - Click on `Deploy model` and `Deploy base model`. + - Choose `gpt-4o-mini` then `Confirm` and `Deploy` + - Create the embedding model + - Click on `Deploy model` and `Deploy base model`. + - Choose `text-embedding-3-small` then `Confirm` and `Deploy` + +4. **Get the Azure OpenAI key**: + - In the resource page on Azure portal, go to "Keys and Endpoint" section. + - Copy one of the keys (KEY 1 or KEY 2) and Endpoint URL. + - Use these to configure your access when deploying intelligence-toolkit app or using the `Settings` page. \ No newline at end of file diff --git a/README.md b/README.md index 28db8e7d..9ff29bbb 100644 --- a/README.md +++ b/README.md @@ -130,9 +130,19 @@ All use of Intelligence Toolkit should be consistent with this documentation. In ## Getting Started -You can start using the Intelligence Toolkit as either a web application (with a tool called Docker) or a Python package (via PyPI). Choose one of the options below based on your needs. +You can start using the Intelligence Toolkit as either a web application (in Azure or locally with a tool called Docker) or a Python package (via PyPI). Choose one of the options below based on your needs. + +**Option 1: Using Intelligence Toolkit in Azure** +### NGOs + +Non-profit organizations can apply for an annual Azure credit grant of $2,000, which can be used to set up and run an instance of the intelligence-toolkit app for your organization. + +[Read more about eligibility and registration here](https://www.microsoft.com/en-us/nonprofits/azure) + +[See instructions](./deploy/azure/README.md) on how to. -**Option 1: Using Intelligence Toolkit as a Web Application (via Docker)** + +**Option 2: Using Intelligence Toolkit as a Web Application (via Docker)** To use the Intelligence Toolkit as a web application, you can download and run it using Docker. @@ -187,7 +197,7 @@ You can access the `Settings` page on the left sidebar when running the applicat - For Azure OpenAI, you will need an active Azure account ([create here](https://portal.azure.com/)), endpoint, key and version for the AI Service ([create here](https://portal.azure.com/#view/Microsoft_Azure_ProjectOxford/CognitiveServicesHub/~/OpenAI)). -**Option 2: Using Intelligence Toolkit as a Python Package (via PyPI)** +**Option 3: Using Intelligence Toolkit as a Python Package (via PyPI)** If you prefer to use Intelligence Toolkit as a Python package, install it directly from PyPI: @@ -206,12 +216,6 @@ If you have any questions or need further assistance, you can reach out to the p
-### NGOs - -Non-profit organizations can apply for an annual Azure credit grant of $2,000, which can be used to set up and run an instance of the intelligence-toolkit app for your organization. - -[Read more about eligibility and registration here](https://www.microsoft.com/en-us/nonprofits/azure) - ## Trademarks - This project may contain trademarks or logos for projects, products, or services. diff --git a/app/Home.py b/app/Home.py index 4580611e..78535618 100644 --- a/app/Home.py +++ b/app/Home.py @@ -2,10 +2,12 @@ # Copyright (c) 2024 Microsoft Corporation. All rights reserved. # Licensed under the MIT license. See LICENSE file in the project. # +import importlib.metadata import inspect import os import os.path +import requests import streamlit as st import util.mermaid as mermaid from components.app_loader import load_multipage_app @@ -13,7 +15,6 @@ filename = inspect.getframeinfo(inspect.currentframe()).filename path = os.path.dirname(os.path.abspath(filename)) - def get_readme_and_mermaid(): file_path = os.path.join(path, "README.md") if not os.path.exists(file_path): @@ -60,6 +61,20 @@ def main(): page_title="Intelligence Toolkit | Home", ) + version = importlib.metadata.version("intelligence-toolkit") + st.sidebar.markdown(f"Version: {version}") + + url = "https://raw.githubusercontent.com/microsoft/intelligence-toolkit/refs/heads/main/pyproject.toml" + response = requests.get(url) + if response.status_code == 200: + lines = response.text.splitlines() + if len(lines) >= 3 and lines[2].startswith("version ="): + file_version = lines[2].split("=")[1].strip().strip('"') + if file_version > version: + st.sidebar.warning( + f"There is a new version of Intelligence Toolkit available: {file_version}. Please update your installation." + ) + load_multipage_app() transparency_faq, mermaid_text = get_readme_and_mermaid() diff --git a/app/util/ui_components.py b/app/util/ui_components.py index 5b1e58e0..721c2b30 100644 --- a/app/util/ui_components.py +++ b/app/util/ui_components.py @@ -810,17 +810,17 @@ def check_ai_configuration(enforce_structured_output=False): st.warning("Please set your OpenAI model in the Settings page.") list_enforce_structured_output = [ - "gpt-4o", - "gpt-4o-2024-08-06", "gpt-4o-mini", "gpt-4o-mini-2024-07-18", + "gpt-4o", + "gpt-4o-2024-08-06", ] if ( enforce_structured_output and ai_configuration.model not in list_enforce_structured_output ): st.warning( - "Your current OpenAI model does not support this workflow. Please use the Settings page to use `gpt-4o` or `gpt-4o-mini` as OpenAI Deployment Name." + "Your current OpenAI model does not support this workflow. Please use the Settings page to use `gpt-4o-mini` or `gpt-4o` as OpenAI Deployment Name." ) diff --git a/deploy/azure/README.md b/deploy/azure/README.md new file mode 100644 index 00000000..743f08f8 --- /dev/null +++ b/deploy/azure/README.md @@ -0,0 +1,81 @@ +# Deploying the App Using Azure Marketplace +This guide will help you deploy your application using Azure Marketplace, even if you're not a technical expert. + +### Prerequisites +Before you start, make sure you have the following: + +1. **Azure Subscription**: An active Azure subscription. +1. **OpenAI or Azure OpenAI instance**: This will provide the AI capabilities required by the application. If you don't have one, you can find [instructions here](../../OPENAI.md) +2. **Azure Account**: At minimum `Contributor` role assignment to deploy the resources in your Azure subscription. + +### Steps to Deploy the App + +It is recommended that you use Entra ID for authentication. + +#### Creating an app registration for website authentication + +- Open your web browser and go to [Microsoft Entra admin center](https://entra.microsoft.com/#view/Microsoft_AAD_RegisteredApps/ApplicationsListBlade) +- On the left panel click on `Applications` then `App registrations` +- Click on `+ New registration`. + - **Give it an identifiable name** + - **Supported account types**: + - Accounts in this organizational directory only (Microsoft only - Single tenant) +- **Redirect URI**: + - Select `Web` as platform and in the URL insert the following URL, being `[webAppName]` the name you'll give to the app on the next steps: + - `https://[webAppName].azurewebsites.net/.auth/login/aad/callback` + - Click on `Register` + - Copy the value of `Application (client) ID` to be used when creating the app in the next steps. + +#### Deploy +See details on pricing [here](https://azure.microsoft.com/en-us/pricing/details/app-service/linux/) (We default to `Premium v3 P0v3` Plan) + +1. **Go to Azure Marketplace**: + - Open your web browser and go to [Azure portal](https://portal.azure.com), search in the top bar for `Marketplace`. + - If you're not logged in, you may need to log in to your Azure account. + - Use the search bar to find the `Intelligence Toolkit` application. + +2. **Select the Application**: + - Click on the application from the search results to open its details page. + +3. **Click "Create"**: + - Click the "Create" button with Plan `Web App` selected to start the deployment process. + +4. **Configure Deployment Settings**: + - You will be redirected to the [Azure portal](https://portal.azure.com) to set up the deployment. + - Fill in the required information: + - **Subscription**: Choose your Azure subscription. + - **Resource Group**: Select an existing group or create a new one. + - **Region**: Choose the region where you want to deploy the app (the closer to y ou, the better). + - **Web App Name**: Enter a unique name for your web app. + - This will create the URl you'll access: + `webappname`.azurewebsites.net + - **Service Principal Type**: + - To create a new authentication app, leave as `Create New` + - Click change Selection to change its name or leave it as the default. + - **AI Settings**: + - This will configure how the app will access an AI instance. + - **AI Type**: + - OpenAI or Azure OpenAI + - **Use Managed Identity**: + - Check this if type is Azure OpenAI and you don't have a key, but the user accessing the app have permission to it. + - **Endpoint**: + - If Azure OpenAI, insert the endpoint for it. + - **Key**: + - Only if Managed Identity is not checked, insert your OpenAI or Azure OpenAI key here. + - **Tags** (Optional): Add any tags you want to use to organize your resources. + +5. **Review and Create**: + - Review the settings you entered to make sure everything is correct. + - Click the "Review + create" button to validate the settings. + - Once validation is complete, click the "Create" button to start the deployment. + +6. **Monitor Deployment**: + - The deployment process will begin, and you can watch its progress in the Azure portal. + - When the deployment is finished, you will get a notification. + +7. **Access the Deployed Application**: + - Go to the resource group where the application was deployed. + - Find the web application resource and click on it to open its details page. + - It takes a few minutes for the application to be ready. Wait about 5-10 and then use the provided URL (`webappname`.azurewebsites.net) to access your deployed application. + +By following these steps, you can successfully deploy your application using Azure Marketplace. \ No newline at end of file diff --git a/deploy/azure/createUiDefinition.json b/deploy/azure/createUiDefinition.json new file mode 100644 index 00000000..07a21c89 --- /dev/null +++ b/deploy/azure/createUiDefinition.json @@ -0,0 +1,132 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/0.1.2-preview/CreateUIDefinition.MultiVm.json#", + "handler": "Microsoft.Azure.CreateUIDef", + "version": "0.1.2-preview", + "parameters": { + "basics": [ + { + "name": "webAppName", + "type": "Microsoft.Common.TextBox", + "label": "Web App Name", + "defaultValue": "", + "toolTip": "The App name, to be acessed", + "constraints": { + "required": true, + "regex": "^[a-zA-Z0-9-]{3,60}$", + "validationMessage": "Name must be between 3 and 60 characters long and contain only letters, numbers, and hyphens" + }, + "visible": true + }, + { + "name": "disableAuth", + "type": "Microsoft.Common.CheckBox", + "label": "Disable Authentication" + }, + { + "name": "authClientId", + "type": "Microsoft.Common.TextBox", + "label": "App Registration client ID", + "defaultValue": "", + "toolTip": "The app registration client id. (check github repository readme on how to)", + "constraints": { + "required": "[equals(steps('basics').disableAuth, false)]", + "regex": "^[a-zA-Z0-9-]{36}$", + "validationMessage": "Must be a valid GUID" + }, + "visible": "[equals(steps('basics').disableAuth, false)]" + } + ], + "config": { + "basics": { + "subscription": { + "constraints": { + "validations": [ + { + "permission": "Microsoft.Resources/deployments/validate/action", + "message": "You don't have the right permissions to perform this action." + } + ] + } + }, + "resourceGroup": { + "allowExisting": true + } + } + }, + "steps": [ + { + "name": "AI Settings", + "type": "Microsoft.Common.Section", + "label": "AI Settings", + "elements": [ + { + "name": "aiType", + "type": "Microsoft.Common.OptionsGroup", + "label": "AI Type", + "defaultValue": "OpenAI", + "toolTip": "", + "constraints": { + "allowedValues": [ + { + "label": "OpenAI", + "value": "openai" + }, + { + "label": "Azure OpenAI", + "value": "azure" + } + ], + "required": true + }, + "visible": true + }, + { + "name": "aiManagedIdentity", + "type": "Microsoft.Common.CheckBox", + "label": "Use Managed Identity", + "visible": "[equals(steps('AI Settings').aiType, 'azure')]" + }, + { + "name": "aiEndpoint", + "type": "Microsoft.Common.TextBox", + "label": "Endpoint", + "defaultValue": "", + "visible": "[equals(steps('AI Settings').aiType, 'azure')]" + }, + { + "name": "openaiApiKey", + "type": "Microsoft.Common.TextBox", + "label": "Key", + "defaultValue": "", + "visible": "[or(equals(steps('AI Settings').aiManagedIdentity, false), equals(steps('AI Settings').aiType, 'openai'))]" + } + ] + }, + { + "name": "tags", + "type": "Microsoft.Common.Section", + "label": "Tags", + "elements": [ + { + "name": "tagsObj", + "type": "Microsoft.Common.TagsByResource", + "resources": [ + "Microsoft.Web/sites" + ] + } + ] + } + ], + "outputs": { + "webAppName": "[basics('webAppName')]", + "location": "[location()]", + "tags": "[steps('tags').tagsObj]", + "clientId": "[basics('authClientId')]", + "disableAuth": "[basics('disableAuth')]", + "aiType": "[steps('AI Settings').aiType]", + "aiManagedIdentity": "[steps('AI Settings').aiManagedIdentity]", + "openaiApiKey": "[steps('AI Settings').openaiApiKey]", + "aiEndpoint": "[steps('AI Settings').aiEndpoint]" + } + } +} \ No newline at end of file diff --git a/deploy/azure/main.tf b/deploy/azure/main.tf index 2f3ec4fa..0537fab1 100644 --- a/deploy/azure/main.tf +++ b/deploy/azure/main.tf @@ -58,4 +58,4 @@ resource "azurerm_linux_web_app" "az_webapp" { } } -} +} \ No newline at end of file diff --git a/deploy/azure/mainTemplate.json b/deploy/azure/mainTemplate.json new file mode 100644 index 00000000..0e4433b8 --- /dev/null +++ b/deploy/azure/mainTemplate.json @@ -0,0 +1,238 @@ +{ + "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "parameters": { + "webAppName": { + "type": "string" + }, + "location": { + "type": "string" + }, + "clientId": { + "type": "string", + "defaultValue": "" + }, + "disableAuth": { + "type": "bool", + "defaultValue": false + }, + "openaiApiKey": { + "type": "string", + "defaultValue": "" + }, + "aiType": { + "type": "string", + "defaultValue": "" + }, + "aiManagedIdentity": { + "type": "bool", + "defaultValue": false + }, + "aiEndpoint": { + "type": "string", + "defaultValue": "" + }, + "tags": { + "type": "object", + "defaultValue": {} + }, + "alwaysOn": { + "type": "bool", + "defaultValue": true + }, + "sku": { + "type": "string", + "defaultValue": "Premium v3" + }, + "skuCode": { + "type": "string", + "defaultValue": "P0V3" + }, + "workerSize": { + "type": "string", + "defaultValue": "8" + }, + "workerSizeId": { + "type": "string", + "defaultValue": "8" + }, + "numberOfWorkers": { + "type": "string", + "defaultValue": "1" + } + }, + "variables": { + "hostingPlanName": "[concat(parameters('webAppName'), '-plan')]", + "ftpsState": "FtpsOnly", + "linuxFxVersion": "sitecontainers", + "siteContainerName": "main", + "redirectUrl": "[concat('https://', parameters('webAppName'), '.azurewebsites.net')]" + }, + "resources": [ + { + "apiVersion": "2019-10-01", + "name": "pid-02837e98-dc6a-4353-9712-eb2e50086e2c-partnercenter", + "type": "Microsoft.Resources/deployments", + "properties": { + "mode": "Incremental", + "template": { + "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#", + "contentVersion": "1.0.0.0", + "resources": [] + } + } + }, + { + "apiVersion": "2022-03-01", + "name": "[parameters('webAppName')]", + "type": "Microsoft.Web/sites", + "location": "[parameters('location')]", + "tags": "[if(contains(parameters('tags'), 'Microsoft.Web/sites'), parameters('tags')['Microsoft.Web/sites'], json('null'))]", + "dependsOn": [ + "[variables('hostingPlanName')]" + ], + "properties": { + "name": "[parameters('webAppName')]", + "siteAuthEnabled": true, + "siteConfig": { + "appSettings": [ + { + "name": "WEBSITES_ENABLE_APP_SERVICE_STORAGE", + "value": "false" + }, + { + "name": "DOCKER_ENABLE_CI", + "value": "true" + }, + { + "name": "OPENAI_API_KEY", + "value": "[parameters('openaiApiKey')]" + }, + { + "name": "OPENAI_TYPE", + "value": "[parameters('aiType')]" + }, + { + "name": "AZURE_AUTH_TYPE", + "value": "[if(equals(parameters('aiManagedIdentity'), 'true'), 'Managed Identity', 'Azure Key')]" + }, + { + "name": "AZURE_OPENAI_ENDPOINT", + "value": "[parameters('aiEndpoint')]" + } + ], + "linuxFxVersion": "[variables('linuxFxVersion')]", + "alwaysOn": "[parameters('alwaysOn')]", + "ftpsState": "[variables('ftpsState')]" + }, + "serverFarmId": "[concat('/subscriptions/', subscription().subscriptionId,'/resourcegroups/', resourceGroup().id, '/providers/Microsoft.Web/serverfarms/', variables('hostingPlanName'))]", + "clientAffinityEnabled": false, + "httpsOnly": true, + "publicNetworkAccess": "Enabled" + }, + "resources": [ + { + "type": "Microsoft.Web/sites/basicPublishingCredentialsPolicies", + "apiVersion": "2022-09-01", + "name": "[concat(parameters('webAppName'), '/scm')]", + "properties": { + "allow": false + }, + "dependsOn": [ + "[resourceId('Microsoft.Web/Sites', parameters('webAppName'))]" + ] + }, + { + "type": "Microsoft.Web/sites/basicPublishingCredentialsPolicies", + "apiVersion": "2022-09-01", + "name": "[concat(parameters('webAppName'), '/ftp')]", + "properties": { + "allow": false + }, + "dependsOn": [ + "[resourceId('Microsoft.Web/Sites', parameters('webAppName'))]" + ] + } + ] + }, + { + "type": "Microsoft.Web/sites/config", + "apiVersion": "2022-09-01", + "name": "[concat(parameters('webAppName'), '/authsettingsV2')]", + "dependsOn": [ + "[resourceId('Microsoft.Web/Sites', parameters('webAppName'))]" + ], + "properties": { + "globalValidation": { + "requireAuthentication": "[equals(parameters('disableAuth'), 'false')]", + "unauthenticatedClientAction": "RedirectToLoginPage" + }, + "identityProviders": { + "azureActiveDirectory": { + "enabled": "[equals(parameters('disableAuth'), 'false')]", + "registration": { + "clientId": "[parameters('clientId')]", + "openIdIssuer": "[concat('https://login.microsoftonline.com/',subscription().tenantId,'/v2.0')]" + }, + "validation": { + "allowedAudiences": [ "[parameters('clientId')]" ] + } + } + } + } + }, + { + "type": "Microsoft.Web/sites/sitecontainers", + "apiVersion": "2023-12-01", + "name": "[format('{0}/{1}', parameters('webAppName'), variables('siteContainerName'))]", + "properties": { + "image": "ghcr.io/microsoft/intelligence-toolkit:latest", + "targetPort": "80", + "isMain": true, + "startUpCommand": "", + "authType": "Anonymous" + }, + "dependsOn": [ + "[resourceId('Microsoft.Web/sites', parameters('webAppName'))]" + ] + }, + { + "apiVersion": "2023-12-01", + "name": "[variables('hostingPlanName')]", + "type": "Microsoft.Web/serverfarms", + "location": "[parameters('location')]", + "kind": "linux", + "dependsOn": [], + "properties": { + "name": "[variables('hostingPlanName')]", + "workerSize": "[parameters('workerSize')]", + "workerSizeId": "[parameters('workerSizeId')]", + "numberOfWorkers": "[parameters('numberOfWorkers')]", + "reserved": true, + "zoneRedundant": false + }, + "sku": { + "Tier": "[parameters('sku')]", + "Name": "[parameters('skuCode')]" + } + } + ], + "outputs": { + "webAppName": { + "type": "string", + "value": "[parameters('webAppName')]" + }, + "hostingPlanName": { + "type": "string", + "value": "[variables('hostingPlanName')]" + }, + "location": { + "type": "string", + "value": "[parameters('location')]" + }, + "tags": { + "type": "object", + "value": "[parameters('tags')]" + } + } +} \ No newline at end of file diff --git a/intelligence_toolkit/AI/defaults.py b/intelligence_toolkit/AI/defaults.py index a120cec9..f82dd2ad 100644 --- a/intelligence_toolkit/AI/defaults.py +++ b/intelligence_toolkit/AI/defaults.py @@ -10,7 +10,7 @@ EMBEDDING_BATCHES_NUMBER = 500 # # Text Embedding Parameters -DEFAULT_EMBEDDING_MODEL = "text-embedding-ada-002" +DEFAULT_EMBEDDING_MODEL = "text-embedding-3-small" DEFAULT_TEMPERATURE = 0 DEFAULT_MAX_INPUT_TOKENS = 128000 DEFAULT_OPENAI_VERSION = "2023-12-01-preview" diff --git a/pyproject.toml b/pyproject.toml index 2afaa3ea..d91e4a8f 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -1,6 +1,6 @@ [tool.poetry] name = "intelligence-toolkit" -version = "0.0.2" +version = "0.0.3" description = "Interactive workflows for generating AI intelligence reports from real-world data sources using GPT models" authors = [ "Dayenne Souza ",