Skip to content

425show/wokload-identity-workshop

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

2 Commits
 
 
 
 
 
 
 
 

Repository files navigation

topic languages products description
workshop
csharp
nodejs
azurecli
azure-active-directory
dotnet-core
node-js
office-ms-graph
Shows how to secure a Service Principal with Workload Identity features. The SP is used by a daemon console app to retrieve data from Microsoft Graph.

Workload Identity Workshop

In this workshop you'll learn how to enable Workload Identity features for your solution. The workshop consistes of 2 parts

  1. In the first part we will build a simple daemon solution that authenticates with a Service Principal locally and retrieves data from MS Graph
  2. Apply Workload Identity capabilities to further secure your solution

Prerequisites

To go this workshop, you'll need:

  • An Internet connection
  • VS Code
  • The workload/framework of your choice
  • Azure CLI
  • A Windows machine (necessary if you want to run the app on Windows)
  • An OS X machine (necessary if you want to run the app on Mac)
  • A Linux machine (necessary if you want to run the app on Linux)
  • An Azure Active Directory (Azure AD) tenant. For more information on how to get a FREE (no Credit Card required) Azure AD tenant with a P2 license, see the Microsoft 365 Developer Program
  • An admin account in your Azure AD tenant. This sample will not work with a Microsoft account (formerly Windows Live account). Therefore, if you signed in to the Azure portal with a Microsoft account and have never created a user account in your directory before, you need to do that now.

Scenario

The console application:

  • gets a token from Azure AD in its own name (without a user)
  • and then calls the Microsoft Graph /users endpoint to get the list of user, which it then displays

Topology

For more information on the concepts used in this sample, be sure to read the Microsoft identity platform endpoint client credentials protocol documentation.

Daemon applications can use two forms of secrets to authenticate themselves with Azure AD:

  • application secrets (also named application password).
  • certificates.

The first form (application secret) is treated in the next paragraphs.


Getting started

Step 1: Clone or download this repository

From your shell or command line:

git clone https://github.com/Azure-Samples/active-directory-dotnetcore-daemon-v2.git

Given that the name of the sample is pretty long, and so are the name of the referenced NuGet packages, you might want to clone it in a folder close to the root of your hard drive, to avoid file size limitations on Windows.

Step 2: Register the sample with your Azure Active Directory tenant

There is one project in this sample. To register it, you can:

Create a new Service Principal and assign the right permissions

az ad app create --display-name workloadIdentityDotnetDemo
az ad sp create --id <app id from previous command output>
az ad sp credential reset --name workloadIdentityDotnetDemo

Choose the Azure AD tenant where you want to create your applications

As a first step you'll need to:

  1. Sign in to the Azure portal using either a work or school account or a personal Microsoft account.
  2. If your account is present in more than one Azure AD tenant, select Directory + Subscription at the top right corner in the menu on top of the page, and switch your portal session to the desired Azure AD tenant.
  3. In the left-hand navigation pane, select the Azure Active Directory service, and then select App registrations.

Register the client app (daemon-console)

  1. Navigate to the Microsoft identity platform for developers App registrations page.

  2. Select New registration.

    • In the Name section, enter a meaningful application name that will be displayed to users of the app, for example daemon-console.
    • In the Supported account types section, select Accounts in this organizational directory only ({tenant name}).
    • Select Register to create the application.
  3. On the app Overview page, find the Application (client) ID value and record it for later. You'll need it to configure the Visual Studio configuration file for this project.

  4. From the Certificates & secrets page, in the Client secrets section, choose New client secret:

    • Type a key description (for instance app secret),
    • Select a key duration of either In 1 year, In 2 years, or Never Expires.
    • When you press the Add button, the key value will be displayed, copy, and save the value in a safe location.
    • You'll need this key later to configure the project in Visual Studio. This key value will not be displayed again, nor retrievable by any other means, so record it as soon as it is visible from the Azure portal.

Add the necessary MS Graph Permissions

  1. Navigate to the Microsoft identity platform for developers portal.

  2. Select App registrations.

  3. In the list of pages for the app, select API permissions

    • Click the Add a permission button and then,
    • Ensure that the Microsoft APIs tab is selected
    • In the Commonly used Microsoft APIs section, click on Microsoft Graph
    • In the Application permissions section, ensure that the right permissions are checked: User.Read.All
    • Select the Add permissions button
  4. At this stage permissions are assigned correctly but the client app does not allow interaction. Therefore no consent can be presented via a UI and accepted to use the service app. Click the Grant/revoke admin consent for {tenant} button, and then select Yes when you are asked if you want to grant consent for the requested permissions for all account in the tenant.

You need to be an Azure AD tenant admin to do this. If you're using the Azure AD Developer tenant, then you should be OK

Sign in the Azure CLI with the Service Principal

az login --service-principal -u <SP Id> -p <SP Password> --tenant <Tenant Id> --allow-no-subscriptions

Build and Run the Code

Working with the .NET Core project

Build and open the .NET project in VS Code. In your terminal, type the following:

