page_type | description | products | languages | extensions | urlFragment | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
sample |
This is a sample app which shows connector authentication and sends notification on task creation. |
|
|
|
officedev-microsoft-teams-samples-connector-todo-notification-nodejs |
This is a sample connector application which demonstarates how to add authentication to connector configuration page and send notification on task creation.
For more information on developing apps for Microsoft Teams, please review the Microsoft Teams developer documentation.
- Microsoft Teams is installed and you have an account (not a guest account)
- NodeJS
- ngrok or equivalent tunneling solution
- M365 developer account or access to a Teams account with the appropriate permissions to install an app.
- Upload your custom app in Microsoft Teams using this manifest file.
- Configure the Connector.
- Select either Create or Update on the registration page and click Save.
- Once the connector is configured, you will get a notification in channel for the configured connector.
Note: With the above instructions, you can use sample connector which is deployed on Azure. Please follow the instructions below to create your own connector.
The sample shows a simple implementation of a connector registration implementation. It also sends a connector card to the registered connector via a process triggered "externally."
- Clone the repository
git clone https://github.com/OfficeDev/Microsoft-Teams-Samples.git
- In a terminal, navigate to
samples/connector-auth-nodejs/nodejs
- Install node modules using command npm install.
- Run your app using command npm start.
- Begin your tunnelling service to get an https endpoint.
- Open a new command prompt window.
- Change to the directory that contains the ngrok.exe application.
- In the command prompt, run the command
ngrok http 3978 --host-header=localhost
. - Ngrok will fill the entire prompt window. Make note of the https:// Forwarding URL. This URL will be your [BASE_URI] referenced below.
- Minimize the ngrok Command Prompt window. It is no longer referenced in these instructions, but it must remain running.
- Register a new connector in the Connector Developer Portal
- Fill in all the basic details such as name, logo, descriptions etc. for the new connector.
- For the configuration page, you'll use our sample code's setup endpoint:
https://[BASE_URI]/connector/SimpleAuth
- For Valid domains, make entery of your domain's https URL, e.g. XXXXXXXX.ngrok.io.
- Click on Save. After the save completes, download the zip file for your connector which will contain the connector id.
- Now you can sideload your app package and test your new connector.
-
Go to the Application Registration Portal and sign in with the your account to create an application.
-
Navigate to Authentication under Manage and add the following redirect URLs:
https://<your_ngrok_url>/SimpleEnd
-
Additionally, under the Implicit grant subsection select Access tokens and ID tokens
-
Click on Expose an API under Manage. Select the Set link to generate the Application ID URI in the form of api://{AppID}. Insert your fully qualified domain name (with a forward slash "/" appended to the end) between the double forward slashes and the GUID. The entire ID should have the form of: api://<your_ngrok_url>/{AppID}
-
Navigate to API Permissions, and make sure to add the following delegated permissions:
- User.Read
- offline_access
- openid
- profile
-
Scroll to the bottom of the page and click on "Add Permissions".
-
Update the
.env
configuration with theClientId
andBaseUrl
-
Update your Microsoft Teams application manifest
-
Add your ngrok URL to validDomains. Teams will only show the sign-in popup if its from a whitelisted domain.
"validDomains": [ "<<base-url>>" ]
For more information about getting started with Teams, please review the following resources: