go-xmpp/websocket_transport.go

70 lines
1.5 KiB
Go
Raw Normal View History

2019-10-06 11:15:26 -07:00
package xmpp
import (
"context"
"net"
"strings"
"time"
"nhooyr.io/websocket"
)
const pingTimeout = time.Duration(5) * time.Second
2019-10-06 11:15:26 -07:00
type WebsocketTransport struct {
Config TransportConfiguration
2019-10-06 11:15:26 -07:00
wsConn *websocket.Conn
netConn net.Conn
ctx context.Context
}
func (t *WebsocketTransport) Connect() error {
2019-10-06 11:15:26 -07:00
t.ctx = context.Background()
2019-10-12 08:50:00 -07:00
if t.Config.ConnectTimeout > 0 {
ctx, cancel := context.WithTimeout(t.ctx, time.Duration(t.Config.ConnectTimeout)*time.Second)
t.ctx = ctx
defer cancel()
}
2019-10-06 11:15:26 -07:00
2019-10-12 08:50:00 -07:00
wsConn, _, err := websocket.Dial(t.ctx, t.Config.Address, nil)
if err != nil {
return NewConnError(err, true)
2019-10-06 11:15:26 -07:00
}
t.wsConn = wsConn
t.netConn = websocket.NetConn(t.ctx, t.wsConn, websocket.MessageText)
return nil
2019-10-06 11:15:26 -07:00
}
2019-10-10 22:15:47 -07:00
func (t WebsocketTransport) StartTLS(domain string) error {
return TLSNotSupported
}
2019-10-06 11:15:26 -07:00
func (t WebsocketTransport) DoesStartTLS() bool {
return false
}
2019-10-10 22:15:47 -07:00
func (t WebsocketTransport) IsSecure() bool {
return strings.HasPrefix(t.Config.Address, "wss:")
}
func (t WebsocketTransport) Ping() error {
ctx, cancel := context.WithTimeout(context.Background(), pingTimeout)
defer cancel()
// Note that we do not use wsConn.Ping(), because not all websocket servers
// (ejabberd for example) implement ping frames
return t.wsConn.Write(ctx, websocket.MessageText, []byte(" "))
}
2019-10-06 11:15:26 -07:00
func (t WebsocketTransport) Read(p []byte) (n int, err error) {
return t.netConn.Read(p)
}
func (t WebsocketTransport) Write(p []byte) (n int, err error) {
return t.netConn.Write(p)
}
func (t WebsocketTransport) Close() error {
return t.netConn.Close()
}