Skip to content
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
58aea18
Added main.biceppram file and removed hard coded var values in bicep
TravisHilbert May 5, 2025
d79a91e
updating azure.yaml
TravisHilbert May 5, 2025
f20dd49
Update azure-dev.yml
gpickett May 5, 2025
dff0019
Update azure-dev.yml
gpickett May 5, 2025
5d622ad
Update azure-dev.yml
gpickett May 5, 2025
5ea9588
Update azure-dev.yml
gpickett May 5, 2025
63996fd
Merge pull request #178 from microsoft/gpickett-patch-2
gpickett May 5, 2025
48f6ad2
Merge branch 'main' into dev
Abdul-Microsoft May 6, 2025
c950dae
Remove main.bicepparam file and its parameters
Abdul-Microsoft May 6, 2025
155d295
Merge remote-tracking branch 'origin/main' into dev
Prashant-Microsoft May 6, 2025
10ef8d2
testing var named imageName
TravisHilbert May 6, 2025
e9b9319
Merge branch 'dev' of https://github.com/microsoft/Multi-Agent-Custom…
TravisHilbert May 6, 2025
bf882a9
reverting change
TravisHilbert May 6, 2025
bd62025
feat: add historical tagging to Docker image builds
Abdul-Microsoft May 7, 2025
84cadee
added changes for testing from feature branch
Abdul-Microsoft May 7, 2025
9b8944d
refactor: improve Docker build workflow by restructuring tag determin…
Abdul-Microsoft May 7, 2025
034fb65
refactor: streamline Docker image build and push steps using build-pu…
Abdul-Microsoft May 7, 2025
706b48a
remove feature branch from Docker build workflow triggers
Abdul-Microsoft May 7, 2025
243a6cf
Merge pull request #187 from microsoft/feature/psl-conregchanges
Roopan-Microsoft May 7, 2025
51c2d70
Testing ai key error fix
TravisHilbert May 7, 2025
198ddc8
Merge branch 'dev' of https://github.com/microsoft/Multi-Agent-Custom…
Prashant-Microsoft May 12, 2025
bc515a3
test files folder structure changed
Ravikirana-Microsoft May 13, 2025
5cf57cc
added kernal_agent folder
May 13, 2025
4d906f4
Remove folders and files
UtkarshMishra-Microsoft May 13, 2025
a606b9f
added test_marketing_tools.py
May 19, 2025
1dff194
solved pylint issues of marketing_tools.py
May 19, 2025
588eefa
edit2
May 19, 2025
931a03b
test_runtime_interrupt_kernal_file
UtkarshMishra-Microsoft May 19, 2025
c876e6b
Merge branch 'psl-backend-sk-unit-test' of https://github.com/microso…
UtkarshMishra-Microsoft May 19, 2025
d01fa9e
added test_messages_kernel.py
May 23, 2025
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
68 changes: 9 additions & 59 deletions .github/workflows/azure-dev.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,69 +15,19 @@ permissions:
jobs:
template_validation_job:
runs-on: ubuntu-latest
name: Template validation
name: template validation
steps:
# Step 1: Checkout the code from your repository
- name: Checkout code
uses: actions/checkout@v4
- uses: actions/checkout@v4

# Step 2: Set up Python
- name: Set up Python
uses: actions/setup-python@v4
with:
python-version: "3.9"

# Step 3: Create and populate the virtual environment
- name: Create virtual environment and install dependencies
run: |
python -m venv .venv
source .venv/bin/activate
python -m pip install --upgrade pip
pip install azure-mgmt-resource azure-identity azure-core azure-mgmt-subscription azure-cli-core
# Install any other dependencies that might be needed
pip freeze > requirements-installed.txt
echo "Virtual environment created with these packages:"
cat requirements-installed.txt

# Step 4: Create azd directory if it doesn't exist
- name: Create azd directory
run: |
mkdir -p ./.azd || true
touch ./.azd/.env || true

