add mixpanel
This commit is contained in:
		
							
								
								
									
										23
									
								
								app.js
									
									
									
									
									
								
							
							
						
						
									
										23
									
								
								app.js
									
									
									
									
									
								
							@@ -3,6 +3,7 @@ var express = require('express')
 | 
			
		||||
  , nodemailer = require('nodemailer')
 | 
			
		||||
  , _ = require('underscore')
 | 
			
		||||
  , fs = require('fs')
 | 
			
		||||
  , mixpanel = require('mixpanel')
 | 
			
		||||
  /*
 | 
			
		||||
  , amazonses = require('amazon-ses')
 | 
			
		||||
  */
 | 
			
		||||
@@ -19,6 +20,7 @@ var sendgrid = new SendGrid(
 | 
			
		||||
  process.env.SENDGRID_PASSWORD || 'd0y4yjqn'
 | 
			
		||||
)
 | 
			
		||||
*/
 | 
			
		||||
var mpq = new mixpanel.Client('6e6e6b71ed5ada4504c52d915388d73d');
 | 
			
		||||
 | 
			
		||||
var redis;
 | 
			
		||||
if (process.env.NODE_ENV == 'production')
 | 
			
		||||
@@ -44,6 +46,8 @@ app.get('/', function(req, res) {
 | 
			
		||||
});
 | 
			
		||||
 | 
			
		||||
