2016-04-07 12:40:53 -04:00
|
|
|
LevelSession = require './../models/LevelSession'
|
|
|
|
Handler = require '../commons/Handler'
|
2014-03-31 18:48:22 -04:00
|
|
|
log = require 'winston'
|
2016-05-04 01:26:48 -04:00
|
|
|
LZString = require 'lz-string'
|
2014-01-03 13:32:13 -05:00
|
|
|
|
|
|
|
TIMEOUT = 1000 * 30 # no activity for 30 seconds means it's not active
|
|
|
|
|
|
|
|
class LevelSessionHandler extends Handler
|
|
|
|
modelClass: LevelSession
|
|
|
|
|
|
|
|
getByRelationship: (req, res, args...) ->
|
2014-03-31 18:48:22 -04:00
|
|
|
return @getActiveSessions req, res if args.length is 2 and args[1] is 'active'
|
2015-01-05 18:40:26 -05:00
|
|
|
return @getRecentSessions req, res if args.length is 2 and args[1] is 'recent'
|
2014-08-30 02:09:38 -04:00
|
|
|
return @getCodeLanguageCounts req, res if args[1] is 'code_language_counts'
|
2014-04-08 22:26:19 -04:00
|
|
|
super(arguments...)
|
2014-06-11 22:38:41 -04:00
|
|
|
|
2014-05-15 18:18:15 -04:00
|
|
|
formatEntity: (req, document) ->
|
2016-05-04 01:26:48 -04:00
|
|
|
document = super(req, document)
|
2016-05-24 16:42:37 -04:00
|
|
|
submittedCode = document.submittedCode ? {}
|
2016-05-04 01:26:48 -04:00
|
|
|
unless req.user?.isAdmin() or
|
2015-01-31 13:04:02 -05:00
|
|
|
req.user?.id is document.creator or
|
2015-04-07 17:51:18 -04:00
|
|
|
not document.submittedCode # TODO: only allow leaderboard access to non-top-5 solutions
|
2016-05-04 01:26:48 -04:00
|
|
|
document = _.omit document, @privateProperties
|
|
|
|
if req.query.interpret
|
2016-05-08 23:59:58 -04:00
|
|
|
plan = submittedCode[if document.team is 'humans' then 'hero-placeholder' else 'hero-placeholder-1']?.plan ? ''
|
2016-05-04 01:26:48 -04:00
|
|
|
plan = LZString.compressToUTF16 plan
|
|
|
|
document.interpret = plan
|
2016-08-23 19:02:03 -04:00
|
|
|
document.code = {'hero-placeholder': {plan: ''}, 'hero-placeholder-1': {plan: ''}}
|
2016-05-04 01:26:48 -04:00
|
|
|
return document
|
2014-06-11 22:38:41 -04:00
|
|
|
|
2014-03-31 18:48:22 -04:00
|
|
|
getActiveSessions: (req, res) ->
|
2014-11-22 21:40:28 -05:00
|
|
|
return @sendForbiddenError(res) unless req.user?.isAdmin()
|
2014-01-03 13:32:13 -05:00
|
|
|
start = new Date()
|
|
|
|
start = new Date(start.getTime() - TIMEOUT)
|
|
|
|
query = @modelClass.find({'changed': {$gt: start}})
|
|
|
|
query.exec (err, documents) =>
|
|
|
|
return @sendDatabaseError(res, err) if err
|
|
|
|
documents = (@formatEntity(req, doc) for doc in documents)
|
|
|
|
@sendSuccess(res, documents)
|
|
|
|
|
2015-01-05 18:40:26 -05:00
|
|
|
getRecentSessions: (req, res) ->
|
|
|
|
return @sendForbiddenError(res) unless req.user?.isAdmin()
|
|
|
|
|
|
|
|
levelSlug = req.query.slug or req.body.slug
|
2016-01-11 12:51:23 -05:00
|
|
|
limit = parseInt req.query.limit or req.body.limit or 7
|
2015-01-05 18:40:26 -05:00
|
|
|
|
|
|
|
return @sendSuccess res, [] unless levelSlug?
|
|
|
|
|
2015-01-08 20:00:02 -05:00
|
|
|
today = new Date()
|
|
|
|
today.setUTCMinutes(today.getUTCMinutes() - 10)
|
|
|
|
queryParams = {$and: [{"changed": {"$lt": today}}, {"levelID": levelSlug}]}
|
|
|
|
query = @modelClass.find(queryParams).sort({changed: -1}).limit(limit)
|
2015-01-05 18:40:26 -05:00
|
|
|
query.exec (err, documents) =>
|
|
|
|
return @sendDatabaseError(res, err) if err
|
|
|
|
@sendSuccess res, documents
|
|
|
|
|
2014-02-13 19:42:35 -05:00
|
|
|
hasAccessToDocument: (req, document, method=null) ->
|
2015-01-31 13:04:02 -05:00
|
|
|
get = (method ? req.method).toLowerCase() is 'get'
|
|
|
|
return true if get and document.get('submitted')
|
2015-04-07 17:51:18 -04:00
|
|
|
return true if get and not document.get('submittedCode') # Allow leaderboard access to non-multiplayer sessions
|
2014-02-13 19:42:35 -05:00
|
|
|
super(arguments...)
|
|
|
|
|
2014-08-30 02:09:38 -04:00
|
|
|
getCodeLanguageCounts: (req, res) ->
|
|
|
|
if @codeLanguageCache and (new Date()) - @codeLanguageCountCachedSince > 86400 * 1000 # Dumb cache expiration
|
|
|
|
@codeLanguageCountCache = null
|
|
|
|
@codeLanguageCountCacheSince = null
|
|
|
|
if @codeLanguageCountCache
|
|
|
|
return @sendSuccess res, @codeLanguageCountCache
|
|
|
|
query = LevelSession.aggregate [
|
|
|
|
#{$match: {codeLanguage: {$exists: true}}} # actually slows it down
|
|
|
|
{$group: {_id: "$codeLanguage", sessions: {$sum: 1}}}
|
|
|
|
{$sort: {sessions: -1}}
|
|
|
|
]
|
|
|
|
query.exec (err, data) =>
|
|
|
|
if err? then return @sendDatabaseError res, err
|
|
|
|
@codeLanguageCountCache = data
|
|
|
|
@codeLanguageCountCachedSince = new Date()
|
|
|
|
@sendSuccess res, data
|
|
|
|
|
|
|
|
|
2014-01-03 13:32:13 -05:00
|
|
|
module.exports = new LevelSessionHandler()
|