RickDotNet.Apollo.Messaging
0.1.1
dotnet add package RickDotNet.Apollo.Messaging --version 0.1.1
NuGet\Install-Package RickDotNet.Apollo.Messaging -Version 0.1.1
<PackageReference Include="RickDotNet.Apollo.Messaging" Version="0.1.1" />
paket add RickDotNet.Apollo.Messaging --version 0.1.1
#r "nuget: RickDotNet.Apollo.Messaging, 0.1.1"
// Install RickDotNet.Apollo.Messaging as a Cake Addin #addin nuget:?package=RickDotNet.Apollo.Messaging&version=0.1.1 // Install RickDotNet.Apollo.Messaging as a Cake Tool #tool nuget:?package=RickDotNet.Apollo.Messaging&version=0.1.1
Apollo
Apollo is a lightweight, high-performance messaging platform built on top of the NATS messaging system. It is designed to provide developers with a simple yet powerful way to incorporate flexible architectures into their .NET applications. With Apollo, you can easily handle events, commands, and requests with minimal configuration, while benefiting from the speed and scalability of NATS.
Planned Features
- Simple Configuration: Set up your messaging handlers and publishers with just a few lines of code.
- Auto-wiring of Consumers: Apollo automatically discovers and wires up your message handlers, making it easy to scale your system.
- Integration with .NET Core: Designed to work seamlessly with the .NET Core dependency injection system.
- High Throughput: Leverages the performance of NATS to handle high volumes of messages efficiently.
- Flexible Serialization: Supports various serialization formats to suit your needs.
- Scalability: Scales horizontally as your application grows, thanks to the underlying NATS infrastructure.
- Resilience: Built-in fault tolerance and message retry mechanisms to ensure reliable message delivery.
Getting Started
To get started with Apollo, you'll need to have a running instance of NATS. You can find instructions on setting up NATS here.
Current Usage
The API is in rapid design right now. This is the current usage.
Endpoint Host
var builder = Host.CreateApplicationBuilder(args);
var config = ApolloConfig.Default;
builder.Services.AddApollo(
config,
apollo => apollo.WithEndpoints(endpoints => endpoints.AddEndpoint<TestEndpoint>()));
return builder.Build();
Endpoint
public record TestEvent(string Message) : IEvent;
// EndpointBase is optional, but provides access to the MesssageContext
public class TestEndpoint : EndpointBase, IListenFor<TestEvent>
{
private readonly ILogger<TestEndpoint> logger;
public TestEndpoint(ILogger<TestEndpoint> logger)
{
this.logger = logger;
}
public Task HandleAsync(TestEvent message, CancellationToken cancellationToken = default)
{
logger.LogInformation("TestEndpoint Received: {Message}", message.Message);
logger.LogInformation("Subject: {Subject}", Context.Subject);
logger.LogInformation("Source: {Source}", Context.Source);
logger.LogInformation("ReplyTo: {ReplyTo}", Context.ReplyTo);
Context.Headers.ToList()
.ForEach(x => logger.LogInformation("Header: {Key}={Value}", x.Key, x.Value));
return Task.FromResult(true);
}
}
External Publisher
var config = ApolloConfig.Default;
var builder = Host.CreateApplicationBuilder(args);
builder.Services
.AddApollo(config, x=>x.WithEndpoints());
var host = builder.Build();
var publisherFactory = host.Services.GetRequiredService<IPublisherFactory>();
var remoteDispatcher = publisherFactory.CreatePublisher("TestEndpoint");
await remoteDispatcher.BroadcastAsync(new TestEvent("Hello, World!"),default);
public record TestEvent(string Message) : IEvent;
Local Publisher
var localPublisher = publisherFactory.CreatePublisher(nameof(TestEndpoint), PublisherType.Local);
localPublisher.BroadcastAsync(new TestEvent("Hello, World!"), cancellationToken);
NATS Cli
nats pub apollo.default.testendpoint.testevent "{""message"":""Hello, World!""}"
HTTP
POST https://localhost:7199/endpoints/apollo.default.testendpoint.testevent
Accept: application/json
Content-Type: application/json
{
"message": "Hello, World!"
}
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. |
-
net8.0
- Microsoft.AspNetCore.Hosting (>= 2.2.7)
- RickDotNet.Apollo (>= 0.1.1)
- RickDotNet.Apollo.Abstractions (>= 0.1.1)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|