ABT Node WebSocket
ABT Node PubSub base on Websocket and Phoenix Protocol
Usage
- WsServer
const { WsServer } = require('@arcblock/ws');
const wsServer = new WsServer({
httpServer: http.createServer(),
authenticate: (req, cb) => {
const { searchParams } = new URL(req.url, `http://${req.headers.host || 'unknown'}`);
const token = searchParams.get('token');
if (!token) {
cb(new Error('token not found'), null);
return;
}
const authInfo = validateToken(token);
cb(null, authInfo);
cb(new Error('validate fail'), null);
},
});
wsSerer.attach();
wsServer.push('blocklet.installed', data);
wsServer.push('notification.create', data);
- WsClient
WsClient is inherited from Phoenix(source),
import WsClient from '@arcblock/ws/lib/client';
const socket = new WsClient(`//${window.location.hostname}`, {
params: () => ({
token: window.localStorage.getItem('abt_node_login_token'),
}),
logger: (type, msg, data) => console.log(type, msg, data),
});
socket.connect();
socket.on('blocklet.installed', callback1);
socket.on('notification.create', callback2);
socket.off('blocklet.installed', callback1);
socket.off('notification.create', callback2);
socket.disconnect(() => {
});
- Hooks
It's very simple to create hooks in react apps.