Skip to content

Latest commit

 

History

History
256 lines (233 loc) · 7.35 KB

README.md

File metadata and controls

256 lines (233 loc) · 7.35 KB

Feature

go-sse-broker is a powerful and flexible SSE (Server-Sent Events) server designed to offer a complete SSE service solution. Built with scalability in mind, it connects to a Redis instance to automatically form a cluster, ensuring efficient message distribution across multiple nodes.

Key features include:

  • Multi-device support for a single user: Users can connect from multiple devices simultaneously, with seamless synchronization across all connected devices.
  • Targeted message delivery: Provides APIs to send messages and events to a specific user, a specific device, or broadcast to all connected clients.
  • Redis-based clustering: Multiple go-sse-broker instances connected to the same Redis instance automatically form a cluster, enabling horizontal scaling and improved fault tolerance. This makes go-sse-broker an ideal solution for real-time applications that require reliable event delivery across distributed systems.

Usage

Windows

Linux

  • Download rpm from the release page.
  • Install rpm -Uvh sse-broker-1.0.1-1.el7.x86_64
  • Edit configuration: vim /etc/sse-broker/config.toml
  • Start the service: systemctl start sse-broker
  • Visit the API&Demo Page: http://127.0.0.1:8080/

Docker

docker build -t sse-broker:1.0.3 .

Edit config.toml

[jwt]
secret = "please_modify"

[redis]
addrs = ["please_modify_1:6379", "please_modify_2:6379"]
password = "please_modify"

Api

Create Token

  • EndPoint: /token

  • HTTP Method: GET/POST

  • Parameters:

    name type required desc
    uid string true unique user id
    device string false unique client device id
  • Request Example

    • Get
      /token?uid=1965
    • Post JSON
    {
      "uid": "1986",
      "device": "my computer 1"
    }
  • Response Example (code 1:success, others:failure)

    {
      "code": 1,            
      "msg": "success",
      "micro": 192,
      "result": "jwt token string"
    }

Send Message/Event

  • EndPoint: /send
  • HTTP Method: GET/POST
  • Parameters:
    name type required desc
    data string true message data
    event string false event name
    uid string false multiple uids separated by commas
    device string false multiple devices separated by commas
  • Request Example
    • Get
      /send?uid=1935&data=hello
    • Post Json
    {
     "device": "ax001,ax002",
     "event": "custom-event",
     "data": "hello"
    }
  • Response Example (code 1:success, others:failure)
    {
      "code": 1,         
      "msg": "success",
      "micro": 225,
      "result": 2       
    }

SSE Connection

  • EndPoint: /events
  • HTTP Method: Get
  • Parameters: Either use parameters in the header or in the query
    • HTTP Headers (Optional):
      name type required desc
      X-SSE-TOKEN string true token
      X-SSE-DEVICE string true device
      X-SSE-ID string false last event id
    • Query (Optional):
      name type required desc
      token string true token
      device string true device
      id string false id
  • JS Example (JS)
      const token = "jwt_token"
      const device = "my computer 1"
      const lastEventId = 1098
    
      // connect to sse-broker
      const eventSource = new EventSource('/events?token=' + token + '&device=' + device + '&id=' + lastEventId)
    
      // message
      eventSource.onmessage = function(event) {
          appendMessage('message', 'Message', event.data);
      };
    
      // event: 'custom-event'
      eventSource.addEventListener('custom-event', function(event) {
          appendMessage('event', 'Custom Event', event.data);
      });
    
      // close
      eventSource.onerror = function() {
          appendMessage('error', 'Error', 'Connection was closed');
          eventSource.close();
      };

Info/Status

  • EndPoint: /info
  • HTTP Method: GET/POST
  • Parameters:
    name type required desc
    uid string false one user id
    device string false one device
    address string false sse-broker instance address(ip:port)
  • Request Example
    • Get: Custer Info
      /info
    • Post: User Info
    {
     "uid": "sssxyd"
    }
  • Response Example (code 1:success, others:failure)
    {
      "code": 1,         
      "msg": "success",
      "micro": 225,
      "result": {
          "online": true,
          "uid": "sssxyd",
          "login_time": "2024-09-12 09:57:59",
          "last_touch_time": "2024-09-12 10:13:59",
          "devices": [
              {
                  "device_id": "c7ea097beaf447e97f41af1c4651983c",
                  "device_name": "xuyd",
                  "uid": "sssxyd",
                  "login_time": "2024-09-12 09:57:59",
                  "instance_address": "192.168.2.22:8080",
                  "device_address": "192.168.2.22:64321",
                  "last_touch_time": "2024-09-12 10:13:59",
                  "last_frame_id": 12
              }
          ]
      }      
    }

Kick Offline

  • EndPoint: /kick
  • HTTP Method: GET/POST
  • Parameters:
    name type required desc
    uid string false multiple uids separated by commas
    device string false multiple devices separated by commas
    data string false data part of system event: sys_kick_offline
  • Request Example
    • Get
      /kick?uid=1935,1936
    • Post Json
    {
     "device": "ax001,ax002",
     "uid": "1937",
    }
  • Response Example (code 1:success, others:failure)
    {
      "code": 1,         
      "msg": "success",
      "micro": 225,
      "result": 6       
    }

System Event

Event Name Data Trigger
sys_connected IP:Port of your client Client connected
sys_instance_close IP:Port of the instance your client was connected to SSE-broker instance stopped
sys_extrude_offline IP:Port of another client Another client with the same device connected
sys_kick_offline Parameter data of API kick API kick invoked

Callback

Please Subscribe Redis Channel

  • Redis Channels

    Redis Channel Trigger
    sse_topic_user_online uid first connected
    sse_topic_user_offline last device of uid disconnected
    sse_topic_device_online device connected
    sse_topic_device_offline device disconnected
  • Message JSON Structure (Go)

    type StateChange struct {
      UID         string `json:"uid"`
      Device      string `json:"device"`
      TriggerTime string `json:"trigger_time"`
      Reason      string `json:"reason"`
      Payload     string `json:"payload"`
    }
  • Reasons (Go)

    const DCR_EXTRUDE_OFFLINE = "extrude_offline"
    const DCR_KICK_OFFLINE = "kick_offline"
    const DCR_INSTANCE_CLOSE = "instance_close"
    const DCR_INSTANCE_CLEAR = "instance_clear"
    const DCR_HEARTBEAT_FAIL = "heartbeat_fail"
    const DCR_DEVICE_CONNECTED = "device_connected"
    const DCR_DEVICE_DISCONNECT = "device_disconnect"