Documentation ¶
Overview ¶
Content managed by Project Forge, see [projectforge.md] for details.
Content managed by Project Forge, see [projectforge.md] for details.
Content managed by Project Forge, see [projectforge.md] for details.
Content managed by Project Forge, see [projectforge.md] for details.
Content managed by Project Forge, see [projectforge.md] for details.
Content managed by Project Forge, see [projectforge.md] for details.
Content managed by Project Forge, see [projectforge.md] for details.
Index ¶
- func OnMessage(s *Service, connID uuid.UUID, message *Message) error
- type Channel
- type ConnectEvent
- type Connection
- type Handler
- type Message
- type OnlineUpdate
- type Service
- func (s *Service) ChannelList(params *filter.Params) []string
- func (s *Service) Close()
- func (s *Service) Count() int
- func (s *Service) Disconnect(connID uuid.UUID) (bool, error)
- func (s *Service) GetByID(id uuid.UUID) *Status
- func (s *Service) GetOnline(ch string) []uuid.UUID
- func (s *Service) Join(connID uuid.UUID, ch string) (bool, error)
- func (s *Service) Leave(connID uuid.UUID, ch string) (bool, error)
- func (s *Service) OnClose(connID uuid.UUID) error
- func (s *Service) OnOpen(connID uuid.UUID) error
- func (s *Service) ReadLoop(connID uuid.UUID, onDisconnect func(conn *Connection) error) error
- func (s *Service) Register(profile *user.Profile, c *websocket.Conn) (*Connection, error)
- func (s *Service) Status() ([]string, []*Connection, any)
- func (s *Service) UserList(params *filter.Params) Statuses
- func (s *Service) Write(connID uuid.UUID, message string) error
- func (s *Service) WriteChannel(message *Message, except ...uuid.UUID) error
- func (s *Service) WriteMessage(connID uuid.UUID, message *Message) error
- type Status
- type Statuses
- type UpdateMemberParams
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
Types ¶
type ConnectEvent ¶
type ConnectEvent func(s *Service, conn *Connection) error
Function used to handle incoming connections.
type Connection ¶
type Connection struct { ID uuid.UUID `json:"id"` Profile *user.Profile `json:"profile,omitempty"` Accounts user.Accounts `json:"accounts,omitempty"` Svc string `json:"svc,omitempty"` ModelID *uuid.UUID `json:"modelID,omitempty"` Channels []string `json:"channels,omitempty"` // contains filtered or unexported fields }
Represents a user's WebSocket session.
func NewConnection ¶
func NewConnection(svc string, profile *user.Profile, accounts user.Accounts, socket *websocket.Conn) *Connection
Creates a new Connection.
func (*Connection) Read ¶
func (c *Connection) Read() ([]byte, error)
Reads bytes from this Connection, you should probably use a helper method.
func (*Connection) ToStatus ¶
func (c *Connection) ToStatus() *Status
Transforms this Connection to a serializable Status object.
func (*Connection) Write ¶
func (c *Connection) Write(b []byte) error
Writes bytes to this Connection, you should probably use a helper method.
type Handler ¶
type Handler func(s *Service, conn *Connection, svc string, cmd string, param json.RawMessage) error
Function used to handle incoming messages.
type Message ¶
type Message struct { From *uuid.UUID `json:"from,omitempty"` Channel string `json:"channel,omitempty"` Cmd string `json:"cmd"` Param json.RawMessage `json:"param"` }
Common message struct for passing a service, command and parameter.
func NewMessage ¶
Constructor.
type OnlineUpdate ¶
Message for updates of a user's online status.
type Service ¶
Manages all Connection objects.
func NewService ¶
func NewService(logger util.Logger, onOpen ConnectEvent, handler Handler, onClose ConnectEvent, ctx any) *Service
Creates a new service with the provided handler functions.
func (*Service) ChannelList ¶
Returns an array of channels based on the parameters.
func (*Service) Disconnect ¶
Removes a Connection from this Service.
func (*Service) ReadLoop ¶
Enter an loop that reads Message objects from the Connection matching the provided ID.
func (*Service) Register ¶
Registers a new Connection for this Service using the provided fevouser.Profile and websocket.Conn.
func (*Service) WriteChannel ¶
Write a Message to the provided Channel.
type Status ¶
type Status struct { ID uuid.UUID `json:"id"` Username string `json:"username"` Channels []string `json:"channels"` }
Serializable representation of a Connection.