# OpenIddict Angular UI Migration Guide ## Angular Project - In `environment.ts` and `environment.prod.ts` **add a trailing slash at the end of the issuer**: ```typescript oAuthConfig: { issuer: 'https://localhost:44377/', ... }, ``` ## Http.Api.Host (Non-Separated IdentityServer) - In **MyApplication.HttpApi.Host.csproj** replace **project references**: ```csharp ``` with ```csharp ``` - In the **MyApplicationHttpApiHostModule.cs** replace usings and **module dependencies**: ```csharp using Volo.Abp.AspNetCore.Authentication.JwtBearer; using IdentityServer4.Configuration; ... typeof(AbpAccountPublicWebIdentityServerModule), ``` with ```csharp using OpenIddict.Validation.AspNetCore; ... typeof(AbpAccountPublicWebOpenIddictModule), ``` - In the **MyApplicationHttpApiHostModule.cs** add `PreConfigureServices` like below with your application name as the audience: ```csharp public override void PreConfigureServices(ServiceConfigurationContext context) { PreConfigure(builder => { builder.AddValidation(options => { options.AddAudiences("MyApplication"); // Replace with your application name options.UseLocalServer(); options.UseAspNetCore(); }); }); } ``` - In the **MyApplicationHttpApiHostModule.cs** `ConfigureServices` method, **replace the method call**: From `ConfigureAuthentication(context, configuration);` to `ConfigureAuthentication(context);` and update the method as: ```csharp private void ConfigureAuthentication(ServiceConfigurationContext context) { context.Services.ForwardIdentityAuthenticationForBearer(OpenIddictValidationAspNetCoreDefaults.AuthenticationScheme); } ``` - In the **MyApplicationHttpApiHostModule.cs** `OnApplicationInitialization` method, **replace the midware**: ```csharp app.UseJwtTokenMiddleware(); app.UseIdentityServer(); ``` with ``` app.UseAbpOpenIddictValidation(); ``` - In the **MyApplicationHttpApiHostModule.cs** `OnApplicationInitialization` method, delete `c.OAuthClientSecret(configuration["AuthServer:SwaggerClientSecret"]);` in `app.UseAbpSwaggerUI` options configurations which is no longer needed. - In `appsettings.json` delete **SwaggerClientSecret** from the *AuthServer* section like below: ```json "AuthServer": { "Authority": "https://localhost:44345", "RequireHttpsMetadata": "false", "SwaggerClientId": "MyApplication_Swagger" }, ## Http.Api.Host (Separated IdentityServer) - In the **MyApplicationHttpApiHostModule.cs** `OnApplicationInitialization` method, delete `c.OAuthClientSecret(configuration["AuthServer:SwaggerClientSecret"]);` in `app.UseAbpSwaggerUI` options configurations which is no longer needed. - In `appsettings.json` delete **SwaggerClientSecret** from the *AuthServer* section like below: ```json "AuthServer": { "Authority": "https://localhost:44345", "RequireHttpsMetadata": "false", "SwaggerClientId": "MyApplication_Swagger" }, ``` ## IdentityServer This project is renamed to **AuthServer** after v6.0.0. You can also refactor and rename your project to *AuthServer* for easier updates in the future. - In **MyApplication.IdentityServer.csproj** replace **project references**: ```csharp ``` with ```csharp ``` - In the **MyApplicationIdentityServerModule.cs** replace usings and **module dependencies**: ```csharp using IdentityServer4.Configuration; using Microsoft.AspNetCore.Authentication.JwtBearer; ... typeof(AbpAccountPublicWebIdentityServerModule), ``` with ```csharp using OpenIddict.Validation.AspNetCore; ... typeof(AbpAccountPublicWebOpenIddictModule), ``` - In the **MyApplicationIdentityServerModule.cs** add `PreConfigureServices` like below with your application name as the audience: ```csharp public override void PreConfigureServices(ServiceConfigurationContext context) { PreConfigure(builder => { builder.AddValidation(options => { options.AddAudiences("MyApplication"); // Replace with your application name options.UseLocalServer(); options.UseAspNetCore(); }); }); } ``` - In the **MyApplicationIdentityServerModule.cs** replace **ForwardIdentityAuthenticationForBearer** under `ConfigureServices` method: ```csharp context.Services.ForwardIdentityAuthenticationForBearer(); ``` with ```csharp context.Services.ForwardIdentityAuthenticationForBearer(OpenIddictValidationAspNetCoreDefaults.AuthenticationScheme); ``` - In the **MyApplicationIdentityServerModule.cs**, **remove IdentityServerOptions** configuration and **JwtBearer** options under `ConfigureServices` method: ```csharp if (Convert.ToBoolean(configuration["AuthServer:SetSelfAsIssuer"])) // Remove { Configure(options => { options.IssuerUri = configuration["App:SelfUrl"]; }); } ... context.Services.AddAuthentication() // Remove .AddJwtBearer(options => { options.Authority = configuration["AuthServer:Authority"]; options.RequireHttpsMetadata = Convert.ToBoolean(configuration["AuthServer:RequireHttpsMetadata"]); options.Audience = "MyApplication"; }) ``` - In the **MyApplicationIdentityServerModule.cs** `OnApplicationInitialization` method, **remove the midware**: ```csharp app.UseJwtTokenMiddleware(); app.UseIdentityServer(); ``` with ```csharp app.UseAbpOpenIddictValidation(); ``` - To use the new AuthServer page, replace **Index.cshtml.cs** with [AuthServer Index.cshtml.cs](https://gist.github.com/gterdem/878ea99edaf998bb9f360bbf1a674a87#file-index-cshtml-cs) and **Index.cshtml** file with [AuthServer Index.cshtml](https://gist.github.com/gterdem/878ea99edaf998bb9f360bbf1a674a87#file-index-cshtml). > Note: It can be found under the *Pages* folder. ## See Also * [OpenIddict Step-by-Step Guide](openiddict-step-by-step.md)