codecombat/app/models/LevelSession.coffee

109 lines
3.9 KiB
CoffeeScript
Raw Normal View History

2014-06-30 22:16:26 -04:00
CocoModel = require './CocoModel'
2014-01-03 13:32:13 -05:00
module.exports = class LevelSession extends CocoModel
2014-06-30 22:16:26 -04:00
@className: 'LevelSession'
@schema: require 'schemas/models/level_session'
2014-06-30 22:16:26 -04:00
urlRoot: '/db/level.session'
2014-01-03 13:32:13 -05:00
initialize: ->
super()
@on 'sync', (e) =>
state = @get('state') or {}
state.scripts ?= {}
@set('state', state)
2014-01-03 13:32:13 -05:00
updatePermissions: ->
permissions = @get 'permissions', true
2014-01-03 13:32:13 -05:00
permissions = (p for p in permissions when p.target isnt 'public')
@set 'permissions', permissions
getSourceFor: (spellKey) ->
# spellKey ex: 'tharin/plan'
code = @get('code')
parts = spellKey.split '/'
code?[parts[0]]?[parts[1]]
readyToRank: ->
return false unless @get('levelID') # If it hasn't been denormalized, then it's not ready.
return false unless c1 = @get('code')
return false unless team = @get('team')
return true unless c2 = @get('submittedCode')
2014-06-30 22:16:26 -04:00
thangSpellArr = (s.split('/') for s in @get('teamSpells')[team])
for item in thangSpellArr
thang = item[0]
spell = item[1]
2014-06-20 23:52:50 -04:00
return true if c1[thang][spell] isnt c2[thang]?[spell]
false
isMultiplayer: ->
@get('submittedCodeLanguage')? and @get('team')?
completed: ->
@get('state')?.complete || @get('submitted') || false
shouldAvoidCorruptData: (attrs) ->
return false unless me.team is 'humans'
if _.string.startsWith (attrs?.code ? @get('code'))?.anya?.makeBid ? '', 'var __interceptThis'
noty text: "Not saving session--it's trying to overwrite Anya's code with transpiled output. Please let us know and help us reproduce this bug!", layout: 'topCenter', type: 'error', killer: false, timeout: 120000
return true
false
save: (attrs, options) ->
return if @shouldAvoidCorruptData attrs
super attrs, options
increaseDifficulty: (callback) ->
state = @get('state') ? {}
state.difficulty = (state.difficulty ? 0) + 1
delete state.lastUnsuccessfulSubmissionTime
@set 'state', state
@trigger 'change-difficulty'
@save null, success: callback
timeUntilResubmit: ->
state = @get('state') ? {}
return 0 unless last = state.lastUnsuccessfulSubmissionTime
last = new Date(last) if _.isString last
# Wait at least this long before allowing submit button active again.
2016-03-23 18:56:45 -04:00
wait = (last - new Date()) + 22 * 60 * 60 * 1000
if wait > 24 * 60 * 60 * 1000
# System clock must've gotten busted; max out at one day's wait.
wait = 24 * 60 * 60 * 1000
state.lastUnsuccessfulSubmissionTime = new Date()
@set 'state', state
wait
2015-01-31 00:36:36 -05:00
recordScores: (scores, level) ->
return unless scores
2015-01-31 00:36:36 -05:00
state = @get 'state'
oldTopScores = state.topScores ? []
newTopScores = []
now = new Date()
for scoreType in level.get('scoreTypes') ? []
oldTopScore = _.find oldTopScores, type: scoreType
newScore = scores[scoreType]
unless newScore?
newTopScores.push oldTopScore
continue
newScore *= -1 if scoreType in ['time', 'damage-taken'] # Make it so that higher is better
if not oldTopScore? or newScore > oldTopScore.score
newTopScores.push type: scoreType, date: now, score: newScore
else
newTopScores.push oldTopScore
state.topScores = newTopScores
@set 'state', state
generateSpellsObject: (options={}) ->
{level} = options
{createAetherOptions} = require 'lib/aether_utils'
aetherOptions = createAetherOptions functionName: 'plan', codeLanguage: @get('codeLanguage'), skipProtectAPI: options.level?.isType('game-dev')
spellThang = thang: {id: 'Hero Placeholder'}, aether: new Aether aetherOptions
spells = "hero-placeholder/plan": thang: spellThang, name: 'plan'
source = @get('code')?['hero-placeholder']?.plan ? ''
try
spellThang.aether.transpile source
catch e
console.log "Couldn't transpile!\n#{source}\n", e
spellThang.aether.transpile ''
spells