Much improved the mailchimp webhook.

This commit is contained in:
Scott Erickson 2014-01-24 12:23:14 -08:00
parent b2366c50af
commit 95186cc5ae

View file

@ -5,42 +5,53 @@ errors = require '../commons/errors'
request = require 'request'
badLog = (text) ->
options.text = text
console.log text
request.post 'http://requestb.in/1brdpaz1', { form: {log: text} }
module.exports.setupRoutes = (app) ->
app.all '/mail/webhook', (req, res) ->
post = req.body
unless post['data[email]'] is 'sderickson+test@gmail.com'
unless post.type in ['unsubscribe', 'profile']
badLog("Bad post type: #{post.type}")
return res.end()
unless post['data[email]']
badLog("Ignoring because no email: #{JSON.stringify(req.body, null, '\t')}")
return res.end()
return handleProfileUpdate(post, res) if post.type is 'profile'
return handleUnsubscribe(post, res) if post.type is 'unsubscribe'
console.log 'unrecognized...', post
return res.end()
handleProfileUpdate: (data, res) ->
User.findOne {'mailChimp.euid':data['data[id]']}, (err, user) ->
return errors.serverError(res) if err
unless post['data[email]'] is 'sderickson@gmail.com'
badLog("Ignoring because this is a test: #{JSON.stringify(req.body, null, '\t')}")
return res.end()
groups = data['data[merges][INTERESTS]'].split(', ')
groups = (map[g] for g in groups when map[g])
user.set 'emailSubscriptions', groups
User.findOne {'mailChimp.euid':post['data[id]']}, (err, user) ->
return errors.serverError(res) if err
if not user
badLog("could not find user for...: #{{'mailChimp.euid':post['data[id]']}}")
return res.end()
mailChimpInfo = user.get 'mailChimp'
mailChimpInfo.email = data['data[email]']
user.set 'mailChimp', mailChimpInfo
handleProfileUpdate(post, user) if post.type is 'profile'
handleUnsubscribe(post, user) if post.type is 'unsubscribe'
badLog("Updating user object to: #{JSON.stringify(user.toObject(), null, '\t')}")
res.end()
res.end()
user.updatedMailChimp = true # so as not to echo back to mailchimp
user.save (err) ->
badLog("Error updating profile: #{error.message or error}") if err
res.end()
handleUnsubscribe: (data) ->
User.findOne {'mailChimp.euid':data['data[id]']}, (err, user) ->
return errors.serverError(res) if err
handleProfileUpdate = (data, user) ->
groups = data['data[merges][INTERESTS]'].split(', ')
groups = (map[g] for g in groups when map[g])
user.set 'emailSubscriptions', groups
user.set 'emailSubscriptions', []
user.set 'mailChimp', undefined
mailChimpInfo = user.get 'mailChimp'
mailChimpInfo.email = data['data[email]']
user.set 'mailChimp', mailChimpInfo
badLog("Unsubscribing user object to: #{JSON.stringify(user.toObject(), null, '\t')}")
res.end()
badLog("Updating user object to: #{JSON.stringify(user.toObject(), null, '\t')}")
handleUnsubscribe = (data, user) ->
user.set 'emailSubscriptions', []
badLog("Unsubscribing user object to: #{JSON.stringify(user.toObject(), null, '\t')}")