SWEN3.Paperless.RabbitMq
2.1.2
dotnet add package SWEN3.Paperless.RabbitMq --version 2.1.2
NuGet\Install-Package SWEN3.Paperless.RabbitMq -Version 2.1.2
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="SWEN3.Paperless.RabbitMq" Version="2.1.2" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="SWEN3.Paperless.RabbitMq" Version="2.1.2" />
<PackageReference Include="SWEN3.Paperless.RabbitMq" />
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 SWEN3.Paperless.RabbitMq --version 2.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: SWEN3.Paperless.RabbitMq, 2.1.2"
#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 SWEN3.Paperless.RabbitMq@2.1.2
#: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=SWEN3.Paperless.RabbitMq&version=2.1.2
#tool nuget:?package=SWEN3.Paperless.RabbitMq&version=2.1.2
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Star if this works for you — helps others find it.
SWEN3.Paperless.RabbitMq
RabbitMQ messaging library for .NET with SSE support and AI-powered document summarization.
Migration to v2.0.0
// Before (v1.0.4)
services.AddOptionsWithValidateOnStart<GeminiOptions>()
.BindConfiguration("GenAI:Gemini")
.ValidateDataAnnotations();
services.AddHttpClient<ITextSummarizer, GeminiService>();
services.AddHostedService<GenAIWorker>();
// After (v2.0.0) - Minimal
services.AddPaperlessGenAI(configuration);
// After (v2.0.0) - With optional validation
services.AddOptionsWithValidateOnStart<GeminiOptions>()
.BindConfiguration(GeminiOptions.SectionName)
.ValidateDataAnnotations();
services.AddPaperlessGenAI(configuration);
Breaking Changes:
- Configuration section renamed:
GenAI:Gemini→Gemini - Removed
MaxRetriesproperty fromGeminiOptions(retry handling now managed byAddStandardResilienceHandler())
Configuration
{
"RabbitMQ": {
"Uri": "amqp://guest:guest@localhost:5672"
}
}
Usage
Basic Setup
// Add RabbitMQ
builder.Services.AddPaperlessRabbitMq(builder.Configuration);
// With SSE support
services.AddPaperlessRabbitMq(config, includeOcrResultStream: true, includeGenAiResultStream: true);
Publishing
var command = new OcrCommand(docId, fileName, storagePath);
await publisher.PublishOcrCommandAsync(command);
var result = new OcrEvent(jobId, "Completed", text, DateTimeOffset.UtcNow);
await publisher.PublishOcrEventAsync(result);
Consuming
await using var consumer = await factory.CreateConsumerAsync<OcrCommand>();
await foreach (var command in consumer.ConsumeAsync(cancellationToken))
{
try
{
// Process message
await consumer.AckAsync();
}
catch
{
await consumer.NackAsync(requeue: true);
}
}
SSE Endpoint
// Map endpoint
app.MapOcrEventStream();
// Client-side
const eventSource = new EventSource('/api/v1/ocr-results');
eventSource.addEventListener('ocr-completed', (event) => {
const data = JSON.parse(event.data);
console.log(data);
});
GenAI Support (v2.0.0+)
// Enable GenAI features with RabbitMQ streaming
builder.Services.AddPaperlessRabbitMq(configuration,
includeOcrResultStream: true,
includeGenAiResultStream: true);
// Add Gemini document summarization (includes automatic resilience)
builder.Services.AddPaperlessGenAI(configuration);
// Publish GenAI command
var genAiCommand = new GenAICommand(request.JobId, result.Text!);
await _publisher.PublishGenAICommandAsync(genAiCommand);
Configuration:
{
"Gemini": {
"ApiKey": "your-api-key",
"Model": "gemini-2.0-flash",
"TimeoutSeconds": 30
}
}
What you get automatically:
- HTTP retry with exponential backoff + jitter (3 attempts)
- Circuit breaker for preventing cascade failures
- Timeout handling per request
- All powered by
Microsoft.Extensions.Http.Resilience
Message Types
public record OcrCommand(Guid JobId, string FileName, string FilePath);
public record OcrEvent(Guid JobId, string Status, string? Text, DateTimeOffset ProcessedAt);
public record GenAICommand(Guid DocumentId, string Text);
public record GenAIEvent(Guid DocumentId, string? Summary, DateTimeOffset ProcessedAt, string? ErrorMessage = null);
Installation
dotnet add package SWEN3.Paperless.RabbitMq
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 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. 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.Http.Resilience (>= 10.0.0)
- RabbitMQ.Client (>= 7.2.0)
-
net8.0
- Microsoft.Extensions.Http.Resilience (>= 8.10.0)
- RabbitMQ.Client (>= 7.2.0)
-
net9.0
- Microsoft.Extensions.Http.Resilience (>= 9.10.0)
- RabbitMQ.Client (>= 7.2.0)
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 |
|---|---|---|
| 2.1.2 | 98 | 11/23/2025 |
| 2.1.0 | 217 | 11/22/2025 |
| 2.0.8 | 380 | 11/20/2025 |
| 2.0.7 | 380 | 11/20/2025 |
| 2.0.6 | 382 | 11/20/2025 |
| 2.0.5 | 374 | 11/20/2025 |
| 2.0.4 | 381 | 11/20/2025 |
| 2.0.3 | 378 | 11/20/2025 |
| 2.0.2 | 269 | 11/12/2025 |
| 2.0.1 | 261 | 11/12/2025 |
| 2.0.0 | 260 | 11/12/2025 |
| 1.0.4 | 299 | 9/9/2025 |
| 1.0.3 | 506 | 7/24/2025 |
| 1.0.2 | 498 | 7/24/2025 |
| 1.0.1 | 495 | 7/24/2025 |
| 1.0.0 | 490 | 7/24/2025 |