--- title: Enhance an app from an external assembly in ASP.NET Core with IHostingStartup author: guardrex description: Discover how to enhance an ASP.NET Core app from an external assembly using an IHostingStartup implementation. monikerRange: '>= aspnetcore-2.0' ms.author: riande ms.custom: mvc ms.date: 12/07/2017 uid: fundamentals/configuration/platform-specific-configuration --- # Enhance an app from an external assembly in ASP.NET Core with IHostingStartup By [Luke Latham](https://github.com/guardrex) An [IHostingStartup](/dotnet/api/microsoft.aspnetcore.hosting.ihostingstartup) implementation allows adding enhancements to an app at startup from an external assembly outside of the app's `Startup` class. For example, an external tooling library can use an `IHostingStartup` implementation to provide additional configuration providers or services to an app. `IHostingStartup` *is available in ASP.NET Core 2.0 and later.* [View or download sample code](https://github.com/aspnet/Docs/tree/master/aspnetcore/fundamentals/configuration/platform-specific-configuration/sample/) ([how to download](xref:tutorials/index#how-to-download-a-sample)) ## Discover loaded hosting startup assemblies To discover hosting startup assemblies loaded by the app or by libraries, enable logging and check the application logs. Errors that occur when loading assemblies are logged. Loaded hosting startup assemblies are logged at the Debug level, and all errors are logged. The sample app reads the [HostingStartupAssembliesKey](/dotnet/api/microsoft.aspnetcore.hosting.webhostdefaults.hostingstartupassemblieskey) into a `string` array and displays the result in the app's Index page: [!code-csharp[](platform-specific-configuration/sample/HostingStartupSample/Pages/Index.cshtml.cs?name=snippet1&highlight=14-16)] ## Disable automatic loading of hosting startup assemblies There are two ways to disable the automatic loading of hosting startup assemblies: * Set the [Prevent Hosting Startup](xref:fundamentals/host/web-host#prevent-hosting-startup) host configuration setting. * Set the `ASPNETCORE_PREVENTHOSTINGSTARTUP` environment variable. When either the host setting or the environment variable is set to `true` or `1`, hosting startup assemblies aren't automatically loaded. If both are set, the host setting controls the behavior. Disabling hosting startup assemblies using the host setting or environment variable disables them globally and may disable several characteristics of an app. It isn't currently possible to selectively disable a hosting startup assembly added by a library unless the library offers its own configuration option. A future release will offer the ability to selectively disable hosting startup assemblies (see [GitHub issue aspnet/Hosting #1243](https://github.com/aspnet/Hosting/pull/1243)). ## Implement IHostingStartup ### Create the assembly An `IHostingStartup` enhancement is deployed as an assembly based on a console app without an entry point. The assembly references the [Microsoft.AspNetCore.Hosting.Abstractions](https://www.nuget.org/packages/Microsoft.AspNetCore.Hosting.Abstractions/) package: [!code-xml[](platform-specific-configuration/snapshot_sample/StartupEnhancement.csproj)] A [HostingStartup](/dotnet/api/microsoft.aspnetcore.hosting.hostingstartupattribute) attribute identifies a class as an implementation of `IHostingStartup` for loading and execution when building the [IWebHost](/dotnet/api/microsoft.aspnetcore.hosting.iwebhost). In the following example, the namespace is `StartupEnhancement`, and the class is `StartupEnhancementHostingStartup`: [!code-csharp[](platform-specific-configuration/snapshot_sample/StartupEnhancement.cs?name=snippet1)] A class implements `IHostingStartup`. The class's [Configure](/dotnet/api/microsoft.aspnetcore.hosting.ihostingstartup.configure) method uses an [IWebHostBuilder](/dotnet/api/microsoft.aspnetcore.hosting.iwebhostbuilder) to add enhancements to an app. `IHostingStartup.Configure` in the hosting startup assembly is called by the runtime before `Startup.Configure` in user code, which allows user code to overwrite any configruation provided by the hosting startup assembly. [!code-csharp[](platform-specific-configuration/snapshot_sample/StartupEnhancement.cs?name=snippet2&highlight=3,5)] When building an `IHostingStartup` project, the dependencies file (*\*.deps.json*) sets the `runtime` location of the assembly to the *bin* folder: [!code-json[](platform-specific-configuration/snapshot_sample/StartupEnhancement1.deps.json?range=2-13&highlight=8)] Only part of the file is shown. The assembly name in the example is `StartupEnhancement`. ### Update the dependencies file The runtime location is specified in the *\*.deps.json* file. To active the enhancement, the `runtime` element must specify the location of the enhancement's runtime assembly. Prefix the `runtime` location with `lib//`: [!code-json[](platform-specific-configuration/snapshot_sample/StartupEnhancement2.deps.json?range=2-13&highlight=8)] In the sample app, modification of the *\*.deps.json* file is performed by a [PowerShell](/powershell/scripting/powershell-scripting) script. The PowerShell script is automatically triggered by a build target in the project file. ### Enhancement activation **Place the assembly file** The `IHostingStartup` implementation's assembly file must be *bin*-deployed in the app or placed in the [runtime store](/dotnet/core/deploying/runtime-store): For per-user use, place the assembly in the user profile's runtime store at: ``` \Users\\.dotnet\store\x64\\\\lib\\ ``` For global use, place the assembly in the .NET Core installation's runtime store: ``` \Program Files\dotnet\store\x64\\\\lib\\ ``` When deploying the assembly to the runtime store, the symbols file may be deployed as well but isn't required for the enhancement to work. **Place the dependencies file** The implementation's *\*.deps.json* file must be in an accessible location. For per-user use, place the file in the `additonalDeps` folder of the user profile's `.dotnet` settings: ``` \Users\\.dotnet\x64\additionalDeps\\shared\Microsoft.NETCore.App\\ ``` For global use, place the file in the `additonalDeps` folder of the .NET Core installation: ``` \Program Files\dotnet\additionalDeps\\shared\Microsoft.NETCore.App\\ ``` The shared framework version reflects the version of the shared runtime that the target app uses. The shared runtime is shown in the *\*.runtimeconfig.json* file. In the sample app, the shared runtime is specified in the *HostingStartupSample.runtimeconfig.json* file. **Set environment variables** Set the following environment variables in the context of the app that uses the enhancement. ASPNETCORE_HOSTINGSTARTUPASSEMBLIES Only hosting startup assemblies are scanned for the `HostingStartupAttribute`. The assembly name of the implementation is provided in this environment variable. The sample app sets this value to `StartupDiagnostics`. The value can also be set using the [Hosting Startup Assemblies](xref:fundamentals/host/web-host#hosting-startup-assemblies) host configuration setting. When multiple hosting startup assembles are present, their [Configure](/dotnet/api/microsoft.aspnetcore.hosting.ihostingstartup.configure) methods are executed in the order that the assemblies are listed. DOTNET_ADDITIONAL_DEPS The location of the implementation's *\*.deps.json* file. If the file is placed in the user profile's *.dotnet* folder for per-user use: ``` \Users\\.dotnet\x64\additionalDeps\ ``` If the file is placed in the .NET Core installation for global use, provide the full path to the file: ``` \Program Files\dotnet\additionalDeps\\shared\Microsoft.NETCore.App\\.deps.json ``` The sample app sets this value to: ``` %UserProfile%\.dotnet\x64\additionalDeps\StartupDiagnostics\ ``` For examples of how to set environment variables for various operating systems, see [Use multiple environments](xref:fundamentals/environments). ## Sample app The [sample app](https://github.com/aspnet/Docs/tree/master/aspnetcore/fundamentals/configuration/platform-specific-configuration/sample/) ([how to download](xref:tutorials/index#how-to-download-a-sample)) uses `IHostingStartup` to create a diagnostics tool. The tool adds two middlewares to the app at startup that provide diagnostic information: * Registered services * Address: scheme, host, path base, path, query string * Connection: remote IP, remote port, local IP, local port, client certificate * Request headers * Environment variables To run the sample: 1. The Startup Diagnostic project uses [PowerShell](/powershell/scripting/powershell-scripting) to modify its *StartupDiagnostics.deps.json* file. PowerShell is installed by default on Windows OS starting with Windows 7 SP1 and Windows Server 2008 R2 SP1. To obtain PowerShell on other platforms, see [Installing Windows PowerShell](/powershell/scripting/setup/installing-windows-powershell). 2. Build the Startup Diagnostic project. A build target in the project file: * Moves the assembly and symbols files to the user profile's runtime store. * Triggers the PowerShell script to modify the *StartupDiagnostics.deps.json* file. * Moves the *StartupDiagnostics.deps.json* file to the user profile's `additionalDeps` folder. 3. Set the environment variables: * `ASPNETCORE_HOSTINGSTARTUPASSEMBLIES`: `StartupDiagnostics` * `DOTNET_ADDITIONAL_DEPS`: `%UserProfile%\.dotnet\x64\additionalDeps\StartupDiagnostics\` 4. Run the sample app. 5. Request the `/services` endpoint to see the app's registered services. Request the `/diag` endpoint to see the diagnostic information.