-
Notifications
You must be signed in to change notification settings - Fork 205
How to Switch Microsoft 365 Tenant
This doc is to help you mitigate the error when the Microsoft 365 tenant of your currently signed-in account does not match with what you previously used. If you are using Teams Toolkit v4, please check Teams Toolkit V4
"M365TenantIdNotMatchError" error may occur when you local debug or kick off provisioning resources in a remote environment but we notice that the Microsoft 365 tenant you are currently using is different from what recorded in .env file. We will not provision AAD or Bot resources in the new tenant by default but would like to ask you to confirm the account and then follow the mitigation steps mentioned below to either fix the wrong account or continue provisioning resources in the new tenant.
- Check your Microsoft 365 account.
a) If you switched to the account unintentionally , please sign out of the current account and sign in with the correct one. Continue local debugging or provision in remote environemnt.
b) If you plan to continue with the new account to provision resources in new tenant, please follow step 2. - To provision resources in new tenant,
- Clear the value of following keys in
.env.{env}
file in teamsfx folder. For example, the file would be .env.dev for dev environment,- Clear the value of TEAMS_APP_TENANT_ID in .env.
- Clear the value of AAD_APP_CLIENT_ID if you need an AAD aap.
- Clear the value of BOT_ID if your project includes a Bot app.
- Start local debugging or provision, and Teams Toolkit will provision resources in the new Microsoft 365 tenant.
- Clear the value of following keys in
Info below will help you understand what will happen when provisioning in an already-provisioned environment but with different account or Azure subscription or local debugging again with another Microsoft 365 account. We will also explain how to recover from the backups.
Important Notes: After switching accounts and provisioning or local debugging again, resources have been created before in the old Microsoft 365 tenant or Azure subscription won't be deleted by default, and you have to manully delete them to avoid further costs if any.
You could run local debugging for a Teams project with one Microsoft 365 tenant and then easily switch to another tenant for further local debugging. To do this, you only need to:
- Sign out of the current Microsoft 365 account.
- Sign in to the new account.
- Start local debugging.
After that, we will
- Back up configuration files for local environment. Learn more about backup & recover.
- Create all resources required for the local environment in the new Microsoft 365 tenant.
-
state.local.json
file in .fx/states folder will be overwritten with the information of new resources in the new Microsoft 365 tenant. If the project requires AAD,local.userdata
will be overwritten with the new client secret.
You could provision resources in a remote environment with one Microsoft 365 tenant and then re-provision in the same environment but with another Microsoft 365 tenant. To do this, you only need to:
- Sign out of the current Microsoft 365 account.
- Sign in to the new account.
- Start provision in the selected environment.
After that, we will
- Back up configuration files for the selected environment. Learn more about backup & recover.
- Create a new Teams app and a new AAD app (if needed) in the new Microsoft 365 tenant.
- If the project requires Azure bot service, we will generate a new bot service name and save it as the value of "botServiceName" in
azure.parameters.{env}.json
. We will use this new name to provision a new Azure bot service in the selected resource group and the subscription since it is not allowed to edit the value of Microsoft App ID of an existing Azure bot service. - If the project requires AAD,
{env}.userdata
will be overwritten with the new client secret.
You could provision Azure resources of a remote environment in one Azure subscription and then switch to another Azure subscription for this environment. To do this, you only need to:
- Sign out of the current Azure account if the subscription you are going to use is in another Azure account.
- Select the correct subscription.
- Start provision in the selected environment.
After that, we will
- Back up configuration files for the selected environment. Learn more about backup & recover.
- Update the value of "resourceBaseName" in
azure.parameters.{env}.json
. - If the project contains Azure bot service, we will create a new AAD app since a Microsoft App ID is required to create an Azure Bot resourc and one Microsoft App Id can only be registered to one bot application. We will replace the value of "fx-resource-bot.botPassword" in
{env.userdata}
with the new secret. - Start provision in the selected environment.
Configuration files will be overwritten by Teams Toolkit when provisioning in an already-provisioned environment but with different Microsoft 365 tenant or Azure subscription or local debugging again with another Microsoft 365 tenant. We will back up those files so that you could use the backups to locate the resources created using the previous account and then delete what you no longer need. Also with the help of backups, you could continue using the resources created before easily when you decide to switch back to the accounts or the subscription that you selected before. Otherwise, new resources will be created, and you have to delete the old resources manully to avoid costs.
We will keep all backups in the .backup/.fx folder and name those backups with the current date and time in the format of YYYYMMDDHHMMSS (which is the value of "time" mentioned below) when a backup happens. "env" below indicates the environment you select, which could be local or any remote environment.
- The backup of
state.{env}.json
will bestate.{env}.{time}.json
in the .backup/.fx/states folder which contains generated resources information of the local or remote environment. -
azure.parameters.{env}.json
will be copied and saved toazure.parameters.{env}.{time}.json
in the .backup/.fx/configs folder if your project contains Azure resources and you have selected a remote environment. - The backup of
{env}.userdata
which exists when your project requires AAD will be{env}.{time}.userdata
in the ./backup/.fx/statesfolder which contains secret information.
If you want to switch back to the account or subscription and reuse resources that have been provisioned before:
- Sign in with the correct accounts and select the correct Azure subscription.
- Determine the date and time of the backup that you want to recover.
- Keep a copy of
state.{env}.json
,azure.parameters.{env}.json
and{env}.userdata
. - Copy the content of
state.{env}.{time}.json
tostate.{env}.json
.
Note: if you want to recover for a remote environment and you have added new features, please edit the value of "provisionSucceeded" to "false" to provision resources required for the newly added features. - If
{env}.{time}.userdata
exists in the backup folder, replace the content of{env}.userdata
with the content of{env}.{time}.userdata
. - If you want to recover for a remote environment and your project previously contains Azure sources, update the value of "resourceBaseName" and "botServiceName"(delete this key if not exists) to the value defined in
azure.parameters.{env}.{time}.json
. - Run provision and deploy again.
- Delete the backups when you think there is no need to keep them.
If you have previewed (local or remote) your Teams app in one Microsoft 365 tenant and then switch to another Microsoft 365 account, you may encounter error as shown below
once the browser is launched when previewing in the new Microsoft 365 tenant. If clicking "try again" or waiting for a few seconds to let Teams bring you to the sign in page, you may notice that the page won't be redirected correctly to the page of adding the Teams app. This happens due to the previous account info saved in the browser storage.
-
Launch browser with userData
By default, the browser is launched with a separate user profile in a temp folder. You could override the value of "userDataDir" to "true" and then specify the path of user data folder in runtimeArgs.-
Visual Studio Code
For example, when you sign in with another Microsoft 365 account for local debugging, you could replace{ "name": "Attach to Frontend (Edge)", "type": "pwa-msedge", "request": "launch", "url": "https://teams.microsoft.com/l/app/${localTeamsAppId}?installAppPackage=true&webjoin=true&${account-hint}", "presentation": { "group": "all", "hidden": true } }
with
{ "name": "Attach to Frontend (Edge)", "type": "pwa-msedge", "request": "launch", "url": "https://teams.microsoft.com/l/app/${localTeamsAppId}?installAppPackage=true&webjoin=true&${account-hint}", "presentation": { "group": "all", "hidden": true }, "userDataDir": true, // Enable to use customized user data folder. "runtimeArgs": [ "--user-data-dir=C:\\Users\\{username}\\temp\\edge\\tenantb" // Pass the path of user data folder here. ] }
If you want to switch back to the previous Microsoft 365 tenant for local debugging, please remove the lines about userDataDir and runtimeArgs that you just added before starting local debugging again.
You could also specify the path of user data folder for each tenant, and edit the value of "user-data-dir" in runtimeArgs whenever you switch tenant for preview.
-
Visual Studio
When running local debug of a Teams project launched in Visual Studio, you could create a new browser configuration after switching to another Microsoft 365 tenant by following steps mentioned in Add Browser Configuration in Visual Studio. Type--user-data-dir=C:\\Users\\{username}\\temp\\edge\\tenantb
(replace the path with what it makes sense to you) as the argument when adding the program. And then choose the corresponding browser configuration before local debugging.If you want to preview a Teams app in Visual Studio after switching Microsoft 365 tenant, you could copy the preview URL shown in the output pane and then run your browser with arguments using command line. For example, you could start Edge with
msedge.exe --user-data-dir="C:\\Users\\{username}\\temp\\edge\\tenantb"
. Once the browser is launched, paste the preview URL.
-
-
Launch browser in incognito mode
This may not work for you if your org enables condition access.-
Visual Studio Code
runtimeArgs are the arguments passed to the runtime executable. You could edit the launch configuration by adding"runtimeArgs": ["--inprivate"]
(for Edge) or"runtimeArgs": ["--incognito"]
(for Chrome) to launch the browser in incognito mode. For example, you could replace{ "name": "Attach to Frontend (Edge)", "type": "pwa-msedge", "request": "launch", "url": "https://teams.microsoft.com/l/app/${localTeamsAppId}?installAppPackage=true&webjoin=true&${account-hint}", "presentation": { "group": "all", "hidden": true } }
with
{ "name": "Attach to Frontend (Edge)", "type": "pwa-msedge", "request": "launch", "url": "https://teams.microsoft.com/l/app/${localTeamsAppId}?installAppPackage=true&webjoin=true&${account-hint}", "presentation": { "group": "all", "hidden": true }, "runtimeArgs": ["--inprivate"] // runtimeArgs that you need to add }
to always start Edge in InPrivate browsing mode when local debugging.
-
Visual Studio
Similarly, for a Teams project launched in Visual Studio, you could create a new browser configuration by following steps mentioned in Add Browser Configuration in Visual Studio. For arguments when adding the program, type--inPrivate
(Edge) or--incognito
(Chrome).If you want to preview a Teams app in a remote environment, you could launch the browser in incognito mode and then copy the preview URL shown in the output pane and paste it in the browser.
-
After preparing Teams app dependencies again in Visual Studio with another Microsoft 365 account in a different tenant, you may notice issues like receiving 401 response when sending a bot command or could not authorize to get the user's profile photo in the tab as the image shown below when local debugging.
We are still improving this scenario but for now a workaround is:
- Please keep a copy of the current content of appsettings.Development.json.
- Delete appsettings.Development.json
- Run F5 again.
- If you have customized appsettings.Development.json before, please restore these values based on the backup.
You may meet 409 conflict error when the Teams app id provided in .env.{env}.json
(state.{env}.json file
if you are using V4) file is conflicting with another Teams app under the same tenant. This usually happens when developers work on the same project, or switch account under same tenant. To resolve it, you can either be added as the owner of existing Teams app, or use another Teams app id to avoid conflict.
You need to know who owns the existing Teams app, and let the owner add your M365 account to the owner list. Please refer to Collaborate on Teams project using Microsoft Teams Toolkit.
You can manually update Teams app id in .env.{env}.json
file (If you are using Teams Toolkit V4, it should be state.{env}.json file
). Run "Provision to the Cloud" again to create the Teams app. Teams Toolkit will generate a new Teams app id.
To create a new browser configuration in Visual Studio, you could
- Open the dropdown and select "Browser with".
- Select "Ädd" to add a new profile
- Find the path of the program, type the arguments you need in the field of "Arguments", and give it a friendly name. For example, we add a new configuration for Edge inPrivate mode as shown in the image below.
- Select the newly added broswer configuration and then Visual Studio will launch browser with the selected configuration.
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