AnnotationServiceBuilder 1.1.2
See the version list below for details.
dotnet add package AnnotationServiceBuilder --version 1.1.2
NuGet\Install-Package AnnotationServiceBuilder -Version 1.1.2
<PackageReference Include="AnnotationServiceBuilder" Version="1.1.2" />
<PackageVersion Include="AnnotationServiceBuilder" Version="1.1.2" />
<PackageReference Include="AnnotationServiceBuilder" />
paket add AnnotationServiceBuilder --version 1.1.2
#r "nuget: AnnotationServiceBuilder, 1.1.2"
#:package AnnotationServiceBuilder@1.1.2
#addin nuget:?package=AnnotationServiceBuilder&version=1.1.2
#tool nuget:?package=AnnotationServiceBuilder&version=1.1.2
AnnotationServiceBuilder
AnnotationServiceBuilder is an ASP.NET Core library that simplifies dependency injection by using custom annotations to automatically register services in the DI container.
Prerequisites
Web Application
- .NET 6.0 or later
- Visual Studio 2022 (or any other IDE with .NET support)
Important Note
Ensure that your .NET SDK is up-to-date. This project requires .NET 6.0 or later.
Setting up Annotations
The Annotations
folder in your project contains the key attributes used for automatically registering services in the DI container. Below are the files and their purposes, along with examples of how they are used:
Installing AnnotationServiceBuilder
Step 1: Install the AnnotationServiceBuilder NuGet Package
You can install the AnnotationServiceBuilder package via NuGet.
Using Package Manager Console
Install-Package AnnotationServiceBuilder
Using .NET Core CLI
dotnet add package AnnotationServiceBuilder
Step 2: Set Up Annotations
Follow these steps to configure and use AnnotationServiceBuilder in your project.
If You're Using before Version 1.0.9
Add the following to your Startup.cs
or Program.cs
:
var assembly = Assembly.GetExecutingAssembly();
builder.Services.AddAnnotatedSingletonServices(assembly);
builder.Services.AddAnnotatedScopedServices(assembly);
builder.Services.AddAnnotatedTransientServices(assembly);
builder.Services.AddRefitClientsFromAttributes(assembly, "https://api.yourservice.com"); // Replace with your API base URL
If You're Using Version 1.0.9
First, create an instance of AnnotationServiceRegistrar
:
var registrar = new AnnotationServiceRegistrar(Assembly.GetExecutingAssembly());
Then, register your services:
registrar.AddSingletonServices(services);
registrar.AddScopedServices(services);
registrar.AddTransientServices(services);
registrar.AddRefitClients(services, "https://api.yourservice.com"); // Replace with your API base URL
If you need to use a custom DelegatingHandler
, you can do so with the following:
var customHandler = new MyCustomHandler();
registrar.AddRefitClients(services, "https://api.yourservice.com", customHandler);
If You're Using Version 1.1.1 or Later
Instead of creating an instance of AnnotationServiceRegistrar
, use the static method Initialize
to set up the types and then call the registration methods:
AnnotationServiceRegistrar.Initialize(Assembly.GetExecutingAssembly());
AnnotationServiceRegistrar.AddSingletonServices(services);
AnnotationServiceRegistrar.AddScopedServices(services);
AnnotationServiceRegistrar.AddTransientServices(services);
AnnotationServiceRegistrar.AddRefitClients(services, "https://api.yourservice.com"); // Replace with your API base URL
If you need to use a custom DelegatingHandler
, use the following:
var customHandler = new MyCustomHandler();
AnnotationServiceRegistrar.AddRefitClients(services, "https://api.yourservice.com", customHandler);
Usage
Here are examples of how to use each annotation in your project:
1. Using Scoped Services
using AnnotationServiceBuilder.Annotations.Scoped;
[ScopedService(typeof(IMyScopedService))]
public class MyScopedService : IMyScopedService
{
// Implementation...
}
2. Using Singleton Services
using AnnotationServiceBuilder.Annotations.Singleton;
[SingletonService]
public class MySingletonService
{
// Implementation...
}
3. Using Transient Services
using AnnotationServiceBuilder.Annotations.Transient_Services;
[TransientService]
public class MyTransientService
{
// Implementation...
}
4. Example of a Refit Client
using AnnotationServiceBuilder.Annotations.Refit;
using AnnotationServiceBuilder.Data.Models;
using Refit;
namespace AnnotationServiceBuilder.Network.Repositories
{
[RefitClient]
public interface IPostsApi
{
[Get("/posts")]
Task<List<Post>> GetPostsAsync();
[Get("/posts/{id}")]
Task<Post> GetPostByIdAsync(int id);
}
}
5. Example with Different baseUrl
for Multiple Refit Clients
using AnnotationServiceBuilder.Annotations.Refit;
using Refit;
namespace AnnotationServiceBuilder.Network.Repositories
{
[RefitClient(BaseUrl = "https://api.service1.com")]
public interface IService1Api
{
[Get("/endpoint1")]
Task<List<ResponseModel1>> GetService1DataAsync();
}
[RefitClient(BaseUrl = "https://api.service2.com")]
public interface IService2Api
{
[Get("/endpoint2")]
Task<List<ResponseModel2>> GetService2DataAsync();
}
[RefitClient(BaseUrl = "https://api.service3.com")]
public interface IService3Api
{
[Get("/endpoint3")]
Task<List<ResponseModel3>> GetService3DataAsync();
}
}
Benefits of Using AnnotationServiceBuilder
1. Automation of Service Registration
Automatically register your services in the DI container without needing to manually add each service in Startup.cs
or Program.cs
. This reduces boilerplate code and makes your setup process much more streamlined.
2. Clear and Organized Codebase
Annotations define the lifetime of services (Singleton, Scoped, Transient), making your code more organized and easier to maintain.
3. Time Efficiency
Automating service registration saves time, especially in large projects. Developers can focus on building features instead of managing service registrations manually.
4. Ease of Use
The library provides a simple, intuitive API for registering services and Refit clients, making the process user-friendly.
5. Caching for Performance
Registered classes and interfaces are cached to improve performance and reduce the overhead of repeated reflection operations.
Video Guide
For a video guide on how to use AnnotationServiceBuilder, you can watch this YouTube video: AnnotationServiceBuilder Guide.
Contributing
We welcome contributions! Please submit a pull request or open an issue to discuss your ideas or report bugs.
License
This project is licensed under the MIT License.
MIT License
Copyright (c) 2024 Gennadii Ianchev
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. net10.0 was computed. 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. |
-
net6.0
- Microsoft.Extensions.DependencyInjection (>= 8.0.0)
- Refit (>= 7.1.2)
- Refit.HttpClientFactory (>= 7.1.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.