# Step 5: Validate the Azure template
- name: Validate Azure Template
uses: microsoft/[email protected]
- uses: microsoft/template-validation-action@Latest
id: validation
env:
AZURE_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
AZURE_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }}
AZURE_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
AZURE_ENV_NAME: ${{ secrets.AZURE_ENV_NAME }}
AZURE_LOCATION: ${{ secrets.AZURE_LOCATION }}
AZURE_CLIENT_ID: ${{ vars.AZURE_CLIENT_ID }}
AZURE_TENANT_ID: ${{ vars.AZURE_TENANT_ID }}
AZURE_SUBSCRIPTION_ID: ${{ vars.AZURE_SUBSCRIPTION_ID }}
AZURE_ENV_NAME: ${{ vars.AZURE_ENV_NAME }}
AZURE_LOCATION: ${{ vars.AZURE_LOCATION }}
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}

# Step 6: Debug output in case of failure
- name: Debug on failure
if: failure()
run: |
echo "Validation failed. Checking environment:"
ls -la
if [ -d ".venv" ]; then
echo ".venv directory exists"
ls -la .venv/bin/
else
echo ".venv directory does not exist"
fi
if [ -d "tva_*" ]; then
echo "TVA directory exists:"
find . -name "tva_*" -type d
ls -la $(find . -name "tva_*" -type d)
else
echo "No TVA directory found"
fi

# Step 7: Print the result of the validation
- name: Print result
if: success()
- name: print result
run: cat ${{ steps.validation.outputs.resultFile }}
55 changes: 33 additions & 22 deletions .github/workflows/docker-build-and-push.yml
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ on:
- dev
- demo
- hotfix
workflow_dispatch:
workflow_dispatch:

jobs:
build-and-push:
Expand All @@ -32,14 +32,19 @@ jobs:
uses: docker/setup-buildx-action@v1

- name: Log in to Azure Container Registry
if: ${{ (github.ref_name == 'main' || github.ref_name == 'dev' || github.ref_name == 'demo' || github.ref_name == 'hotfix') }}
if: ${{ github.ref_name == 'main' || github.ref_name == 'dev' || github.ref_name == 'demo' || github.ref_name == 'hotfix' }}
uses: azure/docker-login@v2
with:
login-server: ${{ secrets.ACR_LOGIN_SERVER }}
username: ${{ secrets.ACR_USERNAME }}
password: ${{ secrets.ACR_PASSWORD }}

- name: Set Docker image tag
- name: Get current date
id: date
run: echo "date=$(date +'%Y-%m-%d')" >> $GITHUB_OUTPUT

- name: Determine Tag Name Based on Branch
id: determine_tag
run: |
if [[ "${{ github.ref }}" == "refs/heads/main" ]]; then
echo "TAG=latest" >> $GITHUB_ENV
Expand All @@ -52,24 +57,30 @@ jobs:
else
echo "TAG=pullrequest-ignore" >> $GITHUB_ENV
fi
- name: Build and push Docker images optionally

- name: Set Historical Tag
run: |
cd src/backend
docker build -t ${{ secrets.ACR_LOGIN_SERVER }}/macaebackend:${{ env.TAG }} -f Dockerfile . && \
if [[ "${{ env.TAG }}" == "latest" || "${{ env.TAG }}" == "dev" || "${{ env.TAG }}" == "demo" || "${{ env.TAG }}" == "hotfix" ]]; then
docker push ${{ secrets.ACR_LOGIN_SERVER }}/macaebackend:${{ env.TAG }} && \
echo "Backend image built and pushed successfully."
else
echo "Skipping Docker push for backend with tag: ${{ env.TAG }}"
fi
cd ../frontend
docker build -t ${{ secrets.ACR_LOGIN_SERVER }}/macaefrontend:${{ env.TAG }} -f Dockerfile . && \
if [[ "${{ env.TAG }}" == "latest" || "${{ env.TAG }}" == "dev" || "${{ env.TAG }}" == "demo" || "${{ env.TAG }}" == "hotfix" ]]; then
docker push ${{ secrets.ACR_LOGIN_SERVER }}/macaefrontend:${{ env.TAG }} && \
echo "Frontend image built and pushed successfully."
else
echo "Skipping Docker push for frontend with tag: ${{ env.TAG }}"
fi
DATE_TAG=$(date +'%Y-%m-%d')
RUN_ID=${{ github.run_number }}
# Create historical tag using TAG, DATE_TAG, and RUN_ID
echo "HISTORICAL_TAG=${{ env.TAG }}_${DATE_TAG}_${RUN_ID}" >> $GITHUB_ENV


