2014-07-04 11:18:46 -04:00
|
|
|
_ = require("underscore")
|
|
|
|
async = require("async")
|
|
|
|
Settings = require('settings-sharelatex')
|
2014-07-14 07:41:06 -04:00
|
|
|
logger = require("logger-sharelatex")
|
2014-07-04 11:18:46 -04:00
|
|
|
redis = require('redis')
|
|
|
|
rclient = redis.createClient(Settings.redis.web.port, Settings.redis.web.host)
|
|
|
|
rclient.auth(Settings.redis.web.password)
|
|
|
|
|
|
|
|
|
|
|
|
ONE_HOUR_IN_S = 60 * 60
|
2014-07-14 08:20:29 -04:00
|
|
|
ONE_DAY_IN_S = ONE_HOUR_IN_S * 24
|
|
|
|
FOUR_DAYS_IN_S = ONE_DAY_IN_S * 4
|
2014-07-04 11:18:46 -04:00
|
|
|
|
2014-07-14 10:30:55 -04:00
|
|
|
USER_TIMEOUT_IN_S = ONE_HOUR_IN_S
|
|
|
|
|
2014-07-10 11:05:05 -04:00
|
|
|
buildProjectSetKey = (project_id)-> return "users_in_project:#{project_id}"
|
2014-07-04 11:18:46 -04:00
|
|
|
buildUserKey = (project_id, user_id)-> return "connected_user:#{project_id}:#{user_id}"
|
|
|
|
|
|
|
|
|
2014-07-14 07:41:06 -04:00
|
|
|
module.exports =
|
2014-07-04 11:18:46 -04:00
|
|
|
|
|
|
|
markUserAsConnected: (project_id, user_id, callback = (err)->)->
|
2014-07-10 12:01:19 -04:00
|
|
|
logger.log project_id:project_id, user_id:user_id, "marking user as connected"
|
2014-07-14 10:38:55 -04:00
|
|
|
|
|
|
|
multi = rclient.multi()
|
|
|
|
multi.sadd buildProjectSetKey(project_id), user_id
|
|
|
|
multi.expire buildProjectSetKey(project_id), FOUR_DAYS_IN_S
|
|
|
|
multi.hset buildUserKey(project_id, user_id), "connected_at", new Date()
|
|
|
|
multi.expire buildUserKey(project_id, user_id), USER_TIMEOUT_IN_S
|
|
|
|
multi.exec (err)->
|
2014-07-14 07:41:06 -04:00
|
|
|
if err?
|
|
|
|
logger.err err:err, project_id:project_id, user_id:user_id, "problem marking user as connected"
|
|
|
|
callback(err)
|
2014-07-04 11:18:46 -04:00
|
|
|
|
2014-07-10 12:01:42 -04:00
|
|
|
markUserAsDisconnected: (project_id, user_id, callback)->
|
2014-07-10 12:01:19 -04:00
|
|
|
logger.log project_id:project_id, user_id:user_id, "marking user as disconnected"
|
2014-07-14 10:38:55 -04:00
|
|
|
multi = rclient.multi()
|
|
|
|
multi.srem buildProjectSetKey(project_id), user_id
|
|
|
|
multi.expire buildProjectSetKey(project_id), FOUR_DAYS_IN_S
|
|
|
|
multi.del buildUserKey(project_id, user_id)
|
|
|
|
multi.exec callback
|
|
|
|
|
2014-07-10 11:05:05 -04:00
|
|
|
|
2014-07-04 11:18:46 -04:00
|
|
|
_getConnectedUser: (project_id, user_id, callback)->
|
2014-07-14 10:30:55 -04:00
|
|
|
rclient.hgetall buildUserKey(project_id, user_id), (err, result)->
|
2014-07-04 11:18:46 -04:00
|
|
|
if !result?
|
2014-07-14 10:30:55 -04:00
|
|
|
result =
|
|
|
|
connected : false
|
|
|
|
user_id:user_id
|
2014-07-04 11:18:46 -04:00
|
|
|
else
|
2014-07-14 10:30:55 -04:00
|
|
|
result.connected = true
|
|
|
|
result.user_id = user_id
|
|
|
|
|
|
|
|
callback err, result
|
|
|
|
|
|
|
|
setUserCursorPosition: (project_id, user_id, cursorData, callback)->
|
2014-07-14 10:38:55 -04:00
|
|
|
multi = rclient.multi()
|
|
|
|
multi.hset buildUserKey(project_id, user_id), "cursorData", JSON.stringify(cursorData)
|
|
|
|
multi.expire buildUserKey(project_id, user_id), USER_TIMEOUT_IN_S
|
|
|
|
multi.exec callback
|
2014-07-04 11:18:46 -04:00
|
|
|
|
|
|
|
|
|
|
|
getConnectedUsers: (project_id, callback)->
|
|
|
|
self = @
|
2014-07-14 07:41:06 -04:00
|
|
|
rclient.smembers buildProjectSetKey(project_id), (err, results)->
|
2014-07-04 11:18:46 -04:00
|
|
|
jobs = results.map (user_id)->
|
|
|
|
(cb)->
|
|
|
|
self._getConnectedUser(project_id, user_id, cb)
|
|
|
|
async.series jobs, (err, users)->
|
|
|
|
users = _.filter users, (user)->
|
|
|
|
user.connected
|
2014-07-14 10:30:55 -04:00
|
|
|
callback err, users
|
2014-07-04 11:18:46 -04:00
|
|
|
|