-
Notifications
You must be signed in to change notification settings - Fork 202
Collaborating on TeamsFx Project
Previous version of Teams Toolkit is not easy for multiple users to develop the same project due to missing privilege to access Teams APP and AAD APP. If multiple developers want to share remote resources and work together, they need to manually handle permissions of Teams App and AAD APP which need deep understanding the low-level details about the TeamsFx project.
Teams Toolkit now natively support add other collaborators for TeamsFx project which is much easy and straightforward for collaborative development.
-
To use collaboration feature, you need to login M365 and Azure account and your TeamsFx project should be provisioned first
-
In the Teams Toolkit panel, click ENVIRONMENT, and expand an environment name which you want to work with others, then you can see collaboration buttons:
-
Click grant permission button on the left, then you can add another M365 account email address as collaborator (this account should be in the same tenant with your M365 account):
-
Click List permission button on the right to view all collaborators for the current environment:
-
Share your project and secret file with the collaborator:
-
Commit your project to GitHub repository
-
Collaborator clone the project to his computer
-
Share secret file
.fx\states\[Environment-Name].userdata
to the collaborator (This step is not strictly required for Tab project, however, if your project contains Bot, this is required) -
Collaborator copy the secret file to the project folder
-
-
Collaborator login to M365 account, and login Azure account which at least has contributor permission for all the Azure resources
-
Now collaborator can develop, provision and deploy the project
Teams Toolkit CLI provides teamsFx permission
Commands for collaboration scenario.
teamsFx permission Commands |
Descriptions |
---|---|
teamsfx permission grant |
Grant permission for collaborator's M365 account for the project |
teamsfx permission status |
Show permission status for the project |
-
(Required) Provide env name.
-
(Required) Provide collaborator's M365 email address. Note that the collaborators's account should be in the same tenant with creator.
-
(Required) Provide env name.
-
With this flag, Teams Toolkit CLI will print out all collaborators for this project.
Here are some examples for you to better handling permission for TeamsFx
projects.
teamsfx permission grant --env dev --email user-email@user-tenant.com
teamsfx permission status --env dev
teamsfx permission status --env dev --list-all-collaborators
-
Azure related permissions should be handled manually by the Azure subscription administrator via Azure portal, different Azure account should at least have contributor role for the subscription so that developers can work together to provision and deploy TeamsFx project. For more information about how to assign Azure roles using the Azure portal, you can refer this doc.
-
For best practice, creator of the project should share secret file
.fx\states\[Environment-Name].userdata
with the collaborator. This is strict required if project contains Bot capability, otherwise collaborator will receive errors as below when provision:
Build Custom Engine Copilots
- Build a basic AI chatbot for Teams
- Build an AI agent chatbot for Teams
- Expand AI bot's knowledge with your content
Scenario-based Tutorials
- Send notifications to Teams
- Respond to chat commands in Teams
- Respond to card actions in Teams
- Embed a dashboard canvas in Teams
Extend your app across Microsoft 365
- Teams tabs in Microsoft 365 and Outlook
- Teams message extension for Outlook
- Add Outlook Add-in to a Teams app
App settings and Microsoft Entra Apps
- Manage Application settings with Teams Toolkit
- Manage Microsoft Entra Application Registration with Teams Toolkit
- Use an existing Microsoft Entra app
- Use a multi-tenant Microsoft Entra app
Configure multiple capabilities
- How to configure Tab capability within your Teams app
- How to configure Bot capability within your Teams app
- How to configure Message Extension capability within your Teams app
Add Authentication to your app
- How to add single sign on in Teams Toolkit for Visual Studio Code
- How to enable Single Sign-on in Teams Toolkit for Visual Studio
Connect to cloud resources
- How to integrate Azure Functions with your Teams app
- How to integrate Azure API Management
- Integrate with Azure SQL Database
- Integrate with Azure Key Vault
Deploy apps to production