mirror of
https://github.com/42wim/matterbridge.git
synced 2025-01-17 23:22:44 +01:00
4dd8bae5c9
* Update dependencies * Update module to go 1.17
129 lines
3.0 KiB
Go
129 lines
3.0 KiB
Go
package ddp
|
|
|
|
import (
|
|
"crypto/sha256"
|
|
"encoding/hex"
|
|
"io"
|
|
)
|
|
|
|
// ------------------------------------------------------------
|
|
// DDP Messages
|
|
//
|
|
// Go structs representing common DDP raw messages ready for JSON
|
|
// encoding.
|
|
// ------------------------------------------------------------
|
|
|
|
// Message contains the common fields that all DDP messages use.
|
|
type Message struct {
|
|
Type string `json:"msg"`
|
|
ID string `json:"id,omitempty"`
|
|
}
|
|
|
|
// Connect represents a DDP connect message.
|
|
type Connect struct {
|
|
Message
|
|
Version string `json:"version"`
|
|
Support []string `json:"support"`
|
|
Session string `json:"session,omitempty"`
|
|
}
|
|
|
|
// NewConnect creates a new connect message
|
|
func NewConnect() *Connect {
|
|
return &Connect{Message: Message{Type: "connect"}, Version: "1", Support: []string{"1"}}
|
|
}
|
|
|
|
// NewReconnect creates a new connect message with a session ID to resume.
|
|
func NewReconnect(session string) *Connect {
|
|
c := NewConnect()
|
|
c.Session = session
|
|
return c
|
|
}
|
|
|
|
// Ping represents a DDP ping message.
|
|
type Ping Message
|
|
|
|
// NewPing creates a new ping message with optional ID.
|
|
func NewPing(id string) *Ping {
|
|
return &Ping{Type: "ping", ID: id}
|
|
}
|
|
|
|
// Pong represents a DDP pong message.
|
|
type Pong Message
|
|
|
|
// NewPong creates a new pong message with optional ID.
|
|
func NewPong(id string) *Pong {
|
|
return &Pong{Type: "pong", ID: id}
|
|
}
|
|
|
|
// Method is used to send a remote procedure call to the server.
|
|
type Method struct {
|
|
Message
|
|
ServiceMethod string `json:"method"`
|
|
Args []interface{} `json:"params"`
|
|
}
|
|
|
|
// NewMethod creates a new method invocation object.
|
|
func NewMethod(id, serviceMethod string, args []interface{}) *Method {
|
|
return &Method{
|
|
Message: Message{Type: "method", ID: id},
|
|
ServiceMethod: serviceMethod,
|
|
Args: args,
|
|
}
|
|
}
|
|
|
|
// Sub is used to send a subscription request to the server.
|
|
type Sub struct {
|
|
Message
|
|
SubName string `json:"name"`
|
|
Args []interface{} `json:"params"`
|
|
}
|
|
|
|
// NewSub creates a new sub object.
|
|
func NewSub(id, subName string, args []interface{}) *Sub {
|
|
return &Sub{
|
|
Message: Message{Type: "sub", ID: id},
|
|
SubName: subName,
|
|
Args: args,
|
|
}
|
|
}
|
|
|
|
|
|
// Login provides a Meteor.Accounts password login support
|
|
type Login struct {
|
|
User *User `json:"user"`
|
|
Password *Password `json:"password"`
|
|
}
|
|
|
|
func NewEmailLogin(email, pass string) *Login {
|
|
return &Login{User: &User{Email: email}, Password: NewPassword(pass)}
|
|
}
|
|
|
|
func NewUsernameLogin(user, pass string) *Login {
|
|
return &Login{User: &User{Username: user}, Password: NewPassword(pass)}
|
|
}
|
|
|
|
type LoginResume struct {
|
|
Token string `json:"resume"`
|
|
}
|
|
|
|
func NewLoginResume(token string) *LoginResume {
|
|
return &LoginResume{Token: token}
|
|
}
|
|
|
|
type User struct {
|
|
Email string `json:"email,omitempty"`
|
|
Username string `json:"username,omitempty"`
|
|
}
|
|
|
|
type Password struct {
|
|
Digest string `json:"digest"`
|
|
Algorithm string `json:"algorithm"`
|
|
}
|
|
|
|
func NewPassword(pass string) *Password {
|
|
sha := sha256.New()
|
|
io.WriteString(sha, pass)
|
|
digest := sha.Sum(nil)
|
|
return &Password{Digest: hex.EncodeToString(digest), Algorithm: "sha-256"}
|
|
}
|