OfX 1.1.4
See the version list below for details.
dotnet add package OfX --version 1.1.4
NuGet\Install-Package OfX -Version 1.1.4
<PackageReference Include="OfX" Version="1.1.4" />
paket add OfX --version 1.1.4
#r "nuget: OfX, 1.1.4"
// Install OfX as a Cake Addin #addin nuget:?package=OfX&version=1.1.4 // Install OfX as a Cake Tool #tool nuget:?package=OfX&version=1.1.4
OfX
OfX is an open-source, which focus on Attribute-based Data Mapping, simplifying data handling across services and enhancing maintainability.
Project Highlights
Attribute-based Data Mapping in OfX is a feature that lets developers annotate properties in their data models with custom attributes. These attributes define how and from where data should be fetched, eliminating repetitive code and automating data retrieval.
For example, imagine a scenario where Service A needs a user’s name stored in Service B. With Attribute-based Data Mapping, Service A can define a UserName property annotated with [UserOf(nameof(UserId))]
. This tells the system to automatically retrieve the UserName based on UserId, without writing custom code each time.
Example:
public sealed class SomeDataResponse
{
public string Id { get; set; }
public string UserId { get; set; }
[UserOf(nameof(UserId), Expression = "Email")]
public string UserEmail { get; set; }
[UserOf(nameof(UserId))] public string UserName { get; set; }
...
}
The [UserOf]
annotation acts as a directive to automatically retrieve UserName
based on UserId
,you can also fetch custom fields as Email
on the User Table using Expression like [UserOf(nameof(UserId), Expression="Email")]
. This eliminates the need for manual mapping logic, freeing developers to focus on core functionality rather than data plumbing.
Start with OfX
To install the OfX package, use the following NuGet command:
dotnet add package OfX
Or via the NuGet Package Manager:
Install-Package OfX
How to Use
1. Register OfX in the Dependency Injection Container
Add the OfX to your service configuration to register OfX:
builder.Services.AddOfX(cfg =>
{
cfg.RegisterContractsContainsAssemblies(typeof(SomeContractAssemblyMarker).Assembly);
cfg.RegisterHandlersContainsAssembly<SomeHandlerAssemblyMarker>();
});
Function Descriptions
RegisterContractsContainsAssemblies
Registers assemblies that contain the contracts (queries) used by OfX for data mapping.
Contracts define the structure and logic for retrieving data.
Parameters:
Assembly
: The assembly containing the contract definitions.
Example:
cfg.RegisterContractsContainsAssemblies(typeof(SomeContractAssemblyMarker).Assembly);
In this example, SomeContractAssemblyMarker
is a type within the assembly containing your contract definitions.
RegisterHandlersContainsAssembly
Registers assemblies that contain handlers responsible for processing queries or commands for data retrieval.
Handlers are the execution units that resolve attributes applied to models.
Parameters:
Type
: A marker type within the assembly that includes the handler implementations.
Example:
cfg.RegisterHandlersContainsAssembly<SomeHandlerAssemblyMarker>();
Here, SomeHandlerAssemblyMarker
is a type within the assembly where your handler logic resides.
2. Create a Relevant Attribute Based on Your Use Case
Define a custom attribute, such as UserOfAttribute, to suit your specific purpose:
public sealed class UserOfAttribute(string propertyName) : OfXAttribute(propertyName);
3. Integrate the Attribute into Your Model, Entity, or DTO
Apply the attribute to your properties like this:
public sealed class SomeDataResponse
{
public string Id { get; set; }
public string UserId { get; set; }
[UserOf(nameof(UserId), Expression = "Email")]
public string UserEmail { get; set; }
[UserOf(nameof(UserId))]
public string UserName { get; set; }
// Add other properties as needed
}
4. Write a Handler in Your Service to Fetch the Data
Implement a handler to process data requests. For example:
public class UserRequestHandler(IRequestClient<GetUserOfXQuery> client)
: IMappableRequestHandler<GetUserOfXQuery, UserOfAttribute>
{
public async Task<ItemsResponse<OfXDataResponse>> RequestAsync(
RequestContext<GetUserOfXQuery> request,
CancellationToken cancellationToken = default)
{
// Implement data fetching logic here (e.g., via REST, RPC, or gRPC)
}
}
Enjoy your moment!
Package Name | Description | .NET Version | Document |
---|---|---|---|
OfX | OfX core | 8.0, 9.0 | This Document |
OfX-EFCore | This is the OfX extension package using EntityFramework to fetch data | 8.0, 9.0 | ReadMe |
OfX-gRPC | OfX.gRPC is an extension package for OfX that leverages gRPC for efficient data transportation. | 8.0, 9.0 | ReadMe |
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. 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 is compatible. 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. |
-
net8.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
- Newtonsoft.Json (>= 13.0.3)
-
net9.0
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 9.0.0)
- Newtonsoft.Json (>= 13.0.3)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on OfX:
Package | Downloads |
---|---|
OfX-EFCore
OfX extension. Use EntityFramework as Data Querying |
|
OfX-gRPC
OfX extension. Use gRPC as Data transporting |
|
OfX-Nats
Nats.io extension. Use Nats as Data transporting |
|
OfX-RabbitMq
OfX-RabbitMq extension. Use RabbitMq as Data transporting |
|
OfX-Kafka
OfX-Kafka extension. Use Kafka as Data transporting |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
4.0.0 | 26 | 2/4/2025 |
3.3.3 | 56 | 2/4/2025 |
3.3.2 | 79 | 2/3/2025 |
3.3.1 | 75 | 2/1/2025 |
3.3.0 | 89 | 1/22/2025 |
3.2.1 | 103 | 1/22/2025 |
3.2.0 | 97 | 1/21/2025 |
3.1.13 | 96 | 1/18/2025 |
3.1.12 | 104 | 1/16/2025 |
3.1.11 | 87 | 1/13/2025 |
3.1.10 | 90 | 1/12/2025 |
3.1.9 | 88 | 1/10/2025 |
3.1.8 | 73 | 1/8/2025 |
3.1.7 | 95 | 1/7/2025 |
3.1.6 | 100 | 1/6/2025 |
3.1.5 | 100 | 1/5/2025 |
3.1.4 | 113 | 1/4/2025 |
3.1.3 | 115 | 1/4/2025 |
3.1.2 | 117 | 1/4/2025 |
3.1.1 | 118 | 1/3/2025 |
3.1.0 | 98 | 12/31/2024 |
3.0.5 | 86 | 12/30/2024 |
3.0.4 | 83 | 12/30/2024 |
3.0.3 | 91 | 12/30/2024 |
3.0.2 | 94 | 12/30/2024 |
3.0.1 | 88 | 12/30/2024 |
3.0.0 | 97 | 12/30/2024 |
2.0.3 | 100 | 12/30/2024 |
2.0.2 | 94 | 12/29/2024 |
2.0.1 | 94 | 12/29/2024 |
2.0.0 | 92 | 12/28/2024 |
1.1.4 | 103 | 12/27/2024 |
1.1.3 | 97 | 12/26/2024 |
1.1.2 | 101 | 12/26/2024 |
1.1.1 | 100 | 12/26/2024 |
1.1.0 | 92 | 12/25/2024 |
1.0.8 | 102 | 12/25/2024 |
1.0.7 | 93 | 12/25/2024 |
1.0.6 | 115 | 12/25/2024 |
1.0.5 | 80 | 12/24/2024 |
1.0.4 | 92 | 12/24/2024 |
1.0.3 | 81 | 12/24/2024 |
1.0.2 | 80 | 12/24/2024 |
1.0.1 | 82 | 12/24/2024 |
1.0.0 | 78 | 12/23/2024 |