overleaf/services/web/app/coffee/Features/Dropbox/DropboxWebhookController.coffee

22 lines
730 B
CoffeeScript
Raw Normal View History

2014-08-13 16:26:18 +00:00
logger = require("logger-sharelatex")
DropboxWebhookHandler = require("./DropboxWebhookHandler")
module.exports = DropboxWebhookController =
verify: (req, res, next = (error) ->) ->
res.send(req.query.challenge)
2014-09-10 13:19:44 +00:00
req.session.destroy()
2014-08-13 16:26:18 +00:00
webhook: (req, res, next = (error) ->) ->
dropbox_uids = req.body?.delta?.users
logger.log dropbox_uids: dropbox_uids, "received webhook request from Dropbox"
if !dropbox_uids?
return res.send(400) # Bad Request
# Do this in the background so as not to keep Dropbox waiting
2014-08-13 16:26:18 +00:00
DropboxWebhookHandler.pollDropboxUids dropbox_uids, (error) ->
if error?
logger.error err: error, dropbox_uids: dropbox_uids, "error in webhook"
2014-09-10 13:19:44 +00:00
res.send(200)
req.session.destroy()