|
|
@ -212,11 +212,21 @@ app.get('/api/v1/streaming/public', (req, res) => { |
|
|
|
streamFrom(redisClient, 'timeline:public', req, streamToHttp(req, res, redisClient), true) |
|
|
|
streamFrom(redisClient, 'timeline:public', req, streamToHttp(req, res, redisClient), true) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
app.get('/api/v1/streaming/public/local', (req, res) => { |
|
|
|
|
|
|
|
const redisClient = getRedisClient() |
|
|
|
|
|
|
|
streamFrom(redisClient, 'timeline:public:local', req, streamToHttp(req, res, redisClient), true) |
|
|
|
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
app.get('/api/v1/streaming/hashtag', (req, res) => { |
|
|
|
app.get('/api/v1/streaming/hashtag', (req, res) => { |
|
|
|
const redisClient = getRedisClient() |
|
|
|
const redisClient = getRedisClient() |
|
|
|
streamFrom(redisClient, `timeline:hashtag:${req.params.tag}`, req, streamToHttp(req, res, redisClient), true) |
|
|
|
streamFrom(redisClient, `timeline:hashtag:${req.params.tag}`, req, streamToHttp(req, res, redisClient), true) |
|
|
|
}) |
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
app.get('/api/v1/streaming/hashtag/local', (req, res) => { |
|
|
|
|
|
|
|
const redisClient = getRedisClient() |
|
|
|
|
|
|
|
streamFrom(redisClient, `timeline:hashtag:${req.params.tag}:local`, req, streamToHttp(req, res, redisClient), true) |
|
|
|
|
|
|
|
}) |
|
|
|
|
|
|
|
|
|
|
|
wss.on('connection', ws => { |
|
|
|
wss.on('connection', ws => { |
|
|
|
const location = url.parse(ws.upgradeReq.url, true) |
|
|
|
const location = url.parse(ws.upgradeReq.url, true) |
|
|
|
const token = location.query.access_token |
|
|
|
const token = location.query.access_token |
|
|
@ -238,9 +248,15 @@ wss.on('connection', ws => { |
|
|
|
case 'public': |
|
|
|
case 'public': |
|
|
|
streamFrom(redisClient, 'timeline:public', req, streamToWs(req, ws, redisClient), true) |
|
|
|
streamFrom(redisClient, 'timeline:public', req, streamToWs(req, ws, redisClient), true) |
|
|
|
break; |
|
|
|
break; |
|
|
|
|
|
|
|
case 'public:local': |
|
|
|
|
|
|
|
streamFrom(redisClient, 'timeline:public:local', req, streamToWs(req, ws, redisClient), true) |
|
|
|
|
|
|
|
break; |
|
|
|
case 'hashtag': |
|
|
|
case 'hashtag': |
|
|
|
streamFrom(redisClient, `timeline:hashtag:${location.query.tag}`, req, streamToWs(req, ws, redisClient), true) |
|
|
|
streamFrom(redisClient, `timeline:hashtag:${location.query.tag}`, req, streamToWs(req, ws, redisClient), true) |
|
|
|
break; |
|
|
|
break; |
|
|
|
|
|
|
|
case 'hashtag:local': |
|
|
|
|
|
|
|
streamFrom(redisClient, `timeline:hashtag:${location.query.tag}:local`, req, streamToWs(req, ws, redisClient), true) |
|
|
|
|
|
|
|
break; |
|
|
|
default: |
|
|
|
default: |
|
|
|
ws.close() |
|
|
|
ws.close() |
|
|
|
} |
|
|
|
} |
|
|
|