Angular is a popular JavaScript library for building web apps user interfaces developed by Google. This guide shows you how to
- Build and run a new simple Angular2 app
- Register your app on Azure AD B2C
- Adding the OAuth2 authorization library
- Configure your library to federate with Azure AD B2C sign-up or sign-in policy
- Adding the sign-in functionality
- Adding the sign-out funcritonlity
We use Angular CLI tool to create the application a simple application. But you can use any existing or new application. To install and use the command-line interface as well as run the Angular application server, you'll need the Node.js JavaScript runtime and npm (the Node.js package manager) installed. npm is included with Node.js, which you can install from here.
Tip: To test that you have Node.js and npm correctly installed on your machine, you can type
node --version
andnpm --version
.
To install the Angular CLI, in a terminal or command prompt type:
npm install -g @angular/cli
This may take a few minutes to install. You can now create a new Angular application by typing:
ng new my-app
my-app
is the name of the folder for your application. This may take a few minutes to create the Angular application in TypeScript and install its dependencies.
Let's quickly run our Angular application by navigating to the new folder and typing ng serve
to start the web server and open the application in a browser:
cd my-app
ng serve --open
You should see "Welcome to app!!" on http://localhost:4200 in your browser.
We'll leave the web server running while we look at the application with VS Code. To open your Angular application in VS Code, open another terminal (or command prompt) and navigate to the my-app
folder and type code .
:
cd my-app
code .
This sample uses three types of policies:
- Unified sign-up and sign-in policy
- Password reset policy [TBD]
- Profile editing policy [TBD]
Create one policy of each type by following the instructions here. You may choose to include as many or as few identity providers as you wish. If you already have existing policies in your Azure AD B2C tenant, feel free to reuse those. No need to create new ones just for this sample.
A Web application needs to be registered in your Azure AD B2C tenant before they can accept and respond to protected resource requests by client applications that present an access token.
- From Azure AD B2C, select Applications, and then select Add.
- Enter a name for the application. For example,
My Angular App
. - For Include web app/ web API and Allow implicit flow, select Yes.
- For Reply URL, enter an endpoint where Azure AD B2C should return any tokens that your application requests. In this tutorial, the Angular sample runs locally and listens at
http://localhost:4200
. - For App ID URI, enter the identifier used for your web API. The full identifier URI including the domain is generated for you. For example,
https://yourtenant.onmicrosoft.com/angular-api
. - Click Create.
- On the properties page, record the Application ID that you'll use when you configure the web application.
Scopes provide a way to govern access to protected resources. Scopes are used by the web API to implement scope-based access control. For example, some users could have both read and write access, whereas other users might have read-only permissions. In this tutorial, you define read permissions for the web API.
- Select Applications, and then select
My Angular App
. - Select Published Scopes.
- For scope, enter
Demo.Read
, and for description, enterRead access
. - Click Save.
To call a protected web API from an application, you need to grant your application permissions to the API.
- Select API access, and then select Add.
- In the Select API dropdown, select
My Angular App
. - In the Select Scopes dropdown, select the
Demo.Read
scope that you previously defined. - Click OK.
The msal-angular package is available on NPM. From VS Code terminal, run following command:
npm install @azure/msal-angular --save
- Under the app folder, create a subfolder: services
- Create a new file: msal.service.ts. This class tonains the code to sign-in and sign-out using Azure AD B2C.
- Add following code to the msal.service.ts file
import { Injectable } from '@angular/core';
import { Observable } from 'rxjs/Observable';
import * as Msal from 'msal';
declare var bootbox: any;
@Injectable()
export class MsalService {
B2CTodoAccessTokenKey = "b2c.todo.access.token";
tenantConfig = {
tenant: "yourtenant.onmicrosoft.com",
clientID: 'ebce2d28-8fb8-4cc7-83ae-accc9d73ee9d',
signUpSignInPolicy: "B2C_1_SUSI",
b2cScopes: ["https://yourtenant.onmicrosoft.com/angular-api/Demo.Read"]
};
// Configure the authority for Azure AD B2C
authority = "https://login.microsoftonline.com/tfp/" + this.tenantConfig.tenant + "/" + this.tenantConfig.signUpSignInPolicy;
/*
* B2C SignIn SignUp Policy Configuration
*/
clientApplication = new Msal.UserAgentApplication(
this.tenantConfig.clientID, this.authority,
function (errorDesc: any, token: any, error: any, tokenType: any) {
// Called after loginRedirect or acquireTokenPopup
}
);
public login(): void {
var _this = this;
this.clientApplication.loginPopup(this.tenantConfig.b2cScopes).then(function (idToken: any) {
_this.clientApplication.acquireTokenSilent(_this.tenantConfig.b2cScopes).then(
function (accessToken: any) {
_this.saveAccessTokenToCache(accessToken);
}, function (error: any) {
_this.clientApplication.acquireTokenPopup(_this.tenantConfig.b2cScopes).then(
function (accessToken: any) {
_this.saveAccessTokenToCache(accessToken);
}, function (error: any) {
bootbox.alert("Error acquiring the popup:\n" + error);
});
})
}, function (error: any) {
bootbox.alert("Error during login:\n" + error);
});
}
saveAccessTokenToCache(accessToken: string): void {
sessionStorage.setItem(this.B2CTodoAccessTokenKey, accessToken);
};
logout(): void {
this.clientApplication.logout();
};
isOnline(): boolean {
return this.clientApplication.getUser() != null;
};
}
The code contains following sections:
- MSAL tenent configuration
- login method allows user to acquire tokens by prompting user authentication in a pop-up window. And then obtain a token silently without prompting the user again.
- saveAccessTokenToCache method, after user successfully sign-in, MSAL library stores the token to the SPA application cache to later use.
- logout method, sign the user out from the application and clears Azure AD B2C session.
- isOnline method, checks if user is sign-in or not
This code sets the Azure AD B2C values. Set those parameters with the value of your environment, including:
- Your tenant name
- The sign-up or sign-in policy
- The application you created earlier
- The application scopes
tenantConfig = {
tenant: "yourtenant.onmicrosoft.com",
clientID: 'ebce2d28-8fb8-4cc7-83ae-accc9d73ee9d',
signUpSignInPolicy: "B2C_1_SUSI",
b2cScopes: ["https://yourtenant.onmicrosoft.com/angular-api/Demo.Read"]
};
Add following code to the app.component.ts
file, so the sign-in and sign-out functionality will cover the entire application, no matter where user is navigates to.
In the app.component.ts
file, import your MSAL service you create earlier.
import { MsalService } from './services/msal.service';
Inside the class, add following code. This code:
- injects the
location
andmsalService
- Add the
login()
method - Add the
logout()
method, which sign-in and clear the local cache - Add the
isOnline()
method, checks if user is sign-in - Add the
getAccessToken()
method, gets the access token from the cache
access_token: string = "";
constructor(
private location: Location,
private msalService: MsalService
) { }
login(): void {
this.msalService.login();
}
logout(): void {
this.msalService.logout();
sessionStorage.clear();
};
isActive(viewLocation: any): boolean {
return viewLocation === this.location.path();
};
isOnline(): boolean {
return this.msalService.isOnline();
};
getAccessToken(): void {
if (sessionStorage.hasOwnProperty(this.msalService.B2CTodoAccessTokenKey) && sessionStorage[this.msalService.B2CTodoAccessTokenKey] !== "") {
this.access_token = sessionStorage[this.msalService.B2CTodoAccessTokenKey];
}
};
In this step, you add the sign-in and sign-out buttons. Those buttons are shown to user in the user is online or not [hidden]="!isOnline()
. Also the DIV below shows the access token Azure AD B2C returns to the application.
<ul>
<li [hidden]="!isOnline()"><a class="btn btn-link" (click)="logout()" href="#">Logout</a></li>
<li [hidden]="isOnline()"><a class="btn btn-link" (click)="login()" href="#">Login</a></li>
</ul>
<div [hidden]="!isOnline()">
<h3>Access token:</h3>
<a class="btn btn-link" [hidden]="access_token.length > 0" (click)="getAccessToken()" href="#">Show the token</a>
<div>
{{access_token}}
</div>
</div>
[TBD]
You can find the complete code in this GitHub repo The sample is already configured to use a demo environment and can be run simply by downloading the code and running the app on your machine. Follow the instructions below if you would like to use your own Azure AD B2C configuration. Optionally, if you want to use your own tenant configuration.