Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update tab-aad-msal2 sample with full docs #17

Merged
merged 23 commits into from
Aug 25, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
5cbf48f
Bump elliptic from 6.5.2 to 6.5.3 in /samples/tab-aad-adal
dependabot[bot] Aug 2, 2020
74ea761
Bump acorn from 7.1.0 to 7.3.1 in /samples/bot-call-graph-as-user
dependabot[bot] Jul 21, 2020
de1d0e0
Bump lodash from 4.17.15 to 4.17.19 in /samples/bot-call-graph-as-user
dependabot[bot] Jul 21, 2020
cd7ef14
Update README, add picture of bot in action
BobGerman Aug 3, 2020
b4eddac
Original sample from lab repo
BobGerman Aug 6, 2020
38efb75
Updated readme
BobGerman Aug 6, 2020
7bae6c7
Fix typo in readme
BobGerman Aug 6, 2020
825095a
Remove adal sample
BobGerman Aug 11, 2020
3ebe555
Setup from Teams app generator
BobGerman Aug 17, 2020
072ff2d
Merge branch 'dev' of https://github.com/BobGerman/teams-dev-samples …
BobGerman Aug 17, 2020
8bd456a
Fixes for SSL, hash routing
BobGerman Aug 17, 2020
2658a03
Stand-alone sample works but is messy
BobGerman Aug 18, 2020
deda467
Cleaned up a bit
BobGerman Aug 18, 2020
4a7299a
Cleaned up a bit
BobGerman Aug 18, 2020
6803549
Web version reads the mail
BobGerman Aug 19, 2020
910c986
Tabs UI now gets the mail
BobGerman Aug 19, 2020
6dffe18
Moved up a level
BobGerman Aug 19, 2020
96701b6
Now works in mobile!
BobGerman Aug 19, 2020
817ede3
Login now requests needed scopes to reduce # of redirects
BobGerman Aug 19, 2020
c7e5b30
Doc and manifest updates
BobGerman Aug 25, 2020
d89407e
Merge remote-tracking branch 'upstream/master' into dev
BobGerman Aug 25, 2020
92048c9
Updated docs and manifest
BobGerman Aug 25, 2020
c60e852
Merge branch 'dev' of https://github.com/BobGerman/teams-dev-samples …
BobGerman Aug 25, 2020
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions samples/tab-aad-msal2/.env
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
HTTPS=false
BROWSER=none

25 changes: 25 additions & 0 deletions samples/tab-aad-msal2/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.

config.js

# dependencies
/node_modules
/.pnp
.pnp.js

# testing
/coverage

# production
/build

# misc
.DS_Store
.env.local
.env.development.local
.env.test.local
.env.production.local

npm-debug.log*
yarn-debug.log*
yarn-error.log*
5 changes: 5 additions & 0 deletions samples/tab-aad-msal2/.publish/Development.env
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
appid=9b0240ae-e7e8-4a68-91b1-7240a64f7c2a
version=1.0.0
appname=tab-aad-msal2
fullappname=Tab authentication with MSAL 2.0
baseUrl0=http://localhost:3000
Binary file added samples/tab-aad-msal2/.publish/Development.zip
Binary file not shown.
37 changes: 37 additions & 0 deletions samples/tab-aad-msal2/.publish/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
# Publishing

Create a publishing package composed of the manifest file that describes your apps capabilities and the required icon images.

## App Manifest

