koa sse(server side event) middleware , use stream programming model
npm install --save koa-sse-stream
const Koa = require('koa');
const compress = require('koa-compress');
const sse = require('koa-sse-stream');
const app = new Koa();
// !!attention : if you use compress, sse must use after compress
app.use(compress())
/**
* koa sse middleware
* @param {Object} opts
* @param {Number} opts.maxClients max client number, default is 10000
* @param {Number} opts.pingInterval heartbeat sending interval time(ms), default 60s
* @param {String} opts.closeEvent if not provide end([data]), send default close event to client, default event name is "close"
* @param {String} opts.matchQuery when set matchQuery, only has query (whatever the value) , sse will create
*/
app.use(sse({
maxClients: 5000,
pingInterval: 30000
}));
app.use(async (ctx) => {
// ctx.sse is a writable stream and has extra method 'send'
ctx.sse.send('a notice');
ctx.sse.sendEnd();
});
a writable stream
ctx.sse.send(data)
/**
* Event `close` Triggered when an SSE connection is closed, whether the server is actively closed or the client is closed
*/
/**
*
* @param {String} data sse data to �send, if it's a string, an anonymous event will be sent.
* @param {Object} data sse send object mode
* @param {Object|String} data.data data to send, if it's object, it will be converted to json
* @param {String} data.event sse event name
* @param {Number} data.id sse event id
* @param {Number} data.retry sse retry times
* @param {*} encoding not use
* @param {function} callback same as the write method callback
*/
send(data, encoding, callback)
ctx.sse.sendEnd(data)
/**
*
* @param {String} data sse data to �send, if it's a string, an anonymous event will be sent.
* @param {Object} data sse send object mode
* @param {Object|String} data.data data to send, if it's object, it will be converted to json
* @param {String} data.event sse event name
* @param {Number} data.id sse event id
* @param {Number} data.retry sse retry times
* @param {*} encoding not use
* @param {function} callback same as the write method callback
*/
sendEnd(data, encoding, callback)
if you use compress, sse must use after compress