mirror of https://github.com/msgbyte/tailchat
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
85 lines
1.8 KiB
TypeScript
85 lines
1.8 KiB
TypeScript
import { io, Socket } from 'socket.io-client';
|
|
import _isNil from 'lodash/isNil';
|
|
import { getServiceUrl } from '../manager/service';
|
|
import { isDevelopment } from '../utils/environment';
|
|
|
|
let socket: Socket;
|
|
|
|
class SocketEventError extends Error {
|
|
name = 'SocketEventError';
|
|
}
|
|
|
|
type SocketEventRespones<T = unknown> =
|
|
| {
|
|
result: true;
|
|
data: T;
|
|
}
|
|
| {
|
|
result: false;
|
|
message: string;
|
|
};
|
|
|
|
/**
|
|
* 封装后的 Socket
|
|
*/
|
|
export class AppSocket {
|
|
constructor(private socket: Socket) {}
|
|
|
|
get connected(): boolean {
|
|
return socket.connected;
|
|
}
|
|
|
|
async request<T = unknown>(
|
|
eventName: string,
|
|
eventData: unknown = {}
|
|
): Promise<T> {
|
|
return new Promise((resolve, reject) => {
|
|
this.socket.emit(eventName, eventData, (resp: SocketEventRespones<T>) => {
|
|
if (resp.result === true) {
|
|
resolve(resp.data);
|
|
} else if (resp.result === false) {
|
|
reject(new SocketEventError(resp.message));
|
|
}
|
|
});
|
|
});
|
|
}
|
|
|
|
listen(eventName: string, callback: (data: unknown) => void) {
|
|
this.socket.on(`notify:${eventName}`, callback);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 创建Socket连接
|
|
* 如果已经有Socket连接则关闭上一个
|
|
* @param token Token
|
|
*/
|
|
export function createSocket(token: string): Promise<AppSocket> {
|
|
if (!_isNil(socket)) {
|
|
socket.close();
|
|
}
|
|
|
|
return new Promise((resolve, reject) => {
|
|
socket = io(getServiceUrl(), {
|
|
transports: ['websocket'],
|
|
auth: {
|
|
token,
|
|
},
|
|
forceNew: true,
|
|
});
|
|
socket.once('connect', () => {
|
|
// 连接成功
|
|
resolve(new AppSocket(socket));
|
|
});
|
|
socket.once('error', () => {
|
|
reject();
|
|
});
|
|
|
|
if (isDevelopment) {
|
|
socket.onAny((...args) => {
|
|
console.log('Receive Notify:', args);
|
|
});
|
|
}
|
|
});
|
|
}
|