Merge branch 'petehunt-authbox'

This commit is contained in:
Ian Webster 2015-01-03 14:51:23 -05:00
commit 47aaa19906
4 changed files with 54 additions and 20 deletions

1
.gitignore vendored
View File

@ -1,5 +1,6 @@
banned_numbers.js banned_numbers.js
mixpanel_config.js mixpanel_config.js
authbox_config.js
keys.json keys.json
*.swp *.swp

View File

@ -6,11 +6,12 @@
} }
, "dependencies": { , "dependencies": {
"express": "~3.5.1" "express": "~3.5.1"
, "authbox": "^0.9.2"
, "jade": "~0.14.2" , "jade": "~0.14.2"
, "mixpanel": "~0.0.19"
, "nodemailer": "~0.6.1" , "nodemailer": "~0.6.1"
, "redis-url": "~0.2.0" , "redis-url": "~0.2.0"
, "underscore": "~1.6.0" , "underscore": "~1.6.0"
, "mixpanel": "~0.0.19"
} }
, "devDependencies": { , "devDependencies": {
} }

View File

@ -1,14 +1,23 @@
var express = require('express') var express = require('express')
, app = express() , app = express()
, _ = require('underscore') , _ = require('underscore')
, authbox = require('authbox')
, crypto = require('crypto')
, exec = require('child_process').exec
, fs = require('fs') , fs = require('fs')
, mixpanel = require('mixpanel') , mixpanel = require('mixpanel')
, exec = require('child_process').exec
, spawn = require('child_process').spawn
, Stream = require('stream')
, redis = require('redis-url').connect() , redis = require('redis-url').connect()
, spawn = require('child_process').spawn
, text = require('../lib/text'); , text = require('../lib/text');
// Express config
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.cookieParser());
app.use(express.static(__dirname + '/public'));
app.use(express.bodyParser());
// Enable log messages when sending texts. // Enable log messages when sending texts.
text.debug(true); text.debug(true);
@ -21,7 +30,8 @@ try {
} }
var mpq var mpq
, mixpanel_config; , mixpanel_config
, authbox_config;
try { try {
mixpanel_config = require('./mixpanel_config.js'); mixpanel_config = require('./mixpanel_config.js');
mpq = new mixpanel.Client(mixpanel_config.api_key); mpq = new mixpanel.Client(mixpanel_config.api_key);
@ -29,6 +39,14 @@ try {
mpq = {track: function() {}}; mpq = {track: function() {}};
} }
try {
authbox_config = require('./authbox_config.js');
authbox.configure(authbox_config);
app.use(authbox.middleware);
} catch(e) {
authbox = {log: function() {}};
}
var access_keys; var access_keys;
try { try {
// Optionally, you may specify special access keys in a keys.json file. // Optionally, you may specify special access keys in a keys.json file.
@ -39,14 +57,6 @@ try {
access_keys = {}; access_keys = {};
} }
// Express config
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.cookieParser());
app.use(express.static(__dirname + '/public'));
app.use(express.bodyParser());
// App routes // App routes
app.get('/', function(req, res) { app.get('/', function(req, res) {
fs.readFile(__dirname + '/views/index.html', 'utf8', function(err, text){ fs.readFile(__dirname + '/views/index.html', 'utf8', function(err, text){
@ -79,13 +89,34 @@ app.post('/intl', function(req, res) {
// App helper functions // App helper functions
function textRequestHandler(req, res, number, region, key) { function textRequestHandler(req, res, number, region, key) {
var authbox_details = {
$actionName: 'text'
};
if (!number || !req.body.message) { if (!number || !req.body.message) {
mpq.track('incomplete request'); mpq.track('incomplete request');
authbox.log(req, _.extend(authbox_details, {$failureReason: 'incomplete_request'}));
res.send({success:false, message:'Number and message parameters are required.'}); res.send({success:false, message:'Number and message parameters are required.'});
return; return;
} }
var message = req.body.message;
if (message.indexOf(':') > -1) {
// Handle problem with vtext where message would not get sent properly if it
// contains a colon.
message = ' ' + message;
}
shasum.update(number);
var authbox_digest = shasum.digest('hex');
_.extend(authbox_details, {
recipient: number,
message__text: message
});
if (banned_numbers.BLACKLIST[number]) { if (banned_numbers.BLACKLIST[number]) {
mpq.track('banned number'); mpq.track('banned number');
authbox.log(req, _.extend(authbox_details, {$failureReason: 'banned_number'}));
res.send({success:false,message:'Sorry, texts to this number are disabled.'}); res.send({success:false,message:'Sorry, texts to this number are disabled.'});
return; return;
} }
@ -95,13 +126,6 @@ function textRequestHandler(req, res, number, region, key) {
ip = req.header('X-Real-IP'); ip = req.header('X-Real-IP');
} }
var message = req.body.message;
if (message.indexOf(':') > -1) {
// Handle problem with vtext where message would not get sent properly if it
// contains a colon
message = ' ' + message;
}
var tracking_details = { var tracking_details = {
number: number, number: number,
message: req.body.message, message: req.body.message,
@ -115,6 +139,7 @@ function textRequestHandler(req, res, number, region, key) {
text.send(number, message, region, function(err) { text.send(number, message, region, function(err) {
if (err) { if (err) {
mpq.track('sendText failed', tracking_details); mpq.track('sendText failed', tracking_details);
authbox.log(req, _.extend(authbox_details, {$failureReason: 'gateway_failed'}));
res.send(_.extend(response_obj, res.send(_.extend(response_obj,
{ {
success:false, success:false,
@ -123,6 +148,7 @@ function textRequestHandler(req, res, number, region, key) {
} }
else { else {
mpq.track('sendText success', tracking_details); mpq.track('sendText success', tracking_details);
authbox.log(req, _.extend(authbox_details, {$success: true}));
res.send(_.extend(response_obj, {success:true})); res.send(_.extend(response_obj, {success:true}));
} }
}); });
@ -160,6 +186,7 @@ function textRequestHandler(req, res, number, region, key) {
}, 1000*60*3); }, 1000*60*3);
if (num > 3) { if (num > 3) {
mpq.track('exceeded phone quota'); mpq.track('exceeded phone quota');
authbox.log(req, _.extend(authbox_details, {$failureReason: 'exceeded_phone_quota'}));
res.send({success:false, message:'Exceeded quota for this phone number. ' + number}); res.send({success:false, message:'Exceeded quota for this phone number. ' + number});
return; return;
} }
@ -173,6 +200,7 @@ function textRequestHandler(req, res, number, region, key) {
} }
if (num > 75) { if (num > 75) {
mpq.track('exceeded ip quota'); mpq.track('exceeded ip quota');
authbox.log(req, _.extend(authbox_details, {$failureReason: 'exceeded_ip_quota'}));
res.send({success:false, message:'Exceeded quota for this IP address. ' + ip}); res.send({success:false, message:'Exceeded quota for this IP address. ' + ip});
return; return;
} }

View File

@ -0,0 +1,4 @@
module.exports = {
apiKey: 'foobar',
secretKey: '1234567'
};