Shiny.Extensions.DependencyInjection
2.0.3
Prefix Reserved
There is a newer prerelease version of this package available.
See the version list below for details.
See the version list below for details.
dotnet add package Shiny.Extensions.DependencyInjection --version 2.0.3
NuGet\Install-Package Shiny.Extensions.DependencyInjection -Version 2.0.3
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Shiny.Extensions.DependencyInjection" Version="2.0.3" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Shiny.Extensions.DependencyInjection" Version="2.0.3" />
<PackageReference Include="Shiny.Extensions.DependencyInjection" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Shiny.Extensions.DependencyInjection --version 2.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: Shiny.Extensions.DependencyInjection, 2.0.3"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Shiny.Extensions.DependencyInjection@2.0.3
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Shiny.Extensions.DependencyInjection&version=2.0.3
#tool nuget:?package=Shiny.Extensions.DependencyInjection&version=2.0.3
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Shiny Extensions
Dependency Injection Extensions
- Source generate all attributed classes to a single add file - saves you the boilerplate
- Extension methods for registering a dependency against multiple interfaces
- Supports multiple interfaces
- Supports open generics
- Supports keyed services
The Results
THIS:
using Microsoft.Extensions.DependencyInjection;
using Shiny;
// given the following code from a user
namespace Sample
{
public interface IStandardInterface;
public interface IStandardInterface2;
[Service(ServiceLifetime.Singleton)]
public class ImplementationOnly;
[Service(ServiceLifetime.Transient, "ImplOnly")]
public class KeyedImplementationOnly;
[Service(ServiceLifetime.Singleton)]
public class StandardImplementation : IStandardInterface;
[Service(ServiceLifetime.Scoped, "Standard")]
public class KeyedStandardImplementation : IStandardInterface;
[Service(ServiceLifetime.Singleton)]
public class MultipleImplementation : IStandardInterface, IStandardInterface2;
[Service(ServiceLifetime.Scoped)]
public class ScopedMultipleImplementation : IStandardInterface, IStandardInterface2;
[Service(ServiceLifetime.Scoped, "KeyedGeneric")]
public class TestGeneric<T1, T2>
{
public T1 Value1 { get; set; }
public T2 Value2 { get; set; }
}
}
GENERATES THIS:
// <auto-generated />
using global::Microsoft.Extensions.DependencyInjection;
using global::Shiny;
namespace Sample
{
public static class __GeneratedRegistrations
{
public static global::Microsoft.Extensions.DependencyInjection.IServiceCollection AddGeneratedServices(
this global::Microsoft.Extensions.DependencyInjection.IServiceCollection services
)
{
services.AddSingleton<global::Sample.ImplementationOnly>();
services.AddKeyedTransient<global::Sample.KeyedImplementationOnly>("ImplOnly");
services.AddSingleton<global::Sample.IStandardInterface, global::Sample.StandardImplementation>();
services.AddKeyedScoped<global::Sample.IStandardInterface, global::Sample.KeyedStandardImplementation>("Standard");
services.AddSingletonAsImplementedInterfaces<global::Sample.MultipleImplementation>();
services.AddScopedAsImplementedInterfaces<global::Sample.ScopedMultipleImplementation>();
services.AddKeyedScoped(typeof(global::Sample.TestGeneric<,>), "KeyedGeneric");
return services;
}
}
}
Setup
- Install the NuGet package
Shiny.Extensions.DependencyInjection - Add the following using directive:
// during your app startup - use your service collection builder.Services.AddGeneratedServices(); - Add the
[Service(ServiceLifetime.Singleton, "optional key")]attribute to your classes and specify the lifetime and optional key
Stores
- Key/value store with support for
- Android/iOS/Windows - Preferences & Secure Storage
- Web - Local Storage & Session Storage
- In Memory
- Object binder binds INotifyPropertyChanged against a key/value store to persist object changes across sessions
- Simply implement IKeyValueStore to create your own store
Setup
- Install the NuGet package
Shiny.Extensions.Stores - Add the following using directive:
// during your app startup - use your service collection
builder.Services.AddPersistentService<MyNotifyPropertyChangedObject>("secure"); // optional: default to `settings`
- Inject the MyNotifyPropertyChangedObject into your view model or service. Set properties and they will be persisted automatically.
- To bypass reflection and make binding super fast - use Shiny Reflector to remove the need for reflection. It is already built into the Shiny.Extensions.Stores package, so you can use it directly. Just mark
[Reflector]on your class and make your class partial.
Available Stores Per Platform
| Platform | Store Alias | Description |
|---|---|---|
| Android | settings | Preferences store |
| Android | secure | Secure Storage |
| iOS | settings | Preferences store |
| iOS | secure | Secure Storage |
| WebAssembly | settings | Local Storage |
| WebAssembly | session | Session Storage |
| All | Memory | In Memory store - great for testing |
For WebAssembly, install the Shiny.Extensions.Stores.Web package and add services.AddWebAssemblyStores() to your service collection.
Web Hosting Extensions
- Merges service container build and post build scenarios into a single class using
IWebModule
Setup
- Install the NuGet package
Shiny.Extensions.WebHosting - Add a web module by implementing
IWebModule:using Shiny; public class MyWebModule : IWebModule { public void Add(WebApplicationBuilder builder) { // Register your services here } public void Use(WebApplication app) { // Configure your middleware/endpoints here } } - In your application hosting startup, add the following:
using Shiny; var builder = WebApplication.CreateBuilder(args); builder.AddInfrastructureModules(new MyWebModule()); var app = builder.Build(); app.UseInfrastructureModules();
MAUI Hosting Extensions
- Module-based MAUI app configuration with
IMauiModule - Static
Host.Servicesfor accessing the service provider anywhere - Platform lifecycle hooks via
ILifecycleExecutor(foreground/background events, activity results, etc.)
Setup
- Install the NuGet package
Shiny.Extensions.MauiHosting - Create a MAUI module by implementing
IMauiModule:using Shiny; public class MyMauiModule : IMauiModule { public void Add(MauiAppBuilder builder) { // Register your services here } public void Use(IPlatformApplication app) { // Post-build initialization here (do NOT block) } } - In your
MauiProgram.cs:using Shiny; var builder = MauiApp.CreateBuilder(); builder .UseMauiApp<App>() .AddInfrastructureModules(new MyMauiModule()); return builder.Build(); - Access services anywhere via
Host.Services
Additional Libraries Used
- Shiny Reflector - Reflection without the actual reflection
NuGet Packages
| Package | Description |
|---|---|
Shiny.Extensions.DependencyInjection |
Attribute-driven DI registration with source generators |
Shiny.Extensions.Stores |
Cross-platform key/value store abstraction |
Shiny.Extensions.Stores.Web |
Blazor WebAssembly localStorage/sessionStorage |
Shiny.Extensions.WebHosting |
ASP.NET modular web hosting with IWebModule |
Shiny.Extensions.MauiHosting |
MAUI modular hosting with IMauiModule and platform lifecycle hooks |
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net10.0
- Microsoft.Extensions.DependencyInjection (>= 10.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on Shiny.Extensions.DependencyInjection:
| Package | Downloads |
|---|---|
|
Shiny.Extensions.MauiHosting
Package Description |
GitHub repositories (1)
Showing the top 1 popular GitHub repositories that depend on Shiny.Extensions.DependencyInjection:
| Repository | Stars |
|---|---|
|
shinyorg/templates
dotnet CLI & Visual Studio Templates
|
| Version | Downloads | Last Updated |
|---|---|---|
| 2.1.0-beta-0043 | 90 | 3/18/2026 |
| 2.1.0-beta-0042 | 80 | 3/18/2026 |
| 2.1.0-beta-0041 | 103 | 3/17/2026 |
| 2.0.3 | 110 | 3/18/2026 |
| 2.0.2 | 83 | 3/18/2026 |
| 2.0.1 | 117 | 3/17/2026 |
| 2.0.0 | 165 | 3/10/2026 |
| 2.0.0-beta-0047 | 88 | 3/10/2026 |
| 2.0.0-beta-0006 | 86 | 3/10/2026 |
| 2.0.0-beta-0005 | 87 | 3/10/2026 |
| 2.0.0-beta-0001 | 575 | 10/19/2025 |
| 1.3.1 | 466 | 9/20/2025 |
| 1.3.1-beta-0001 | 242 | 9/20/2025 |
| 1.3.0 | 340 | 9/16/2025 |
| 1.3.0-beta-0009 | 195 | 8/11/2025 |
| 1.3.0-beta-0008 | 181 | 7/28/2025 |
| 1.3.0-beta-0007 | 170 | 7/28/2025 |
| 1.3.0-beta-0006 | 345 | 7/26/2025 |
| 1.3.0-beta-0004 | 534 | 7/24/2025 |
| 1.2.2 | 213 | 7/28/2025 |
Loading failed