Skip to content

Collaborating on TeamsFx Project

turenlong edited this page May 18, 2022 · 5 revisions

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.

Collaborating - Use VSCode

Usage

  • 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:

    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):

    input-collaborator-email

  • Click List permission button on the right to view all collaborators for the current environment: view-collaborators

  • 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) secret-file

    • 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

Collaborating - Use CLI

Teams Toolkit CLI provides teamsFx permission Commands for collaboration scenario.

Commands

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

Parameters for teamsfx permission grant

  • --env

    (Required) Provide env name.

  • --email

    (Required) Provide collaborator's M365 email address. Note that the collaborators's account should be in the same tenant with creator.

Parameters for teamsfx permission status

  • --env

    (Required) Provide env name.

  • --list-all-collaborators

    With this flag, Teams Toolkit CLI will print out all collaborators for this project.

Examples

Here are some examples for you to better handling permission for TeamsFx projects.

Grant Permission

teamsfx permission grant --env dev --email user-email@user-tenant.com

Show current user Permission Status

teamsfx permission status --env dev

List All Collaborators

teamsfx permission status --env dev --list-all-collaborators

Limitations of collaboration feature

  • 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:

    403-error

Clone this wiki locally