Prerequisites
- Azure B2C account and/or relevant subscription
- Your Client ID, also known as Partner code, provided by itsme®.
- Your Service code provided by itsme®.
- Client secret provided by itsme®
- redirect_uri you will be redirecting the user to. In Azure B2C, it is in the following format (please, provide it to onboarding@itsme-id.com): https://{partnerAzureB2C-tenant-name}.b2clogin.com/{partnerAzureB2C-tenant-name}/oauth2/authresp https://{partnerAzureB2C-tenant-name}.b2clogin.com/{partnerAzureB2C-tenant-name}.onmicrosoft.com/oauth2/authresp
Configuration between Azure B2C and itsme®
Whether your set-up is via user flow (normally, via graphical user-interface (GUI) on Azure portal) or Identity Experience Framework (IEF), custom policies, configured via .xml files, will depend what ID data you wish (and entitled by commercial & legal agreements) to receive.
As of 2023, Azure B2C technical limitation is no possibility to process JSON objects, only strings. Please, cosult to see what claims returned by itsme® are strings or JSON object data type. User flow is limited to sub, names & email. While IEF will allow you to process the rest of ID Data listed above in data type string.
User Flows
User flows is a portal (GUI) configurable flow, which is based on built-in user attributes (values collected on sign up) and application claims, which are values about the user, returned to the application in the token. One can create custom attributes, but Azure B2C does not process any claims from itsme®, except the ones mapped during general idp setup (idp claims mapping), i.e. sub, given_name, family_name, email. Only those were returned consistently during testing of 2023.
End-user will see in the app request to approve all data which is mentioned on the scope, e.g. if full scope defined => all data will be displayed to approve, but Azure B2C will process and return only mapped claims, i.e. sub, given_name, family_name, emails (returned as string collection).
Identity Experience Framework (IEF) or custom policy
IEF is advanced method to configure Azure B2C via .xml files. Due to Azure B2C limitations, JSON Objects returned by itsme® can not be processed or transformed by Azure B2C, thus one could ask & receive data which is returned as strings only.
IEF configuration to retrieve custom OIDC claims (string or boolean data type)
Microsoft has elaborate documentation custom policy definition and how to work with . Below we attempt to provide guidance from partner perspective to smooth the configuration flow. We advise however always fall back to Azure B2C official documentation.
Prerequisites
- An Azure B2C Tenant
- Your itsme® provided ClientID aka PartnerCode
- Your itsme® provided ServiceCode
- Your client secret for your itsme® account
Getting started with Custom Policies
Add Signing and Encryption keys
Open the B2C tenant and, under Policies, select Identity Experience Framework.
Create the signing key
- Select Policy Keys and then select Add.
- For Options, choose Generate.
- In Name, enter TokenSigningKeyContainer. The prefix B2C_1A_ is added automatically.
- For Key type, select RSA.
- For Key usage, select Signature.
- Select Create.
Create the encryption key
- Select Policy Keys and then select Add.
- For Options, choose Generate.
- In Name, enter TokenEncryptionKeyContainer. The prefix B2C_1A_ is added automatically.
- For Key type, select RSA.
- For Key usage, select Encryption.
- Select Create.
Register Identity Experience Framework applications
- Open the B2C tenant and select under Manage App registrations.
- Select App registrations, and then select New registration.
- For Name, enter IdentityExperienceFramework.
- Under Supported account types, select Accounts in this organizational directory only.
- Under Redirect URI, select Web, and then enter https://your-tenant-name.b2clogin.com/your-tenant-name.onmicrosoft.com, where your-tenant-name is your Azure AD B2C tenant domain name.
- Under Permissions, select the Grant admin consent to openid and offline_access permissions check box.
- Select Register.
- Record the Application (client) ID for use in a later step.
Next, expose the API by adding a scope:
- Under Manage, select Expose an API.
- Select Add a scope, then select Save and continue to accept the default application ID URI.
- Enter the following values to create a scope that allows custom policy execution in your Azure AD B2C tenant: - Scope name: user_impersonation
- Admin consent display name: Access IdentityExperienceFramework
- Admin consent description: Allow the application to access IdentityExperienceFramework on behalf of the signed-in user.
 
