2015-12-16 20:09:22 -05:00
|
|
|
mw = require '../middleware'
|
|
|
|
|
2015-12-14 14:10:37 -05:00
|
|
|
module.exports.setup = (app) ->
|
2016-02-25 18:24:16 -05:00
|
|
|
|
|
|
|
app.post('/auth/login-facebook', mw.auth.loginByFacebook)
|
|
|
|
app.post('/auth/login-gplus', mw.auth.loginByGPlus)
|
2016-03-03 17:22:50 -05:00
|
|
|
app.post('/auth/spy', mw.auth.spy)
|
|
|
|
app.post('/auth/stop-spying', mw.auth.stopSpying)
|
|
|
|
|
2015-12-16 20:09:22 -05:00
|
|
|
Article = require '../models/Article'
|
|
|
|
app.get('/db/article', mw.rest.get(Article))
|
|
|
|
app.post('/db/article', mw.auth.checkHasPermission(['admin', 'artisan']), mw.rest.post(Article))
|
|
|
|
app.get('/db/article/names', mw.named.names(Article))
|
|
|
|
app.post('/db/article/names', mw.named.names(Article))
|
|
|
|
app.get('/db/article/:handle', mw.rest.getByHandle(Article))
|
|
|
|
app.put('/db/article/:handle', mw.auth.checkHasPermission(['admin']), mw.rest.put(Article))
|
|
|
|
app.patch('/db/article/:handle', mw.auth.checkHasPermission(['admin']), mw.rest.put(Article))
|
|
|
|
app.post('/db/article/:handle/new-version', mw.auth.checkLoggedIn(), mw.versions.postNewVersion(Article, { hasPermissionsOrTranslations: 'artisan' }))
|
|
|
|
app.get('/db/article/:handle/versions', mw.versions.versions(Article))
|
|
|
|
app.get('/db/article/:handle/version/?(:version)?', mw.versions.getLatestVersion(Article))
|
|
|
|
app.get('/db/article/:handle/files', mw.files.files(Article, {module: 'article'}))
|
|
|
|
app.get('/db/article/:handle/patches', mw.patchable.patches(Article))
|
|
|
|
app.post('/db/article/:handle/watchers', mw.patchable.joinWatchers(Article))
|
|
|
|
app.delete('/db/article/:handle/watchers', mw.patchable.leaveWatchers(Article))
|
2016-02-25 18:24:16 -05:00
|
|
|
|
2016-03-30 16:57:19 -04:00
|
|
|
app.get('/db/classroom', mw.classrooms.getByOwner)
|
|
|
|
app.get('/db/classroom/:handle/member-sessions', mw.classrooms.fetchMemberSessions)
|
|
|
|
app.get('/db/classroom/:handle/members', mw.classrooms.fetchMembers) # TODO: Use mw.auth?
|
2016-03-30 19:20:37 -04:00
|
|
|
app.get('/db/classroom/:handle', mw.auth.checkLoggedIn()) # TODO: Finish migrating route, adding now so 401 is returned
|
2016-03-30 16:57:19 -04:00
|
|
|
|
|
|
|
Course = require '../models/Course'
|
|
|
|
app.get('/db/course', mw.rest.get(Course))
|
|
|
|
app.get('/db/course/:handle', mw.rest.getByHandle(Course))
|
|
|
|
|
|
|
|
app.get('/db/campaign', mw.campaigns.fetchByType) #TODO
|
|
|
|
|
|
|
|
app.post('/db/course_instance/:handle/members', mw.auth.checkLoggedIn(), mw.courseInstances.addMembers)
|
|
|
|
|
2016-02-25 18:24:16 -05:00
|
|
|
app.get('/db/user', mw.users.fetchByGPlusID, mw.users.fetchByFacebookID)
|
2015-12-16 20:09:22 -05:00
|
|
|
|
2015-12-29 00:03:43 -05:00
|
|
|
app.get '/db/products', require('./db/product').get
|
2016-03-09 19:59:25 -05:00
|
|
|
|
|
|
|
TrialRequest = require '../models/TrialRequest'
|
|
|
|
app.get('/db/trial.request', mw.trialRequests.fetchByApplicant, mw.auth.checkHasPermission(['admin']), mw.rest.get(TrialRequest))
|
2016-04-05 13:01:51 -04:00
|
|
|
app.post('/db/trial.request', mw.trialRequests.post)
|
2016-03-09 19:59:25 -05:00
|
|
|
app.get('/db/trial.request/:handle', mw.auth.checkHasPermission(['admin']), mw.rest.getByHandle(TrialRequest))
|
|
|
|
app.put('/db/trial.request/:handle', mw.auth.checkHasPermission(['admin']), mw.trialRequests.put)
|
2015-12-29 00:03:43 -05:00
|
|
|
|
|
|
|
app.get '/healthcheck', (req, res) ->
|
|
|
|
try
|
|
|
|
async = require 'async'
|
2016-04-06 13:56:06 -04:00
|
|
|
User = require '../models/User'
|
2015-12-29 00:03:43 -05:00
|
|
|
async.waterfall [
|
|
|
|
(callback) ->
|
|
|
|
User.find({}).limit(1).exec(callback)
|
|
|
|
, (last, callback) ->
|
|
|
|
return("No users found") unless callback.length > 0
|
|
|
|
User.findOne(slug: 'healthcheck').exec(callback)
|
|
|
|
, (hcuser, callback) ->
|
|
|
|
# Create health check user if it doesnt exist
|
|
|
|
return callback(null, hcuser) if hcuser
|
|
|
|
user = new User
|
|
|
|
anonymous: false
|
|
|
|
name: 'healthcheck'
|
|
|
|
nameLower: 'healthcheck'
|
|
|
|
slug: 'healthcheck'
|
|
|
|
email: 'rob+healthcheck@codecombat.com'
|
|
|
|
emailLower: 'rob+healthcheck@codecombat.com'
|
|
|
|
user.set 'testGroupNumber', Math.floor(Math.random() * 256) # also in app/core/auth
|
|
|
|
user.save (err) ->
|
|
|
|
return callback(err) if err
|
|
|
|
callback(null, user)
|
|
|
|
|
|
|
|
, (hcuser, callback) ->
|
|
|
|
activity = hcuser.trackActivity 'healthcheck', 1
|
|
|
|
hcuser.update {activity: activity}, callback
|
|
|
|
], (err) ->
|
|
|
|
return res.status(500).send(err.toString()) if err
|
|
|
|
res.send("OK")
|
|
|
|
catch error
|
|
|
|
res.status(500).send(error.toString())
|