app.post('/text', function(req, res) {
 | 
			
		||||
mpq.track('text',
 | 
			
		||||
            {number: req.body.number, message: req.body.message, ip: req.connection.remoteAddress});
 | 
			
		||||
 | 
			
		||||
  var number = stripPhone(req.body.number);
 | 
			
		||||
  if (number.length < 9 || number.length > 10) {
 | 
			
		||||
@@ -56,6 +60,7 @@ app.post('/text', function(req, res) {
 | 
			
		||||
 | 
			
		||||
  redis.incr(phonekey, function(err, num) {
 | 
			
		||||
    if (err) {
 | 
			
		||||
      mpq.track('redis fail');
 | 
			
		||||
      res.send({success:false,message:'Could not validate phone# quota.'});
 | 
			
		||||
      return;
 | 
			
		||||
    }
 | 
			
		||||
@@ -63,11 +68,13 @@ app.post('/text', function(req, res) {
 | 
			
		||||
    setTimeout(function() {
 | 
			
		||||
      redis.decr(phonekey, function(err, num) {
 | 
			
		||||
        if (err) {
 | 
			
		||||
          mpq.track('failed to decr phone quota', {number: number});
 | 
			
		||||
          console.log('*** WARNING failed to decr ' + number);
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
    }, 1000*60*3);
 | 
			
		||||
    if (num > 3) {
 | 
			
		||||
      mpq.track('exceeded phone quota');
 | 
			
		||||
      res.send({success:false,message:'Exceeded quota for this phone number.'});
 | 
			
		||||
      return;
 | 
			
		||||
    }
 | 
			
		||||
@@ -75,19 +82,25 @@ app.post('/text', function(req, res) {
 | 
			
		||||
    // now check against ip quota
 | 
			
		||||
    redis.incr(ipkey, function(err, num) {
 | 
			
		||||
      if (err) {
 | 
			
		||||
        mpq.track('redis fail');
 | 
			
		||||
        res.send({success:false,message:'Could not validate IP quota.'});
 | 
			
		||||
        return;
 | 
			
		||||
      }
 | 
			
		||||
      if (num > 500) {
 | 
			
		||||
        mpq.track('exceeded ip quota');
 | 
			
		||||
        res.send({success:false,message:'Exceeded quota for this IP address.'});
 | 
			
		||||
        return;
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      sendText(req.body.number, req.body.message, function(err) {
 | 
			
		||||
        if (err)
 | 
			
		||||
        if (err) {
 | 
			
		||||
          mpq.track('sendText failed');
 | 
			
		||||
          res.send({success:false,message:'Communication with SMS gateway failed.'});
 | 
			
		||||
        else
 | 
			
		||||
        }
 | 
			
		||||
        else {
 | 
			
		||||
          mpq.track('sendText success');
 | 
			
		||||
          res.send({success:true});
 | 
			
		||||
        }
 | 
			
		||||
      });
 | 
			
		||||
    });
 | 
			
		||||
 | 
			
		||||
@@ -123,16 +136,14 @@ function sendText(phone, message, cb) {
 | 
			
		||||
 | 
			
		||||
  _.each(providers, function(provider) {
 | 
			
		||||
    var email = provider.replace('%s', phone);
 | 
			
		||||
    console.log('email', email);
 | 
			
		||||
    var child = spawn('sendmail', ['-f', 'txt@textbelt.com', email]);
 | 
			
		||||
    child.stdout.on('data', console.log);
 | 
			
		||||
    child.stderr.on('data', console.log);
 | 
			
		||||
    child.on('error', function() {
 | 
			
		||||
      console.log('failed', email);
 | 
			
		||||
    child.on('error', function(data) {
 | 
			
		||||
      mpq.track('sendmail failed', {email: email, data: data});
 | 
			
		||||
      done();
 | 
			
		||||
    });
 | 
			
		||||
    child.on('exit', function(code, signal) {
 | 
			
		||||
      console.log('done', email);
 | 
			
		||||
      done();
 | 
			
		||||
    });
 | 
			
		||||
    child.stdin.write(message + '\n.');
 | 
			
		||||
 
 | 
			
		||||
@@ -8,6 +8,7 @@
 | 
			
		||||
      , "amazon-ses": "latest"
 | 
			
		||||
      , "sendgrid": "latest"
 | 
			
		||||
      , "underscore": "latest"
 | 
			
		||||
      , "mixpanel": "latest"
 | 
			
		||||
    }
 | 
			
		||||
  , "devDependencies": {
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -3,7 +3,7 @@
 | 
			
		||||
  <head>
 | 
			
		||||
    <meta charset="utf-8">
 | 
			
		||||
    <meta http-equiv="X-UA-Compatible" content="chrome=1">
 | 
			
		||||
    <title>TextBelt by typpo</title>
 | 
			
		||||
    <title>TextBelt - Free Texting API</title>
 | 
			
		||||
    <link rel="stylesheet" href="http://typpo.github.com/textbelt/stylesheets/styles.css">
 | 
			
		||||
    <link rel="stylesheet" href="http://typpo.github.com/textbelt/stylesheets/pygment_trac.css">
 | 
			
		||||
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
 | 
			
		||||
@@ -15,7 +15,10 @@
 | 
			
		||||
    <link rel="stylesheet" href="stylesheets/ie.css">
 | 
			
		||||
    <![endif]-->
 | 
			
		||||
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
 | 
			
		||||
 | 
			
		||||
    <!-- start Mixpanel --><script type="text/javascript">(function(d,c){var a,b,g,e;a=d.createElement("script");a.type="text/javascript";a.async=!0;a.src=("https:"===d.location.protocol?"https:":"http:")+'//api.mixpanel.com/site_media/js/api/mixpanel.2.js';b=d.getElementsByTagName("script")[0];b.parentNode.insertBefore(a,b);c._i=[];c.init=function(a,d,f){var b=c;"undefined"!==typeof f?b=c[f]=[]:f="mixpanel";g="disable track track_pageview track_links track_forms register register_once unregister identify name_tag set_config".split(" ");
 | 
			
		||||
      for(e=0;e<g.length;e++)(function(a){b[a]=function(){b.push([a].concat(Array.prototype.slice.call(arguments,0)))}})(g[e]);c._i.push([a,d,f])};window.mixpanel=c})(document,[]);
 | 
			
		||||
      mixpanel.init("6e6e6b71ed5ada4504c52d915388d73d");</script><!-- end Mixpanel -->
 | 
			
		||||
    <script>mixpanel.track('main');</script>
 | 
			
		||||
  </head>
 | 
			
		||||
  <body>
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user