- Select Add scope
Register the ProxyIdentityExperienceFramework application
(cf. )
- Open the B2C tenant and select under Manage App registrations.
- Select App registrations (Preview), and then select New registration.
- For Name, enter ProxyIdentityExperienceFramework.
- Under Supported account types, select Accounts in this organizational directory only.
- Under Redirect URI, use the drop-down to select Public client/native (mobile & desktop).
- For Redirect URI, enter myapp://auth.
- Under Permissions, select the Grant admin consent to openid and offline_access permissions check box.
- Select Register.
- Record the Application (client) ID for use in a later step.
Next, specify that the application should be treated as a public client:
- Under Manage, select Authentication.
- Select Try out the new experience (if shown).
- Under Advanced settings, enable Treat application as a public client (select Yes). Ensure that ”allowPublicClient”: true is set in the application manifest.
- Select Save.
Now, grant permissions to the API scope you exposed earlier in the IdentityExperienceFramework registration:
- Under Manage, select API permissions.
- Under Configured permissions, select Add a permission.
- Select the My APIs tab, then select the IdentityExperienceFramework application.
- Under Permission, select the user_impersonation scope that you defined earlier.
- Select Add permissions. As directed, wait a few minutes before proceeding to the next step.
- Select Grant admin consent for (your tenant name).
- Select your currently signed-in administrator account, or sign in with an account in your Azure AD B2C tenant that’s been assigned at least the Cloud application administrator role.
- Select Accept.
- Select Refresh, and then verify that “Granted for …” appears under Status for the scopes - offline_access, openid and user_impersonation. It might take a few minutes for the permissions to propagate.
App Registration
- Open the B2C tenant and select under Manage select App Registrations
- New registration
- Support account type: Account in this organizational directory only
- Redirect URL: the redirect URL to your app. - For testing purposes, you can use https://jwt.ms
 
- click on Register - For testing purposes, go to Authentication and select in the section implicit grant “Access Tokens” and “ID Tokens”.
 
Client Secret Registration
- Open the B2C tenant and select under Policies Identity Experience Framework.
- Select Policy keys and then select Add.
- For Options, choose Manual.
- Enter the name “itsmeClientSecret”
- For Key usage, select Signature.
- Select Create.
Edit the Custom Policy Starter Pack
- Download the starter pack:
git clone https://github.com/Azure-Samples/active-directory-b2c-custom-policy-starterpack
- Edit the files from the “SocialAndLocalAccounts” folder in the downloaded starter pack
- In all XML files in the starter pack, replace “yourtenant” with the name of your tenant
- In TrustFrameworkExtensions.xml, fill in the AppID of the two Identity Experience Framework applications - replace “ProxyIdentityExperienceFrameworkAppId”
- replace “IdentityExperienceFrameworkAppId”
- remove the “” with the DisplayName ‘Facebook’ 
 
<Metadata>
 <Item Key="client_id">ProxyIdentityExperienceFrameworkAppID</Item>
 <Item Key="IdTokenAudience">IdentityExperienceFrameworkAppID</Item>
</Metadata>
<InputClaims>
<InputClaim ClaimTypeReferenceId="client_id" DefaultValue="ProxyIdentityExperienceFrameworkID" />
 <InputClaim ClaimTypeReferenceId="resource_id" PartnerClaimType="resource" DefaultValue="IdentityExperienceFrameworkAppID" />
</InputClaims>
Edit the Trustframeworkbase.xml to add the itsme provider
- In the element, adjust the URIs for the layout if needed 
- In the element, remove the ClaimsProvider with the displayName facebook.com 
- Add in the element the following element. - the METADATA depends on the environment:
 - E2E: https://oidc.e2e.itsme.services/clientsecret-oidc/csapi/v0.1/.well-known/openid-configuration
- PRD: https://oidc.prd.itsme.services/clientsecret-oidc/csapi/v0.1/.well-known/openid-configuration
 
- Replace YOURitsmePARTNERCODE with your itsme partner code
- Replace YOURitsmeSERVICECODE with your itsme service code In this example, the BENationalNumber claim is added as string and phone_number_verified as boolean. More claims can be added if needed:
<ClaimsProvider>
      <DisplayName>tsme®</DisplayName>
      <TechnicalProfiles>
        <TechnicalProfile Id="ItsmeProfile">
          <DisplayName>itsme®</DisplayName>
          <Protocol Name="OpenIdConnect" />
          <Metadata>
            <Item Key="METADATA">https://oidc.e2e.itsme.services/clientsecret-oidc/csapi/v0.1/.well-known/openid-configuration</Item>
            <Item Key="client_id">YOURitsmePARTNERCODE</Item>
            <Item Key="response_types">code</Item>
            <Item Key="response_mode">query</Item>
            <Item Key="scope">openid service:YOURitsmeSERVICECODE</Item>
            <!-- Policy Engine Clients -->
            <Item Key="UsePolicyInRedirectUri">false</Item>
            <Item Key="HttpBinding">POST</Item>
          </Metadata>
          <CryptographicKeys>
            <Key Id="client_secret" StorageReferenceId="B2C_1A_ItsmeClientSecret"/>
          </CryptographicKeys>
          <InputClaims>
            <InputClaim ClaimTypeReferenceId="claims" DefaultValue="{"userinfo":{"http://itsme.services/v2/claim/BENationalNumber":null,"phone_number_verified":null}}" AlwaysUseDefaultValue="true" />
          </InputClaims>
          <OutputClaims>
            <OutputClaim ClaimTypeReferenceId="identityProvider" DefaultValue="itsme-id.com" AlwaysUseDefaultValue="true" />
            <OutputClaim ClaimTypeReferenceId="issuerUserId" PartnerClaimType="sub" />
            <OutputClaim ClaimTypeReferenceId="givenName" PartnerClaimType="given_name" />
            <OutputClaim ClaimTypeReferenceId="surname" PartnerClaimType="family_name" />
            <OutputClaim ClaimTypeReferenceId="displayName" PartnerClaimType="name" />
            <OutputClaim ClaimTypeReferenceId="email" PartnerClaimType="email" />
            <OutputClaim ClaimTypeReferenceId="extension_BENationalNumber" PartnerClaimType="http://itsme.services/v2/claim/BENationalNumber" />
            <OutputClaim ClaimTypeReferenceId="extension_phoneNumberVerified" PartnerClaimType="phone_number_verified" DefaultValue="false" />
          </OutputClaims>
          <UseTechnicalProfileForSessionManagement ReferenceId="SM-SocialLogin" />
        </TechnicalProfile>
      </TechnicalProfiles>
    </ClaimsProvider>