- name: Build and optionally push Backend Docker image
uses: docker/build-push-action@v6
with:
context: ./src/backend
file: ./src/backend/Dockerfile
push: ${{ env.TAG != 'pullrequest-ignore' }}
tags: |
${{ secrets.ACR_LOGIN_SERVER }}/macaebackend:${{ env.TAG }}
${{ secrets.ACR_LOGIN_SERVER }}/macaebackend:${{ env.HISTORICAL_TAG }}

- name: Build and optionally push Frontend Docker image
uses: docker/build-push-action@v6
with:
context: ./src/frontend
file: ./src/frontend/Dockerfile
push: ${{ env.TAG != 'pullrequest-ignore' }}
tags: |
${{ secrets.ACR_LOGIN_SERVER }}/macaefrontend:${{ env.TAG }}
${{ secrets.ACR_LOGIN_SERVER }}/macaefrontend:${{ env.HISTORICAL_TAG }}
8 changes: 4 additions & 4 deletions infra/deploy_ai_foundry.bicep
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ param gptModelName string
param gptModelVersion string
param managedIdentityObjectId string
param aiServicesEndpoint string
param aiServicesKey string
param aiServices object
param aiServicesId string

var storageName = '${solutionName}hubstorage'
Expand Down Expand Up @@ -136,7 +136,7 @@ resource aiHub 'Microsoft.MachineLearningServices/workspaces@2023-08-01-preview'
authType: 'ApiKey'
isSharedToAll: true
credentials: {
key: aiServicesKey
key: aiServices.Key.key1
}
metadata: {
ApiType: 'Azure'
Expand Down Expand Up @@ -187,7 +187,7 @@ resource azureOpenAIApiKeyEntry 'Microsoft.KeyVault/vaults/secrets@2021-11-01-pr
parent: keyVault
name: 'AZURE-OPENAI-KEY'
properties: {
value: aiServicesKey //aiServices_m.listKeys().key1
value: aiServices.Key.key1 //aiServices_m.listKeys().key1
}
}

Expand Down Expand Up @@ -251,7 +251,7 @@ resource cogServiceKeyEntry 'Microsoft.KeyVault/vaults/secrets@2021-11-01-previe
parent: keyVault
name: 'COG-SERVICES-KEY'
properties: {
value: aiServicesKey
value: aiServices.Key.key1
}
}

Expand Down
34 changes: 16 additions & 18 deletions infra/main.bicep
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
targetScope = 'resourceGroup'
@description('Location for all resources.')
param location string
// @description('Location for all resources.')
// param location string

@allowed([
'australiaeast'
Expand Down Expand Up @@ -28,15 +28,12 @@ param location string
'westus3'
])
@description('Location for all Ai services resources. This location can be different from the resource group location.')
param azureOpenAILocation string = 'eastus2' // The location used for all deployed resources. This location must be in the same region as the resource group.
param azureOpenAILocation string //= 'eastus2' // The location used for all deployed resources. This location must be in the same region as the resource group.

@minLength(3)
@maxLength(20)
@description('A unique prefix for all resources in this deployment. This should be 3-20 characters long:')
param environmentName string

var uniqueId = toLower(uniqueString(subscription().id, environmentName, resourceGroup().location))
var solutionPrefix = 'ma${padLeft(take(uniqueId, 12), 12, '0')}'
@description('Prefix for all resources created by this template. This prefix will be used to create unique names for all resources. The prefix must be unique within the resource group.')
param prefix string //= 'macae'

@description('Tags to apply to all deployed resources')
param tags object = {}
Expand All @@ -61,8 +58,9 @@ param resourceSize {
}
param capacity int = 140