Your manifest file must be named "manifest.json" and be at the top level of the upload package. Note that manifests and packages built previously might support an older version of the schema. For Teams apps and especially AppSource (formerly Office Store) submission, you must use the current [manifest schema](https://docs.microsoft.com/en-us/microsoftteams/platform/resources/schema/manifest-schema). The publish folder in the project you created contains a completed app manifest for the selections you made when generating the project.

## Manifest Environment

The publishing folder contains an environment file with extension ".env". The property and value pairing in this file replace the keys in your manifest.json template.

An example would be in your ".env" file you have a property of "baseUrl". When you update the value of this property the value will be merged into the manifest.json template file and replace all items with the token {baseUrl0}. The generated merge is then paired with the icons files in that folder and a new zip publishing package will be created with the name of that ".env" file.

**For example:**
- development.env
- File contains property value pairing of; baseUrl=http://localhost:3000
- Generates a publishing package with the name of development.zip containing the icons referenced in the manifest file along with the manifest.json template replaced with the values in the env file.

**Supported Properties**
teamsappid: The unique id used to identify your application
version: The version number of your application
appname: The short name of your application
fullappname: The longer version of the name of your application
botId: The id of the bot for your environment
baseUrl: The protocol and hostname of the url for your application
singleSignOnAppId: The Application Client ID from Azure portal used for SSO (Single Sign On)
singleSignOnAPIDomain: The domain of the api service used for SSO

Note:
The 'baseUrl' and 'botId' can be used for multiple replacements in your manifest if you have multiple values for items in your application. As long as the property starts with 'baseUrl' or 'botId' you can add a number or text after to describe another replacement value. Like baseUrl1, baseUrl2, or botId1.

## Automatic Package Generation

Inside of the publishing folder anytime you save an environment file ".env" the deployment package for that file will be generated with the name of the environment file with the ".zip" extension.

Also, if you update the manifest.json template file all environment files in that folder will be used to regenerate all publishing packages ".zip" in that folder.
Binary file added samples/tab-aad-msal2/.publish/color.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
42 changes: 42 additions & 0 deletions samples/tab-aad-msal2/.publish/manifest.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,42 @@
{
"$schema": "https://developer.microsoft.com/en-us/json-schemas/teams/v1.7/MicrosoftTeams.schema.json",
"manifestVersion": "1.7",
"version": "{version}",
"id": "9b0240ae-e7e8-4a68-91b1-7240a64f7c2a",
"packageName": "io.github.pnp.sample.tab-aad-msal2",
"developer": {
"name": "Bob German",
"websiteUrl": "{baseUrl0}",
"privacyUrl": "{baseUrl0}/privacy",
"termsOfUseUrl": "{baseUrl0}/termsofuse"
},
"icons": {
"color": "color.png",
"outline": "outline.png"
},
"name": {
"short": "{appname}",
"full": "{fullappname}"
},
"description": {
"short": "Bare bones sample on tab auth with MSAL 2",
"full": "Bare bones sample on tab authentication to Azure AD with no server side logic using MSAL 2.0 / Auth Code PKCE flow"
},
"accentColor": "#FFFFFF",
"staticTabs": [
{
"entityId": "index",
"name": "AAD MSAL Tab Sample",
"contentUrl": "{baseUrl0}/#tab",
"websiteUrl": "{baseUrl0}/#web",
"scopes": [
"personal"
]
}
],
"permissions": [
"identity",
"messageTeamMembers"
],
"validDomains": []
}
Binary file added samples/tab-aad-msal2/.publish/outline.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
129 changes: 129 additions & 0 deletions samples/tab-aad-msal2/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
# Teams Tab using MSAL 2.0 and Microsoft Graph

This sample demonstrates how to write a single-page application which uses MSAL 2.0 to acquire an access token from Azure Active Directory, and then calls the Microsoft Graph.

## Summary

The sample is bare bones - it just shows the current user's top 15 emails. The point of it is to show how to call the Microsoft Graph from a Teams tab which is hosted on a purely static web site, with no server support at all. Static hosting eliminates the option of using the [Azure AD SSO](https://docs.microsoft.com/microsoftteams/platform/tabs/how-to/authentication/auth-aad-sso?WT.mc_id=m365-blog-rogerman) approach, which requires a simple web service. If you can support the web service, the SSO approach is probably a better choice because it provides a seamless user experience. This sample will cause the user to see some pop-up's; even if they have already logged in, the pop-up will display briefly whenever the tab is opened.

![picture of the app in action](docs/images/tab-aad-msal2-composite.png)

[MSAL 2.0 implements the Auth Code PKCE flow](https://developer.microsoft.com/en-us/microsoft-365/blogs/msal-js-2-0-supports-authorization-code-flow-is-now-generally-available/), which is more secure than the previously used Implicit flow. If you want to understand how it works and why it's more secure, check out [Jason Specland's](https://twitter.com/jayspec/) excellent video, [More Secure JavaScript Single-Page Applications with MSAL 2.0 and OAuth 2.0 Code Flow with PKCE](https://www.youtube.com/watch?v=YxAwGAnmNqQ).

The project was generated using the [Microsoft Teams Toolkit for Visual Studio Code](https://developer.microsoft.com/office/blogs/building-teams-apps-with-visual-studio-and-visual-studio-code-extensions/?WT.mc_id=m365-blog-rogerman). The toolkit uses [Create React App](https://reactjs.org/docs/create-a-new-react-app.html#create-react-app) to generate tabs.

## Frameworks

![drop](https://img.shields.io/badge/React-16.13-green.svg)

## Prerequisites

* [Office 365 tenant](https://dev.office.com/sharepoint/docs/spfx/set-up-your-development-environment)
* [Node.js](https://nodejs.org) version 10.14.1 or higher

```bash
# determine node version
node --version
```
* Optional: Static hosting such as [github pages](https://pages.github.com/)

## Version history

Version|Date|Author|Comments
-------|----|----|--------
1.0|August 25, 2020|Bob German|Initial release

## Disclaimer

**THIS CODE IS PROVIDED *AS IS* WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING ANY IMPLIED WARRANTIES OF FITNESS FOR A PARTICULAR PURPOSE, MERCHANTABILITY, OR NON-INFRINGEMENT.**

---

## Minimal Path to Awesome

#### 1. Clone this repository to your local filesystem

Within the tab-aad-msal directory, run

~~~shell
npm install
~~~

to install the needed npm packages.

#### 2. Register an Azure AD application

a. Browse to Azure Active Directory in the [Microsoft 365 admin center](https://portal.office.com/AdminPortal/Home) or [Azure portal](https://portal.azure.com/).

b. Under "Manage", click "App Registration" to open the App Registrations. Then click "+ New registration" to register a new application.

c. Give your application a name and select who can use the application. The sample was tested using the first option, "Accounts in this organizational directory only" but the multitenant option should work as long as you use the multitenant endpoint ??????

d. Under Redirect URI, enter http://localhost:3000/ for local debugging. NOTE: Other than localhost you should always use https, not http! If you plan to host your solution elsewhere, you will need to add those locations as well. For example if you use Github pages, you'll need to add https://<githubOrgName>.github.io.

e. Under API permissions, click "+ Add a permission", then click Microsoft Graph, and then click Delegated permissions. Under "user", check "User.Read". (NOTE: The sample will request an additional permission, "Mail.Read", at runtime to demonstrate [Dynamic Consent](https://docs.microsoft.com/azure/active-directory/develop/application-consent-experience?WT.mc_id=m365-blog-rogerman).)

f. Return to the application overview and make note of your Application (client) ID and Directory (tenant) ID; you'll need them in the next step.

#### 3. Create the configuration script within your application

a. Make a copy of src/Config.sample.js and name it Config.js. Edit the file to include your Application (client) ID and Directory (tenant) ID. If you registered a multi-tenant app, insert the word "common" instead of your tenant ID. Finally, include your redirect URL; the sample is already filled in with the URL for local debugging.

~~~Javascript
export const clientId = "<Application ID from app you registered in Azure portal>";
export const authority = "https://login.microsoftonline.com/<Tenant ID from app you registered in Azure portal>";
export const redirectUri = "http://localhost:3000/";
~~~

#### 4. Update the manifest

If you're using the [Teams Toolkit Visual Studio Code extensions](https://marketplace.visualstudio.com/items?itemName=TeamsDevApp.ms-teams-vscode-extension&WT.mc_id=m365-blog-rogerman), in the .publish folder, open the Development.env file and ensure that the baseUrl0 setting is right for your development environment (such as http://localhost:3000). Visual Studio Code should update the package file Development.zip for you.
(NOTE: This is pretty cool; you can create other .env files for environments such as staging and production as well and the VS Code extensions will manage those manifests as well.)

If you're not using the extensions, open the manifest.json file and change all occurrances of `{baseUrl0}` to your startup URL and replace the manifest.json within the Development.zip application package with your updated version.

#### 5. Upload the manifest

NOTE: Both these options require you to have [application uploading turned on](https://docs.microsoft.com/microsoftteams/upload-custom-apps?WT.mc_id=m365-blog-rogerman#allow-trusted-users-to-upload-custom-apps) in an App Setup policy that includes your user account.

If you're using the [Teams Toolkit Visual Studio Code extensions](https://marketplace.visualstudio.com/items?itemName=TeamsDevApp.ms-teams-vscode-extension&WT.mc_id=m365-blog-rogerman) you can install the app for yourself using (App Studio)[https://docs.microsoft.com/microsoftteams/platform/concepts/build-and-test/app-studio-overview?WT.mc_id=m365-blog-rogerman]. The app will already be there under "Manifest editor"; open it up and on the left, scroll down to "Test and distribute" and click "Install".

If you're not using these tools, you can upload the app package (the updated Development.zip file) under "Apps" in Microsoft Teams.

#### 6. Run your application

In the tab-aad-msal2 folder, run the application

~~~shell
npm run start
~~~

To debug, you can attach to your browser's debugger in Visual Studio code or debug directly in the browser.

To deploy to a static web site, create an optimized build

~~~shell
npm run build
~~~

and deploy the contents of the build directory to the static hosting location of your choice.

## Features

This web part attempts to acquire an access token on behalf of the signed-in user. If successful, it calls the Microsoft Graph to retrieve the 15 most recent emails, which are then displayed in the tab.

Key files:

* components/App.js - This is the main application. Notice that it calls the Auth Service init() function before doing anything else; that gives MSAL 2.0 a chance to handle any data sent to it in a redirect from Azure AD.

* components/Tab.js - This is the tab user interface used in the Teams desktop client or web UI

* components/Web.js - This is the web page user interface used in the iOS and Android applications, which can't handle a browser pop-up. Notice that App.js checks to see if it's running in an IFrame (which indicates the web or desktop client); if not, it uses Web.js.

* components/TeamsAuthPopup.js - This is the web page that runs in the Teams pop-up window in the desktop client or web UI. In the case of the mobile applications, Web.js handles the login.

* services/AuthService.js - This is a singleton object that handles MSAL 2.0. It keeps an instance of MSAL 2.0 for as long as the page is running so MSAL can do caching, etc. In addition to App.js calling the init function on every page, TeamsAuthPopup.js and Web.js components use AuthService.js to ensure the user is logged in and to acquire an access token.

* services/TeamsAuthService.js - This is a singleton object that launches the Teams authentication pop-up. It's used by Tab.js.

<img src="https://telemetry.sharepointpnp.com/teams-dev-samples/samples/tab-aad-msal2" />
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading