Flaminco.AzureBus.AMQP
2.2.0
dotnet add package Flaminco.AzureBus.AMQP --version 2.2.0
NuGet\Install-Package Flaminco.AzureBus.AMQP -Version 2.2.0
<PackageReference Include="Flaminco.AzureBus.AMQP" Version="2.2.0" />
paket add Flaminco.AzureBus.AMQP --version 2.2.0
#r "nuget: Flaminco.AzureBus.AMQP, 2.2.0"
// Install Flaminco.AzureBus.AMQP as a Cake Addin #addin nuget:?package=Flaminco.AzureBus.AMQP&version=2.2.0 // Install Flaminco.AzureBus.AMQP as a Cake Tool #tool nuget:?package=Flaminco.AzureBus.AMQP&version=2.2.0
Flaminco.AzureBus.AMQP
Flaminco.AzureBus.AMQP is a .NET library that simplifies the integration of Azure Bus in your applications. This library provides a clean and easy-to-use API for creating consumers and publishers to interact with AzureBus queues.
Installation
You can install the package via NuGet Package Manager:
dotnet add package Flaminco.AzureBus.AMQP
Or via the Package Manager Console in Visual Studio:
Install-Package Flaminco.AzureBus.AMQP
Getting Started
Step 1: Configure the AMQP Client
First, you need to configure the AMQP client in your application's Startup
or Program
class:
builder.Services.AddAMQPClient<Program>(options =>
{
options.ConnectionString = "<Azure Bus Connection String>";
});
Step 2: Create a Message Publisher
Implement a custom publisher by extending the MessagePublisher
class. The publisher defines the queue(s) to which it
will send messages:
// must be shared between your consumer and publisher (Must be same type not only identical in properties)
// in case you didn't Set SkipMessageTypeMatching to true.
// if you set SkipMessageTypeMatching = true, then you don't need the identical type
public class Person : IMessage
{
public string Name { get; set; }
public int Age { get; set; }
}
public class PersonPublisher : MessagePublisher<Person>
{
public PersonPublisher(ISendEndpointProvider sendEndpointProvider) : base(sendEndpointProvider)
{
}
protected override string Queue => "HelloQueue";
}
Step 3: Send a Message
Now, you can use your custom publisher to send a message to the specified queue:
public class Example(PersonPublisher _personPublisher)
{
[HttpGet]
public async Task PushMessage(CancellationToken cancellationToken)
{
await _personPublisher.PublishAsync(new Person
{
Name = "Ahmed Abuelnour",
Age = 30
}, cancellationToken);
}
}
Step 4: Create a Message Consumer
Implement a custom consumer by extending the MessageConsumer
class. The consumer defines the queue from which it will
receive messages:
// For queue consumers
[QueueConsumer(queue: "HelloQueue")]
public class PersonConsumer : MessageConsumer<Person>
{
public override Task Consume(ConsumeContext<Person> context)
{
Console.WriteLine($"Received message: {context.Message.Name}, Age: {context.Message.Age}");
return Task.CompletedTask;
}
public override Task Consume(ConsumeContext<Fault<MessageBox>> context)
{
return base.Consume(context);
}
}
// For topic consumers
[TopicConsumer(topic: "HelloQueue", subscription: nameof(PersonConsumer))]
public class PersonConsumer : MessageConsumer<Person>
{
public override Task Consume(ConsumeContext<Person> context)
{
Console.WriteLine($"Received message: {context.Message.Name}, Age: {context.Message.Age}");
return Task.CompletedTask;
}
public override Task Consume(ConsumeContext<Fault<MessageBox>> context)
{
return base.Consume(context);
}
}
// For filter based topic consumer
// you can define sql filter
public class SqlFilterProvider : IRuleFilterProvider
{
public RuleFilter? GetRuleFilter()
{
// Filter key is the one you use in MessagePublishOptions, and Filter Value is the value you pass
return new SqlRuleFilter("FilterKey = FilterValue");
}
}
// or you can define correlation filter
public class CorrelationFilterProvider : IRuleFilterProvider
{
public RuleFilter? GetRuleFilter()
{
return new CorrelationRuleFilter
{
CorrelationId = "Correlation Id Value"
};
}
}
[TopicConsumer(topic: "HelloQueue", subscription: nameof(PersonConsumer), typeof(CorrelationFilterProvider))]
public class PersonConsumer : MessageConsumer<Person>
{
public override Task Consume(ConsumeContext<Person> context)
{
Console.WriteLine($"Received message: {context.Message.Name}, Age: {context.Message.Age}");
return Task.CompletedTask;
}
public override Task Consume(ConsumeContext<Fault<MessageBox>> context)
{
return base.Consume(context);
}
}
Step 5: Run the Application
Build and run your application. The consumer will continuously listen for messages on the specified queue, while the publisher sends messages to that queue.
Step 6: Message Flow
To build synchronous communication between a publisher and waiting the consumer to return a response
[MessageFlow("HelloTest", typeof(ExampleRequest))]
public sealed class HelloMessageFlow(IRequestClient<ExampleRequest> requestClient) : MessageFlow<ExampleRequest>(requestClient);
example for using the flow publisher
[ApiController]
[Route("api/pdf")]
public class ExampleController(HelloMessageFlow helloMessageFlow) : ControllerBase
{
[HttpPost("greating")]
public async Task<IActionResult> GenerateMessage()
{
Response<ExampleResponse> response = await helloMessageFlow.GetResponseAsync<ExampleResponse>(new ExampleRequest
{
Id = 1,
});
return Ok(response.Message);
}
}
and for consumer
[QueueConsumer("HelloTest")]
public class ExampleConsumer : MessageConsumer<ExampleRequest>
{
public override async Task Consume(ConsumeContext<ExampleRequest> context)
{
await context.RespondAsync<ExampleResponse>(new ExampleResponse
{
Message = "This is a test message"
});
}
}
Messages example
public class ExampleRequest : IMessage
{
public int Id { get; set; }
}
public class ExampleResponse : IMessage
{
public string Message { get; set; }
}
Contributing
If you encounter any issues or have suggestions for improvements, please feel free to contribute by submitting an issue or a pull request.
License
This project is licensed under the MIT License.
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 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. |
-
net8.0
- MassTransit (>= 8.3.0)
- MassTransit.Azure.ServiceBus.Core (>= 8.3.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 8.0.1)
- Microsoft.Extensions.Options (>= 8.0.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.