-
Notifications
You must be signed in to change notification settings - Fork 0
/
teamsapp.yml
85 lines (78 loc) · 5.28 KB
/
teamsapp.yml
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
# Visit https://aka.ms/teamsfx-v5.0-guide for details on this file
# Visit https://aka.ms/teamsfx-actions for details on actions
version: 1.0.0
environmentFolderPath: ./env
# Triggered when 'teamsfx provision' is executed
provision:
- uses: botAadApp/create # Creates a new AAD app for Bot Registration.
with:
name: message-extension-bot
# Output: following environment variable will be persisted in current environment's .env file.
# BOT_ID: the AAD app client id created for Bot Registration.
# SECRET_BOT_PASSWORD: the AAD app client secret created for Bot Registration.
- uses: arm/deploy # Deploy given ARM templates parallelly.
with:
subscriptionId: ${{AZURE_SUBSCRIPTION_ID}} # The AZURE_SUBSCRIPTION_ID is a built-in environment variable. TeamsFx will ask you select one subscription if its value is empty. You're free to reference other environment varialbe here, but TeamsFx will not ask you to select subscription if it's empty in this case.
resourceGroupName: ${{AZURE_RESOURCE_GROUP_NAME}} # The AZURE_RESOURCE_GROUP_NAME is a built-in environment variable. TeamsFx will ask you to select or create one resource group if its value is empty. You're free to reference other environment varialbe here, but TeamsFx will not ask you to select or create resource grouop if it's empty in this case.
templates:
- path: ./infra/azure.bicep
parameters: ./infra/azure.parameters.json
deploymentName: Create-resources-for-bot
bicepCliVersion: v0.9.1 # Teams Toolkit will download this bicep CLI version from github for you, will use bicep CLI in PATH if you remove this config.
# Output: every bicep output will be persisted in current environment's .env file with certain naming conversion. Refer https://aka.ms/teamsfx-actions/arm-deploy for more details on the naming conversion rule.
# Triggered when 'teamsfx deploy' is executed
deploy:
- uses: cli/runNpmCommand # Run npm command
with:
args: install
- uses: cli/runNpmCommand
with:
args: run build --if-present
- uses: azureAppService/deploy # Deploy bits to Azure App Serivce
with:
distributionPath: . # Deploy base folder
ignoreFile: ./.webappignore # Can be changed to any ignore file location, leave blank will ignore nothing
resourceId: ${{BOT_AZURE_APP_SERVICE_RESOURCE_ID}} # The resource id of the cloud resource to be deployed to. This key will be generated by arm/deploy action automatically. You can replace it with your existing Azure Resource id or add it to your environment variable file.
# Triggered when 'teamsfx provision' is executed
registerApp:
- uses: teamsApp/create # Creates a Teams app
with:
name: me-ai-sdk-ttk-${{TEAMSFX_ENV}} # Teams app name
# Output: following environment variable will be persisted in current environment's .env file.
# TEAMS_APP_ID: the id of Teams app
# Triggered when 'teamsfx provision' is executed
configureApp:
- uses: teamsApp/validate # This action is currently skipped, will be updated in the future version.
with:
manifestPath: ./appPackage/manifest.json # Path to manifest template
- uses: teamsApp/zipAppPackage # Build Teams app package with latest env value
with:
manifestPath: ./appPackage/manifest.json # Path to manifest template
outputZipPath: ./build/appPackage/appPackage.${{TEAMSFX_ENV}}.zip
outputJsonPath: ./build/appPackage/manifest.${{TEAMSFX_ENV}}.json
- uses: teamsApp/update # Apply the Teams app manifest to an existing Teams app in Teams Developer Portal. Will use the app id in manifest file to determine which Teams app to update.
with:
appPackagePath: ./build/appPackage/appPackage.${{TEAMSFX_ENV}}.zip # Relative path to this file. This is the path for built zip file.
# Output: following environment variable will be persisted in current environment's .env file.
# TEAMS_APP_ID: the id of Teams app
# Triggered when 'teamsfx publish' is executed
publish:
- uses: teamsApp/validate # This action is currently skipped, will be updated in the future version.
with:
manifestPath: ./appPackage/manifest.json # Path to manifest template
- uses: teamsApp/zipAppPackage
with:
manifestPath: ./appPackage/manifest.json # Path to manifest template
outputZipPath: ./build/appPackage/appPackage.${{TEAMSFX_ENV}}.zip
outputJsonPath: ./build/appPackage/manifest.${{TEAMSFX_ENV}}.json
- uses: teamsApp/update # Apply the Teams app manifest to an existing Teams app in Teams Developer Portal. Will use the app id in manifest file to determine which Teams app to update.
with:
appPackagePath: ./build/appPackage/appPackage.${{TEAMSFX_ENV}}.zip # Relative path to this file. This is the path for built zip file.
# Output: following environment variable will be persisted in current environment's .env file.
# TEAMS_APP_ID: the id of Teams app
- uses: teamsApp/publishAppPackage # Publish the app to Teams Admin Center (https://admin.teams.microsoft.com/policies/manage-apps) for review and approval
with:
appPackagePath: ./build/appPackage/appPackage.${{TEAMSFX_ENV}}.zip
# Output: following environment variable will be persisted in current environment's .env file.
# TEAMS_APP_PUBLISHED_APP_ID: app id in Teams tenant app catalog.
projectId: 7928ab9b-1d7c-4559-a143-9681b8224295