var location = resourceGroup().location
var modelVersion = '2024-08-06'
var aiServicesName = '${solutionPrefix}-aiservices'
var aiServicesName = '${prefix}-aiservices'
var deploymentType = 'GlobalStandard'
var gptModelVersion = 'gpt-4o'
var appVersion = 'fnd01'
Expand All @@ -73,7 +71,7 @@ var dockerRegistryUrl = 'https://${resgistryName}.azurecr.io'
var backendDockerImageURL = '${resgistryName}.azurecr.io/macaebackend:${appVersion}'
var frontendDockerImageURL = '${resgistryName}.azurecr.io/macaefrontend:${appVersion}'

var uniqueNameFormat = '${solutionPrefix}-{0}-${uniqueString(resourceGroup().id, solutionPrefix)}'
var uniqueNameFormat = '${prefix}-{0}-${uniqueString(resourceGroup().id, prefix)}'
var aoaiApiVersion = '2025-01-01-preview'

resource logAnalytics 'Microsoft.OperationalInsights/workspaces@2023-09-01' = {
Expand Down Expand Up @@ -123,7 +121,7 @@ resource aiServices 'Microsoft.CognitiveServices/accounts@2024-04-01-preview' =
apiProperties: {
//statisticsEnabled: false
}
//disableLocalAuth: true
disableLocalAuth: true
}
}

Expand All @@ -149,7 +147,7 @@ resource aiServicesDeployments 'Microsoft.CognitiveServices/accounts/deployments
module kvault 'deploy_keyvault.bicep' = {
name: 'deploy_keyvault'
params: {
solutionName: solutionPrefix
solutionName: prefix
solutionLocation: location
managedIdentityObjectId: managedIdentityModule.outputs.managedIdentityOutput.objectId
}
Expand All @@ -163,14 +161,14 @@ module kvault 'deploy_keyvault.bicep' = {
module aifoundry 'deploy_ai_foundry.bicep' = {
name: 'deploy_ai_foundry'
params: {
solutionName: solutionPrefix
solutionName: prefix
solutionLocation: azureOpenAILocation
keyVaultName: kvault.outputs.keyvaultName
gptModelName: gptModelVersion
gptModelVersion: gptModelVersion
managedIdentityObjectId: managedIdentityModule.outputs.managedIdentityOutput.objectId
aiServicesEndpoint: aiServices.properties.endpoint
aiServicesKey: aiServices.listKeys().key1
aiServices: aiServices
aiServicesId: aiServices.id
}
scope: resourceGroup(resourceGroup().name)
Expand Down Expand Up @@ -205,7 +203,7 @@ resource cosmos 'Microsoft.DocumentDB/databaseAccounts@2024-05-15' = {
}
]
capabilities: [{ name: 'EnableServerless' }]
//disableLocalAuth: true
disableLocalAuth: true
}

resource contributorRoleDefinition 'sqlRoleDefinitions' existing = {
Expand Down Expand Up @@ -279,7 +277,7 @@ resource acaCosomsRoleAssignment 'Microsoft.DocumentDB/databaseAccounts/sqlRoleA

@description('')
resource containerApp 'Microsoft.App/containerApps@2024-03-01' = {
name: '${solutionPrefix}-backend'
name: '${prefix}-backend'
location: location
tags: tags
identity: {
Expand Down Expand Up @@ -448,7 +446,7 @@ resource frontendAppService 'Microsoft.Web/sites@2021-02-01' = {
}

resource aiHubProject 'Microsoft.MachineLearningServices/workspaces@2024-01-01-preview' existing = {
name: '${solutionPrefix}-aiproject' // aiProjectName must be calculated - available at main start.
name: '${prefix}-aiproject' // aiProjectName must be calculated - available at main start.
}

resource aiDeveloper 'Microsoft.Authorization/roleDefinitions@2022-04-01' existing = {
Expand All @@ -469,7 +467,7 @@ var cosmosAssignCli = 'az cosmosdb sql role assignment create --resource-group "
module managedIdentityModule 'deploy_managed_identity.bicep' = {
name: 'deploy_managed_identity'
params: {
solutionName: solutionPrefix
solutionName: prefix
//solutionLocation: location
managedIdentityId: pullIdentity.id
managedIdentityPropPrin: pullIdentity.properties.principalId
Expand Down
Loading
Loading