NewsBlur/node/unread_counts.coffee

68 lines
2.3 KiB
CoffeeScript
Raw Normal View History

fs = require 'fs'
redis = require 'redis'
2013-05-01 12:51:59 -07:00
log = require './log.js'
2013-04-21 06:07:01 -07:00
REDIS_SERVER = if process.env.NODE_ENV == 'development' then 'localhost' else 'db12'
SECURE = !!process.env.NODE_SSL
# client = redis.createClient 6379, REDIS_SERVER
# RedisStore = require 'socket.io/lib/stores/redis'
# rpub = redis.createClient 6379, REDIS_SERVER
# rsub = redis.createClient 6379, REDIS_SERVER
# rclient = redis.createClient 6379, REDIS_SERVER
2013-03-15 17:55:58 -07:00
if SECURE
privateKey = fs.readFileSync('./config/certificates/newsblur.com.key').toString()
certificate = fs.readFileSync('./config/certificates/newsblur.com.crt').toString()
ca = fs.readFileSync('./config/certificates/intermediate.crt').toString()
io = require('socket.io').listen 8889
key: privateKey
cert: certificate
ca: ca
else
io = require('socket.io').listen 8888
io.configure 'production', ->
io.set 'log level', 1
2012-05-03 13:43:18 -07:00
io.enable 'browser client minification'
io.enable 'browser client etag'
io.enable 'browser client gzip'
io.configure 'development', ->
io.set 'log level', 2
# io.set 'store', new RedisStore
# redisPub : rpub
# redisSub : rsub
# redisClient : rclient
2013-03-15 17:55:58 -07:00
io.sockets.on 'connection', (socket) ->
socket.on 'subscribe:feeds', (@feeds, @username) ->
2013-05-01 12:51:59 -07:00
log.info @username, "Subscribing to #{feeds.length} feeds " +
" (#{io.sockets.clients().length} users on) " +
" #{if SECURE then "(SSL)" else "(non-SSL)"}"
if not @username
return
socket.subscribe?.end()
socket.subscribe = redis.createClient 6379, REDIS_SERVER
socket.subscribe.subscribe @feeds
socket.subscribe.subscribe @username
2013-03-15 17:55:58 -07:00
socket.subscribe.on 'message', (channel, message) =>
2013-05-01 12:51:59 -07:00
log.info @username, "Update on #{channel}: #{message}"
if channel == @username
socket.emit 'user:update', channel, message
else
socket.emit 'feed:update', channel, message
2013-03-15 17:55:58 -07:00
socket.on 'disconnect', () ->
socket.subscribe?.end()
ip = socket.handshake.address.address
2013-05-01 12:51:59 -07:00
log.info @username, "Disconnect (#{@feeds?.length} feeds, #{ip})," +
" there are now #{io.sockets.clients().length-1} users. " +
2013-03-15 17:55:58 -07:00
" #{if SECURE then "(SSL)" else "(non-SSL)"}"