Commit 90a4a5c4

mo khan <mo@mokhan.ca>
2013-05-05 06:10:58
process mixpanel event using delayed job
1 parent 46c4ca1
app/controllers/comments_controller.rb
@@ -7,6 +7,7 @@ class CommentsController < ApplicationController
 
   def create
     comment = resolve(CommentOnCreationCommand).run(params)
+    MixPanel.track("Added Comment", {} , @request_env)
     redirect_to comment.commentable, :notice => 'Nice Comment!'
   end
 end
app/controllers/creations_controller.rb
@@ -3,6 +3,7 @@ class CreationsController < ApplicationController
 
   def index
     @creations = FindAllCreationsQuery.new.fetch(params)
+    MixPanel.track "Viewed Home Page", {}, @request_env
   end
 
   def show
app/controllers/registrations_controller.rb
@@ -1,4 +1,5 @@
 class RegistrationsController < Devise::RegistrationsController
+  before_filter :initialize_env
   #force_ssl
   def edit
     @user = current_user
@@ -14,7 +15,20 @@ class RegistrationsController < Devise::RegistrationsController
       render "edit"
     end
   end
+
   def after_sign_in_path_for(resource)
+    MixPanel.track "Signed In", {}, @request_env
     edit_user_registration_path
   end
+
+  private
+
+  def initialize_env
+    @request_env = {
+      'REMOTE_ADDR' => request.env['REMOTE_ADDR'],
+      'HTTP_X_FORWARDED_FOR' => request.env['HTTP_X_FORWARDED_FOR'],
+      'rack.session' => request.env['rack.session'].to_hash,
+      'mixpanel_events' => request.env['mixpanel_events']
+    }
+  end
 end
app/services/commands/mixpanel_worker.rb
@@ -1,5 +1,5 @@
 class MixpanelWorker < Struct.new(:name, :properties, :request_env)
-  MIXPANEL_TOKEN = "7b1aa3b32ab81758228d1c95115cfc7e"
+  MIXPANEL_TOKEN = "866e150970370a95c77cf6293dbc02c5"
 
   def perform
     return unless Rails.env.production?
app/views/layouts/_mix_panel.html.erb
@@ -1,4 +0,0 @@
-<script type="text/javascript">(function(e,b){if(!b.__SV){var a,f,i,g;window.mixpanel=b;a=e.createElement("script");a.type="text/javascript";a.async=!0;a.src=("https:"===e.location.protocol?"https:":"http:")+'//cdn.mxpnl.com/libs/mixpanel-2.2.min.js';f=e.getElementsByTagName("script")[0];f.parentNode.insertBefore(a,f);b._i=[];b.init=function(a,e,d){function f(b,h){var a=h.split(".");2==a.length&&(b=b[a[0]],h=a[1]);b[h]=function(){b.push([h].concat(Array.prototype.slice.call(arguments,0)))}}var c=b;"undefined"!==
-typeof d?c=b[d]=[]:d="mixpanel";c.people=c.people||[];c.toString=function(b){var a="mixpanel";"mixpanel"!==d&&(a+="."+d);b||(a+=" (stub)");return a};c.people.toString=function(){return c.toString(1)+".people (stub)"};i="disable track track_pageview track_links track_forms register register_once alias unregister identify name_tag set_config people.set people.set_once people.increment people.append people.track_charge people.clear_charges people.delete_user".split(" ");for(g=0;g<i.length;g++)f(c,i[g]);
-b._i.push([a,e,d])};b.__SV=1.2}})(document,window.mixpanel||[]);
-mixpanel.init("866e150970370a95c77cf6293dbc02c5");</script>
app/views/layouts/application.html.erb
@@ -31,12 +31,8 @@
     <![endif]-->
     <%= yield :javascript %>
     <script type="text/javascript" src="http://scripts.embed.ly/jquery.embedly.min.js"></script>
-    <%= render "layouts/mix_panel"%>
     <script type="text/javascript" charset="utf-8">
       $.embedly.defaults['key'] = '4b97d740439245d8905d046dfa4d3e9a';
-      <% if current_user %>
-        mixpanel.identify("<%= current_user.id %>");
-      <% end %>
     </script>
     <%= render "layouts/google_analytics" %>
   </body>