Kafka.SignalR 1.0.1

dotnet add package Kafka.SignalR --version 1.0.1
                    
NuGet\Install-Package Kafka.SignalR -Version 1.0.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="Kafka.SignalR" Version="1.0.1" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Kafka.SignalR" Version="1.0.1" />
                    
Directory.Packages.props
<PackageReference Include="Kafka.SignalR" />
                    
Project file
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 Kafka.SignalR --version 1.0.1
                    
#r "nuget: Kafka.SignalR, 1.0.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.
#addin nuget:?package=Kafka.SignalR&version=1.0.1
                    
Install Kafka.SignalR as a Cake Addin
#tool nuget:?package=Kafka.SignalR&version=1.0.1
                    
Install Kafka.SignalR as a Cake Tool

Kafka.SignalR

Real-time Kafka Message Delivery to Frontend Using SignalR

Nuget Nuget

Overview

In this guide, we will demonstrate how to set up a Kafka.SingalR in your application and deliver Kafka messages directly to your frontend client using SignalR. This approach enables real-time updates and seamless communication between your backend and frontend.

Feature

  • Connect Kafka as a Consumer: Establish a connection to Kafka and consume messages from one or more topics.
  • Deliver Kafka Messages Directly to UI Client: Use SignalR to push Kafka messages to the frontend in real-time.
  • Support for Multiple Kafka Topics: Easily connect and consume messages from multiple Kafka topics.

Usage

  1. Install the Kafka.SignalR NuGet package.
  • .NET CLI
  dotnet add package Kafka.SignalR --version 1.0.1
  • PackageManager
Install-Package Kafka.SignalR -Version 1.0.1
  1. In ConfigureServices in Startup.cs, configure with .AddKafkaSignalR(Configuration.GetSection("Kafka")):
  2. In Configure in Startup.cs, configure with endpoints.MapHub<KafkaSignalRHub>(Configuration["Kafka:Hub"])

Configuration

Simple configuration:

services.AddKafkaSignalR(Configuration.GetSection("Kafka"))
 app.UseEndpoints(endpoints =>
            {
                endpoints
                .MapHub<KafkaSignalRHub>(Configuration["Kafka:Hub"])
                endpoints
                .MapGet("/", async context => { 
                    await context.Response.WriteAsync("Running Kafka Service...."); 
                });
            });

Simple appsettings.json

"Kafka": {
    "Hub": "kafka/hubService",
    "Topics": "MyTopic",
    "GroupId": "myFirstApp",
    "BootstrapServers": "localhost:9092",
    "SecurityProtocol": "PlainText", //Ssl or PlainText
    "EnableAutoCommit": "true",
    "AutoCommitIntervalMs": "600000",
    //If Ssl than configure below
    "SslCaLocation": "",
    "SslCertificateLocation": "",
    "SslKeyLocation": ""
  },

SignalR Client

const connection = new signalR.HubConnectionBuilder().withUrl("https://localhost:44363/kafka/hubService").build();

connection.on("RelayMessage", function (topicName,message) {
    // your code 
  
  });

  connection.start().then(function () {
   
   //subscribe to kafka topics
    connection.invoke("Subscribe", "MyTopic");
    connection.invoke("Subscribe", "MyTopic1");
}).catch(function (err) {
    return console.error(err.toString());
});

Override Message Processing (NEW)

If user want to override message processing before delivering it to the SignalR Client. Please follow the below approach.

public class KafkaMessageProcessService: IKafkaMessageProcessService
{
     public string ProcessMessage(string message)
     {
        string processedMessage = message;
        //Do your process
         return processedMessage;
     }
}

public void ConfigureServices(IServiceCollection services)
{
    ...
    services.AddSingleton<IKafkaMessageProcessService, KafkaMessageProcessService>();
    ...

}

Local Build and DEMO

Move the demo folder outside of KafkaSignalR folder.

Open demo\UI.ServiceKafkaConsumerService.csproj project

Product Compatible and additional computed target framework versions.
.NET 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
1.0.1 5,556 3/10/2025
1.0.0 6,365 7/26/2023