abstract struct Lattice::ClientSocket

Overview

ClientSocket struct maps a user to an HTTP::WebSocket. For every websocket connection there will be an associated ClientSocket. Authentication and authorization happen within the ClientSocket. ClientSocket will subscribe to Channels, where incoming and outgoing messages are routed through.

struct UserSocket < Lattice::ClientSocket
  channel "user_channel:*", UserChannel
  channel "room_channel:*", RoomChannel

  def on_connect
    return some_auth_method!
  end
end

Defined in:

lattice/client_socket.cr

Constant Summary

BEAT_INTERVAL = 30.seconds
MAX_SOCKET_IDLE_TIME = 100.seconds

Constructors

Class Method Summary

Instance Method Summary

Constructor Detail

def self.new(socket : HTTP::WebSocket, context : HTTP::Server::Context) #

[View source]

Class Method Detail

def self.broadcast(event : String, topic : String, subject : String, payload : Hash) #

Broadcast a message to all subscribers of the topic

UserSocket.broadcast("message", "chats_room:1", "msg:new", {"message" => "test"})

[View source]
def self.channel(channel_path, channel) #

Add a channel for this socket to listen, publish to


[View source]
def self.channels #

[View source]
def self.get_topic_channel(topic_path) #

[View source]

Instance Method Detail

def on_connect : Bool #

Authentication and authorization can happen here


[View source]
def on_disconnect #

On socket disconnect functionality


[View source]
def on_error : Proc(String, Nil) | Nil #

[View source]
def on_error(&block) #

[View source]
def on_error=(on_error : Proc(String, Nil) | Nil) #

[View source]
def on_uncaptured_event(*args, **options) #

[View source]
def on_uncaptured_event(*args, **options, &) #

[View source]
def socket : HTTP::WebSocket #

[View source]