Files
doneit-web/src/app/services/chat/ws-chat.service.ts
T

707 lines
16 KiB
TypeScript
Raw Normal View History

2022-01-07 09:03:15 +01:00
import { Injectable } from '@angular/core';
2022-01-07 11:21:14 +01:00
import { v4 as uuidv4 } from 'uuid'
2022-01-12 22:07:55 +01:00
import { wsCallbacksParams, msgQueue, send } from 'src/app/models/rochet-chat-cliente-service'
2022-01-10 22:04:04 +01:00
import { deepFind } from 'src/plugin/deep'
2022-01-12 11:52:05 +01:00
import { environment } from 'src/environments/environment';
2022-01-12 13:47:17 +01:00
import { SessionStore } from 'src/app/store/session.service';
2022-01-13 12:52:05 +01:00
import { chatHistory, Rooms } from 'src/app/models/chatMethod';
2022-01-12 13:47:17 +01:00
2022-01-12 12:44:51 +01:00
@Injectable({
2022-01-10 17:52:49 +01:00
providedIn: 'root'
})
2022-01-12 12:44:51 +01:00
export class WsChatService {
2022-01-10 09:35:17 +01:00
isLogin = false;
2022-01-14 09:12:27 +01:00
loginResponse = {}
2022-01-11 12:32:46 +01:00
2022-01-07 15:48:35 +01:00
constructor() {}
2022-01-07 14:29:41 +01:00
2022-01-12 13:47:17 +01:00
connect() {
2022-01-14 09:20:54 +01:00
// dont connect if is already connected
2022-01-17 14:39:12 +01:00
if(this.ws.connected == true) {
return false
2022-01-14 09:33:01 +01:00
}
2022-01-17 14:39:12 +01:00
2022-01-12 13:47:17 +01:00
this.ws.connect();
2022-01-07 11:21:14 +01:00
2022-01-12 22:07:55 +01:00
const message = {
2022-01-07 11:21:14 +01:00
msg: "connect",
version: "1",
support: ["1"]
}
2022-01-07 15:48:35 +01:00
2022-02-02 20:16:12 +01:00
this.ws.send({message, loginRequired: false, requestId: 'connectMessage'})
this.ws.send({message:{msg:"pong"}, loginRequired: false, requestId: 'connectPong'})
2022-01-12 20:21:44 +01:00
this.ws.registerCallback({
type:'Onmessage',
funx:(message: any) => {
if(message.msg == "ping") {
2022-01-12 22:07:55 +01:00
this.ws.send({message:{msg:"pong"}, loginRequired: false})
2022-01-12 20:21:44 +01:00
}
2022-01-12 21:43:53 +01:00
}
})
2022-01-12 20:21:44 +01:00
2022-01-07 09:03:15 +01:00
}
2022-01-12 13:47:17 +01:00
login() {
2022-01-14 09:20:54 +01:00
// dont login if is already login
2022-01-17 14:39:12 +01:00
if(this.isLogin == true) {
return new Promise((resolve, reject)=>{
resolve(this.loginResponse)
})
2022-01-14 09:33:01 +01:00
}
2022-01-17 14:39:12 +01:00
2022-01-07 14:29:41 +01:00
const requestId = uuidv4()
2022-01-12 22:07:55 +01:00
const message = {
2022-01-07 09:03:15 +01:00
msg: "method",
method: "login",
2022-01-07 14:29:41 +01:00
id: requestId,
2022-01-07 09:03:15 +01:00
params: [
{
2022-01-12 13:47:17 +01:00
user: { username: SessionStore.user.RochetChatUser },
password: SessionStore.user.Password
2022-01-07 09:03:15 +01:00
}
]
}
2022-02-02 20:16:12 +01:00
this.ws.send({message, requestId: 'login', loginRequired: false})
2022-01-17 14:39:12 +01:00
2022-01-07 14:29:41 +01:00
2022-01-10 10:53:04 +01:00
return new Promise((resolve, reject) => {
2022-01-13 07:29:28 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-12 11:52:05 +01:00
if(message.id == requestId ) { // same request send
2022-01-13 17:08:25 +01:00
if(message.result) {
if(message.result.token) {
2022-01-17 14:39:12 +01:00
2022-01-13 17:08:25 +01:00
this.isLogin = true
2022-01-14 09:12:27 +01:00
this.loginResponse = message
2022-01-12 11:52:05 +01:00
2022-01-13 17:08:25 +01:00
this.ws.wsMsgQueue()
2022-01-13 17:08:25 +01:00
resolve(message)
}
2022-01-10 10:53:04 +01:00
} else {
2022-01-10 10:54:51 +01:00
this.isLogin = false
2022-01-10 10:53:04 +01:00
reject(message)
}
2022-01-10 22:04:04 +01:00
reject(message)
return true
2022-01-10 10:53:04 +01:00
}
}})
});
2022-01-07 09:03:15 +01:00
}
2022-01-12 11:52:05 +01:00
getRooms(roomOlder = 1480377601) {
2022-01-10 22:35:44 +01:00
const requestId = uuidv4()
2022-01-10 22:04:04 +01:00
2022-01-12 22:07:55 +01:00
const message = {
2022-01-10 22:04:04 +01:00
"msg": "method",
"method": "rooms/get",
"id": requestId,
"params": [ { "$date": 1480377601 } ]
}
2022-01-12 22:10:42 +01:00
this.ws.send({message, requestId})
2022-01-10 22:04:04 +01:00
2022-01-13 12:52:05 +01:00
return new Promise<Rooms>((resolve, reject) => {
2022-01-12 21:42:45 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-10 22:04:04 +01:00
if(message.id == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-02-02 11:57:11 +01:00
getUserOfRoom(roomId) {
const requestId = uuidv4()
const message = {
"msg": "method",
"method": "getUsersOfRoom",
"id": requestId,
"params": [
roomId,
false,
{
"limit": 100,
"skip": 0
} ]
}
this.ws.send({message, requestId})
return new Promise<Rooms>((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-01-13 12:52:05 +01:00
logout() {
this.isLogin = false
this.ws.connected = false
}
2022-01-17 14:39:12 +01:00
2022-01-13 07:57:50 +01:00
// send message to room
2022-01-12 22:07:55 +01:00
send(roomId, msg) {
2022-01-07 09:03:15 +01:00
2022-01-07 14:29:41 +01:00
const requestId = uuidv4()
2022-01-12 22:07:55 +01:00
var message = {
2022-01-07 14:29:41 +01:00
msg: "method",
method: "sendMessage",
id: requestId,
params: [{
2022-01-10 11:40:34 +01:00
_id: uuidv4(),
rid: roomId,
2022-01-12 22:07:55 +01:00
msg: msg
2022-01-07 11:21:14 +01:00
}]
2022-01-07 14:29:41 +01:00
}
2022-01-12 22:10:42 +01:00
this.ws.send({message, requestId});
2022-01-07 11:21:14 +01:00
2022-01-10 11:40:34 +01:00
return new Promise((resolve, reject) => {
2022-01-13 07:29:28 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-10 22:04:04 +01:00
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
2022-01-10 11:40:34 +01:00
resolve(message)
2022-01-10 22:04:04 +01:00
return true
2022-01-10 11:40:34 +01:00
}
}})
});
2022-01-07 11:21:14 +01:00
}
2022-01-07 09:03:15 +01:00
2022-01-26 09:19:54 +01:00
leaveRoom(roomId) {
const requestId = uuidv4()
var message = {
msg: "method",
method: "leaveRoom",
id: requestId,
params: [
roomId,
]
}
this.ws.send({message, requestId});
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
addRoomOwner(roomId, userId) {
const requestId = uuidv4()
var message = {
msg: "method",
method: "addRoomOwner",
id: requestId,
params: [
roomId,
userId
]
}
this.ws.send({message, requestId});
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-01-29 19:21:46 +01:00
hidingRoom(roomId) {
2022-01-26 09:19:54 +01:00
const requestId = uuidv4()
var message = {
msg: "method",
method: "hideRoom",
id: requestId,
params: [roomId]
}
this.ws.send({message, requestId});
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-01-07 09:03:15 +01:00
joinRoom(){}
2022-01-28 15:31:52 +01:00
deleteMessage(msgId) {
const requestId = uuidv4();
var message = {
msg: "method",
method: "deleteMessage",
id: requestId,
params:[{"_id":msgId}]
}
this.ws.send({message, requestId});
return new Promise ((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message) =>{
if(message.id == requestId || deepFind(message, 'result') == requestId){
resolve(message)
return true
}
}})
});
}
2022-01-26 16:37:59 +01:00
createPrivateRoom(groupName, username, customFields) {
const requestId = uuidv4()
var message = {
msg: "method",
method: "createPrivateGroup",
id: requestId,
params: [
groupName,
[username],
false,
customFields,
{
"broadcast":false,
"encrypted":false
}
]
}
this.ws.send({message, requestId});
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-01-07 14:29:41 +01:00
2022-01-28 16:15:20 +01:00
sendStreamNotifyRoom(roomId : string, username, event: 'typing', param: any) {
2022-01-10 12:23:01 +01:00
2022-01-28 16:15:20 +01:00
const requestId = uuidv4()
let message = {
msg: "method",
method: "stream-notify-room",
id: requestId,
params: [
`${roomId}/${event}`,
username,
param
]
};
this.ws.send({message, requestId})
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
2022-01-29 17:06:25 +01:00
resolve(message)
2022-01-28 16:15:20 +01:00
return true
}
}})
});
}
subStreamNotifyRoom(roomId : string , event: 'typing' | 'deleteMessage', param: any) {
const requestId = uuidv4()
2022-01-10 08:34:30 +01:00
2022-01-28 16:15:20 +01:00
let message = {
msg: "sub",
id: requestId,
name: "stream-notify-room",
params:[
`${roomId}/${event}`,
param
]
}
this.ws.send({message, requestId})
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId ) { // same request send
2022-01-29 17:06:25 +01:00
resolve(message)
2022-01-28 16:15:20 +01:00
return true
}
}})
});
}
receiveStreamNotifyRoom(funx: Function) {
this.ws.registerCallback({
type:'Onmessage',
funx:(message)=> {
if(message.collection == "stream-notify-room" && message.msg == 'changed') {
funx(message)
}
}})
}
2022-01-28 19:09:37 +01:00
2022-01-29 19:21:46 +01:00
getUserStatus(funx:Function){
this.ws.registerCallback({
type:'Onmessage',
funx:(message)=>{
if(message.msg == 'changed' && message.collection == "stream-notify-logged") {
funx(message)
}
}
})
}
2022-02-02 11:57:11 +01:00
2022-01-29 19:21:46 +01:00
2022-01-10 17:52:49 +01:00
loadHistory(roomId, limit: number = 50) {
2022-01-10 10:22:17 +01:00
const requestId = uuidv4()
2022-01-10 08:34:30 +01:00
2022-01-12 22:07:55 +01:00
const message = {
2022-01-10 17:52:49 +01:00
msg: "method",
method: "loadHistory",
id: requestId,
params: [
roomId,
null,
limit,
{
"$date": 1480377601
}
2022-01-10 17:52:49 +01:00
]
2022-01-10 10:22:17 +01:00
}
2022-01-10 17:52:49 +01:00
2022-01-31 15:01:41 +01:00
this.ws.send({message, requestId: 'loadHistory'})
2022-01-10 11:11:27 +01:00
2022-01-13 12:52:05 +01:00
return new Promise<chatHistory>((resolve, reject) => {
2022-01-12 21:42:45 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-10 22:35:44 +01:00
// console.log(message)
if(message.id == requestId ) { // same request send
2022-01-10 11:11:27 +01:00
resolve(message)
2022-01-10 22:04:04 +01:00
return true
2022-01-10 11:11:27 +01:00
}
}})
});
2022-01-10 08:34:30 +01:00
}
2022-01-13 14:51:44 +01:00
setStatus(status: 'online' | 'busy' | 'away' | 'offline') {
2022-01-17 14:39:12 +01:00
2022-01-13 11:24:14 +01:00
const requestId = uuidv4()
const message = {
2022-01-17 14:39:12 +01:00
2022-01-13 11:24:14 +01:00
msg: "method",
method: `UserPresence:setDefaultStatus`,
id: requestId,
params: [ status ]
2022-01-17 14:39:12 +01:00
2022-01-13 11:24:14 +01:00
}
this.ws.send({message, requestId})
}
2022-01-12 12:44:51 +01:00
subscribeNotifyRoom(roomId : string) {
2022-01-10 08:34:30 +01:00
2022-01-10 11:11:27 +01:00
const requestId = uuidv4()
2022-01-12 22:07:55 +01:00
var message = {
2022-01-07 14:29:41 +01:00
"msg": "sub",
2022-01-10 11:11:27 +01:00
"id": requestId,
2022-01-07 14:29:41 +01:00
"name": "stream-notify-room",
"params":[
2022-01-10 11:29:02 +01:00
`${roomId}/event`,
2022-01-07 14:29:41 +01:00
false
]
}
2022-01-12 22:10:42 +01:00
this.ws.send({message, requestId});
2022-01-11 12:32:46 +01:00
2022-01-10 11:11:27 +01:00
return new Promise((resolve, reject) => {
2022-01-12 21:42:45 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-10 22:04:04 +01:00
if(message.msg == 'ready' || deepFind(message, 'subs.0') == requestId) { // same request send
2022-01-10 11:11:27 +01:00
resolve(message)
2022-01-10 22:04:04 +01:00
return true
2022-01-10 11:11:27 +01:00
}
}})
});
2022-01-07 14:29:41 +01:00
}
2022-01-28 17:33:26 +01:00
updateRoomEventss(roomId, collection:string, funx: Function, ) {
2022-01-14 11:47:55 +01:00
this.ws.registerCallback({
type:'Onmessage',
funx:(message)=>{
2022-01-28 15:31:52 +01:00
//console.log(message);
if(message.msg =='changed' && message.collection == collection) {
2022-01-14 11:47:55 +01:00
if(message.fields.args[0].rid == roomId) {
funx(message)
}
2022-01-28 15:31:52 +01:00
else if(message.fields.eventName ==`${roomId}/deleteMessage`){
funx(message)
}
2022-01-14 11:47:55 +01:00
}
}
})
}
2022-01-10 15:56:11 +01:00
streamRoomMessages(roomId : string) {
const requestId = uuidv4()
2022-01-12 22:07:55 +01:00
const message = {
2022-01-10 15:56:11 +01:00
"msg": "sub",
"id": requestId,
"name": "stream-room-messages",
"params":[
2022-01-14 11:47:55 +01:00
`${roomId}`,
2022-01-10 15:56:11 +01:00
false
]
}
2022-01-10 15:56:11 +01:00
2022-01-12 22:10:42 +01:00
this.ws.send({message, requestId});
2022-01-10 15:56:11 +01:00
return new Promise((resolve, reject) => {
2022-01-12 21:42:45 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-14 11:47:55 +01:00
if(message.id == requestId) { // same request send
2022-01-10 15:56:11 +01:00
resolve(message)
2022-01-10 22:04:04 +01:00
return true
2022-01-10 15:56:11 +01:00
}
}})
});
}
2022-01-17 14:39:12 +01:00
streamNotifyLogged() {
const requestId = uuidv4()
const message = {
"msg": "sub",
"id": requestId,
"name": "stream-notify-logged",
"params":[
"user-status",
false
]
}
this.ws.send({message, requestId});
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-01-10 12:59:25 +01:00
streamNotifyRoom(roomId : string) {
2022-01-10 12:59:25 +01:00
const requestId = uuidv4()
2022-01-12 22:07:55 +01:00
let message = {
2022-01-10 12:59:25 +01:00
"msg": "method",
"method": "stream-notify-room",
2022-01-10 12:59:25 +01:00
"id": requestId,
"params": [
`null/typing`,
"paulo.pinto",
true
]
};
2022-01-12 22:10:42 +01:00
this.ws.send({message, requestId})
2022-01-10 12:59:25 +01:00
return new Promise((resolve, reject) => {
2022-01-12 21:42:45 +01:00
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
2022-01-10 22:04:04 +01:00
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
2022-01-29 17:06:25 +01:00
resolve(message)
2022-01-10 22:04:04 +01:00
return true
2022-01-10 12:59:25 +01:00
}
}})
});
2022-01-07 14:29:41 +01:00
}
2022-01-11 12:32:46 +01:00
2022-01-28 15:31:52 +01:00
streamNotifyRoomDeleteMessage(roomId:string) {
const requestId = uuidv4()
let message = {
"msg": "sub",
"id": requestId,
"name": "stream-notify-room",
"params": [
`${roomId}/deleteMessage`,
true
]
};
this.ws.send({message, requestId})
return new Promise((resolve, reject) => {
this.ws.registerCallback({type:'Onmessage', funx:(message)=>{
if(message.id == requestId || deepFind(message,'result.id') == requestId) { // same request send
resolve(message)
return true
}
}})
});
}
2022-01-12 11:52:05 +01:00
registerCallback(data:wsCallbacksParams) {
return this.ws.registerCallback(data)
}
2022-01-07 16:34:02 +01:00
// socket class ==================================================================
2022-01-17 14:39:12 +01:00
private socket!: WebSocket;
2022-01-12 20:21:44 +01:00
private wsMsgQueue : {[key: string]: msgQueue} = {}
2022-01-10 09:35:17 +01:00
private wsCallbacks: {[key: string]: wsCallbacksParams} = {}
2022-01-31 14:44:22 +01:00
private wsReconnect = 0
2022-01-07 15:48:35 +01:00
2022-01-10 10:22:17 +01:00
private ws = {
2022-01-10 09:35:17 +01:00
connected: false,
2022-01-10 17:52:49 +01:00
registerCallback:(params: wsCallbacksParams) => {
2022-01-11 12:32:46 +01:00
2022-01-12 21:31:10 +01:00
let id = params.requestId || params.key || uuidv4()
2022-01-12 21:46:08 +01:00
this.wsCallbacks[id] = params
2022-01-10 09:35:17 +01:00
2022-01-12 21:30:32 +01:00
return id
2022-01-07 15:48:35 +01:00
},
2022-01-12 13:47:17 +01:00
connect:()=> {
this.socket = new WebSocket(environment.apiWsChatUrl);
2022-01-07 15:48:35 +01:00
// bind function
this.socket.onopen = this.ws.onopen;
this.socket.onmessage = this.ws.onmessage;
this.socket.onclose = this.ws.onclose;
this.socket.onerror = this.ws.onerror;
},
onopen:()=> {
2022-01-10 09:35:17 +01:00
this.ws.connected = true
2022-02-02 11:57:11 +01:00
2022-01-07 15:48:35 +01:00
console.log('================== welcome to socket server =====================')
2022-01-10 18:52:21 +01:00
this.ws.wsMsgQueue()
2022-01-31 14:44:22 +01:00
if(this.wsReconnect >= 1) {
for (const [key, value] of Object.entries(this.wsCallbacks)) {
if(value.type== 'reConnect') {
const dontRepeat = value.funx()
2022-02-02 11:57:11 +01:00
2022-01-31 14:44:22 +01:00
if(dontRepeat) {
delete this.wsCallbacks[key]
}
2022-02-02 11:57:11 +01:00
2022-01-31 14:44:22 +01:00
}
2022-02-02 11:57:11 +01:00
2022-01-31 14:44:22 +01:00
}
}
this.wsReconnect++;
2022-01-10 18:52:21 +01:00
},
wsMsgQueue:()=> {
2022-01-12 16:10:59 +01:00
2022-01-12 20:21:44 +01:00
for (const [key, item] of Object.entries(this.wsMsgQueue)) {
2022-01-17 14:39:12 +01:00
2022-01-10 22:35:44 +01:00
if(item.loginRequired == true && this.isLogin == true) {
2022-01-29 20:34:36 +01:00
console.log('run msgQueue ', key)
2022-01-12 22:07:55 +01:00
this.ws.send(item);
2022-01-12 20:21:44 +01:00
delete this.wsMsgQueue[key]
2022-01-10 22:04:04 +01:00
} else if(item.loginRequired == false) {
2022-01-29 20:34:36 +01:00
console.log('run msgQueue ', key)
2022-01-12 22:07:55 +01:00
this.ws.send(item);
2022-01-12 20:21:44 +01:00
delete this.wsMsgQueue[key]
2022-01-10 22:04:04 +01:00
}
2022-01-12 20:21:44 +01:00
}
2022-01-07 15:48:35 +01:00
},
2022-01-12 22:10:42 +01:00
send: ({message, requestId = uuidv4(), loginRequired = true}:send) => {
2022-01-11 12:32:46 +01:00
2022-01-10 22:04:04 +01:00
if (this.ws.connected == false || loginRequired == true && this.isLogin == false) { // save data to send when back online
2022-01-12 16:17:40 +01:00
// console.log('save msgQueue this.ws.connected == false || loginRequired == true && this.isLogin == false',this.ws.connected, loginRequired, this.isLogin)
2022-02-02 20:16:12 +01:00
console.log('save msgQueue', requestId, message)
2022-01-29 20:34:36 +01:00
2022-01-12 20:21:44 +01:00
this.wsMsgQueue[requestId] = {message, requestId, loginRequired}
2022-01-07 15:48:35 +01:00
} else {
let messageStr = JSON.stringify(message)
this.socket.send(messageStr)
}
return requestId
},
2022-01-11 12:32:46 +01:00
2022-01-07 15:48:35 +01:00
onmessage:(event: any)=> {
const data = JSON.parse(event.data)
2022-01-11 12:32:46 +01:00
2022-01-10 09:35:17 +01:00
for (const [key, value] of Object.entries(this.wsCallbacks)) {
if(value.type== 'Onmessage') {
2022-01-10 22:04:04 +01:00
const dontRepeat = value.funx(data)
2022-01-10 22:04:04 +01:00
if(dontRepeat) {
delete this.wsCallbacks[key]
2022-01-11 12:32:46 +01:00
}
2022-01-10 10:53:04 +01:00
2022-01-10 22:04:04 +01:00
}
2022-01-10 10:53:04 +01:00
2022-01-10 09:35:17 +01:00
}
2022-01-07 15:48:35 +01:00
},
2022-01-11 12:32:46 +01:00
2022-01-07 15:48:35 +01:00
onclose:(event: any)=> {
2022-01-12 16:10:59 +01:00
this.ws.connected = false
this.isLogin = false
2022-01-17 14:39:12 +01:00
2022-01-12 13:47:17 +01:00
this.connect()
this.login()
2022-01-10 08:34:30 +01:00
2022-01-07 15:48:35 +01:00
console.log(`[close] Connection closed cleanly, code=${event.code} reason=${event.reason}`);
},
2022-01-11 12:32:46 +01:00
2022-01-07 15:48:35 +01:00
onerror: (event: any) => {
console.log(`[error] ${event.message}`);
}
2022-01-12 12:44:51 +01:00
}}