- Add in the section <ClaimsSchema>element the following<ClaimType>element:
<ClaimType Id="claims">
  <DisplayName>Custom Claims</DisplayName>
  <DataType>string</DataType>
</ClaimType>
- Adjust the <UserJourneys>elements to suit your needs. For example, replace the<ClaimsProviderSelection TargetClaimsExchangeId="FacebookExchange"/>with<ClaimsProviderSelection TargetClaimsExchangeId="ItsmeExchange"/>
and <ClaimsExchange Id="FacebookExchange" TechnicalProfileReferenceId="Facebook-OAUTH" /> with <ClaimsExchange Id="ItsmeExchange" TechnicalProfileReferenceId="ItsmeProfile" />
Persist Custom Claims in AAD
- Edit the TrustFrameworkBase.xml document.
- Add in the section <ClaimsSchema>element the follow<ClaimType>element
<ClaimType Id="extension_BENationalNumber">
 <DisplayName>Belgian National Number of the user provided by itsme</DisplayName>
 <DataType>string</DataType>
 <UserInputType>TextBox</UserInputType>
</ClaimType>
<ClaimType Id="extension_phoneNumberVerified">
  <DisplayName>phone_number_verified</DisplayName>
  <DataType>boolean</DataType>
  <UserInputType>TextBox</UserInputType>
</ClaimType>  
- Add in the <TechnicalProfile Id=”AAD-Common”> the Metadata information. The values can be found as follows: - In Azure AD B2C, select App registrations, and then select All Applications.
- Select the b2c-extensions-app. Do not modify. Used by AADB2C for storing user data. application.
 
<!-- CUSTOM -->
<Metadata>
  <Item Key="ApplicationObjectId">ObjectID of b2c-extensions-app</Item>
  <Item Key="ClientId">Application/ClientID of b2c-extensions-app</Item>
</Metadata>
- Next, in the section add the custom claim link. 
- Depending on your needs, you might need to add the custom claims in other as well. For example, to Write the value in the AAD, as well as to read it back from the AAD. 
<TechnicalProfile Id="AAD-Common">
 <DisplayName>Azure Active Directory</DisplayName>
[…]
 <TechnicalProfile Id="AAD-UserWriteUsingAlternativeSecurityId">
[…]
   <PersistedClaims>
[…]
     <!-- Optional claims -->
     <PersistedClaim ClaimTypeReferenceId="otherMails" />
     <PersistedClaim ClaimTypeReferenceId="givenName" />
     <PersistedClaim ClaimTypeReferenceId="surname" />
     <PersistedClaim ClaimTypeReferenceId="extension_BENationalNumber" DefaultValue="Unknown" />
     <PersistedClaim ClaimTypeReferenceId="extension_phoneNumberVerified" DefaultValue="false" />
   </PersistedClaims>
[…]
<TechnicalProfile Id="AAD-UserReadUsingAlternativeSecurityId">
[…]
    <!-- Optional claims -->
    <OutputClaim ClaimTypeReferenceId="userPrincipalName" />
    <OutputClaim ClaimTypeReferenceId="surname" />
    <OutputClaim ClaimTypeReferenceId="extension_BENationalNumber" />
Edit the SignUpOrSignin.xml
In the 
<OutputClaim ClaimTypeReferenceId="extension_BENationalNumber"/>
<OutputClaim ClaimTypeReferenceId="extension_phoneNumberVerified" />
Upload the policies
- Select the Identity Experience Framework
- Select Upload custom policy.
- In this order, upload the policy files: - TrustFrameworkBase.xml
- TrustFrameworkExtensions.xml
- SignUpOrSignin.xml
- ProfileEdit.xml
- PasswordReset.xml
 
Test the flow
- In the Identity Experience Framework, click on the B2C_1A_signup_sigin custom policy file.
- Select Application and the reply url
- Click on Run now
- Based on your , the itsme® “Identify yourself” page will appear. 
- Enter your mobile phone number and click on send.
- Confirm the action in the itsme® app.
- If all succeeds, you will be redirected to the redirect URL.
Reference