SWEN3.Paperless.RabbitMq
2.3.1
dotnet add package SWEN3.Paperless.RabbitMq --version 2.3.1
NuGet\Install-Package SWEN3.Paperless.RabbitMq -Version 2.3.1
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.3.1" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="SWEN3.Paperless.RabbitMq" Version="2.3.1" />
<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.3.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: SWEN3.Paperless.RabbitMq, 2.3.1"
#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.3.1
#: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.3.1
#tool nuget:?package=SWEN3.Paperless.RabbitMq&version=2.3.1
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
// Basic command
var command = new OcrCommand(docId, fileName, storagePath);
await publisher.PublishOcrCommandAsync(command);
// With timestamp (v2.2.0+)
var command = new OcrCommand(docId, fileName, storagePath, createdAt: DateTimeOffset.UtcNow);
await publisher.PublishOcrCommandAsync(command);
// Event
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 Endpoints
// Built-in endpoints
app.MapOcrEventStream(); // /api/v1/ocr-results
app.MapGenAIEventStream(); // /api/v1/events/genai
// Custom endpoint with dynamic event types (v2.3.0+)
app.MapSse<NotificationEvent>("/api/notifications", evt => evt.Type);
// Custom endpoint with fixed event type (v2.4.0+)
app.MapSse<HeartbeatEvent>("/api/heartbeat", "heartbeat");
// Full control with payload projection
app.MapSse<OcrEvent>("/api/ocr",
evt => new { evt.JobId, evt.Status }, // payload
evt => evt.Status == "Completed" ? "done" : "error"); // event type
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.5-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
// OCR
public record OcrCommand(Guid JobId, string FileName, string FilePath, DateTimeOffset? CreatedAt = null);
public record OcrEvent(Guid JobId, string Status, string? Text, DateTimeOffset ProcessedAt);
// GenAI
public record GenAICommand(Guid DocumentId, string Text);
public record GenAIEvent(Guid DocumentId, string? Summary, DateTimeOffset GeneratedAt, string? ErrorMessage = null);
SSE MapSse Overloads
| Overload | Use Case |
|---|---|
MapSse<T>(pattern, payloadSelector, eventTypeSelector) |
Full control over payload and per-event type |
MapSse<T>(pattern, eventTypeSelector) |
Serialize whole object, dynamic event type |
MapSse<T>(pattern, eventType) |
Serialize whole object, fixed event type |
Installation
dotnet add package SWEN3.Paperless.RabbitMq
Changelog
v2.4.0
- Added
MapSse<T>(pattern, eventType)overload for fixed event type streams - .NET 10: Uses optimized
TypedResults.ServerSentEventsoverload (no per-eventSseItem<T>allocation)
v2.3.0
ISseStream<T>now extendsIAsyncDisposablefor graceful shutdown- Added
MapSse<T>(pattern, eventTypeSelector)overload for simplified endpoint registration SseStream<T>completes all client channels on dispose
v2.2.0
- Added optional
CreatedAtparameter toOcrCommandfor document timestamp tracking - Updated default Gemini model to
gemini-2.5-flash
v2.1.0
- GenAI SSE streaming support
v2.0.0
- Simplified
AddPaperlessGenAI()registration - Added
Microsoft.Extensions.Http.Resiliencefor automatic retry/circuit breaker - Configuration section renamed:
GenAI:Gemini→Gemini
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.3.1 | 449 | 12/1/2025 |
| 2.3.0 | 351 | 11/30/2025 |
| 2.2.0 | 398 | 11/30/2025 |
| 2.1.2 | 184 | 11/23/2025 |
| 2.1.0 | 235 | 11/22/2025 |
| 2.0.8 | 403 | 11/20/2025 |
| 2.0.7 | 400 | 11/20/2025 |
| 2.0.6 | 398 | 11/20/2025 |
| 2.0.5 | 392 | 11/20/2025 |
| 2.0.4 | 396 | 11/20/2025 |
| 2.0.3 | 403 | 11/20/2025 |
| 2.0.2 | 293 | 11/12/2025 |
| 2.0.1 | 283 | 11/12/2025 |
| 2.0.0 | 287 | 11/12/2025 |
| 1.0.4 | 312 | 9/9/2025 |
| 1.0.3 | 518 | 7/24/2025 |
| 1.0.2 | 513 | 7/24/2025 |
| 1.0.1 | 507 | 7/24/2025 |
| 1.0.0 | 505 | 7/24/2025 |