cd src/dotnet
dotnet restore
dotnet build
code .

To run the application, you can:

  • either use the dotnet command line tool
  • or use the debugger in the VS Code terminal.

Using the terminal

In the terminal, type dotnet run to start the application.

Using the debugger

Bring the Run view up:

Open Debugger

Launch the debugger

Launch .NET Debugger

If everything has been configured correctly, you should see the following (or similar output):

Run Results

For more details about the code check out the underlying README.MD file

Working with the Node.js project

Build and open the Node.js project in VS Code. In your terminal, type the following:

cd src/nodejs
npm install
code .

To run the application, you can:

  • either use the node command line tool
  • or use the debugger in the VS Code terminal.

Using the terminal

In the terminal, type node index.js to start the application.

Using the debugger

Bring the Run view up:

Open Debugger

Launch the debugger

Launch .NET Debugger

If everything has been configured correctly, you should see the following (or similar output):

Run Results

For more details about the code check out the underlying README.MD file

Implement the Workload Identity features // TODO

Step 1 Apply Conditional Access policy to service principal

This will generate a Conditional Access policy that will restrict access to the service account based on location, whenever it is outside of the trusted locations.

  1. Sign in to the Entra Portal as a Global, Security or Conditional Access administrator
  2. Browse to Azure Active Directory - Protect & secure - Conditional Access.
  3. To create a Trusted Location: Under Manage - Named locations - IP ranges location. • Choose a Name for the trusted location - DotnetDemo. • Select Mark as trusted location. • Choose the + sign, and enter a new IPv4 or IPv6 range.*

(Administrators can name locations defined by IP address ranges to be trusted named locations. To know more: Location condition in Azure Active Directory Conditional Access - Microsoft Entra | Microsoft Docs) 4. Select + New Policy - Create new policy. • Enter a name for the policy - example: WId Dotnet Demo CA. • Under Assignments - What does this policy apply to? Choose Workload identities (preview). • Include - Select service principals. • Search for workloadIdentityDotnetDemo previously generated, and Select.

• In the Cloud apps or actions section, choose All cloud apps. (It is not possible to select individual cloud apps at this moment). • Conditions section - Select Locations - Configure: Yes - Include: All trusted locations. • Access control will setup the Grant enforcement to Block automatically. • Enable Policy - set to On, and Create.

Now if the Service Principal tries to retrieve data from MS Graph, for our demo application, when outside of the trusted locations, the access will be blocked.

*For this dem IP range can be the IP the device is currently using, or the application will not work, since the Service Principal access will be blocked.

Step 2 Secure Workload Identities with Identity Protection

Organizations can find workload identities that have been flagged for risk in one of two locations:

  1. Navigate to the Entra admin center.
  2. Browse to Azure Active Directory - Protect & Secure - Identity Protection - Risky workload identities (preview).

Workload Identities risk level is based on sign-in behavior and offline indicator of compromise, for example leaked credentials and suspicious sign in. For a complete list of detections: Workload identity risk detections

Risk level can also be applied to a Conditional Access policy, where access can be blocked to the Service Principal, based on Risk level, with the instructions below:

  1. Browse to Azure Active Directory - Protect & secure - Conditional Access.
  2. Select the previously created Conditional Access policy – Wid Dotnet Demo.
  3. Selection Conditions – Service Principal risk (Preview). Toggle Yes in the Configure option.
  4. Configure risk level – High.
  5. Click Save.

Step 3 Create access review of an Azure AD role for the service principal

For this part, the recently created Service Principal need to have an Azure AD role assigned, that can be done by following these steps:

  1. Navigate to the Azure portal - search for Azure AD Roles and administrators.
  2. Search for Global Administrator role - Add assignments.
  3. Select Members - type workloadIdentityDotnetDemo.
  4. Click next.

Access reviews can remove access, approve access, and take recommendations.

  1. Sign in to the Entra portal.
  2. Navigate to Azure Active Directory - Identity Governance - Privilege Identity Management.
  3. Under Manage select Azure AD Roles - Access Reviews - New. • Name the access review - example Dotnet demo review. • Set the start date, frequency (for the review to happen periodically), and end date. For scope - select (Preview Service Principals). Role - select Global Administrator. • Expand the Upon completion settings section. If reviewers don't respond: No Approve Access. At the end of review, send notification to: Select the user you are currently using. • Click on Start.

It can take some minutes to finish, and will send notification to the current user.


Next Steps // TODO

Learn how to:

Community Help and Support // TODO

Use Stack Overflow to get support from the community. Ask your questions on Stack Overflow first and browse existing issues to see if someone has asked your question before. Make sure that your questions or comments are tagged with [msal dotnet].

If you find a bug in the sample, please raise the issue on GitHub Issues.

If you find a bug in msal.Net, please raise the issue on MSAL.NET GitHub Issues.

To provide a recommendation, visit the following User Voice page.

More information // TODO

For more information, see MSAL.NET's conceptual documentation:

For more information about the underlying protocol:

For a more complex multi-tenant Web app daemon application, see active-directory-dotnet-daemon-v2

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published