From 6ac73f45f0d88b4a7fded64260a8d6ea1cff7400 Mon Sep 17 00:00:00 2001
From: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
Date: Wed, 18 Dec 2013 13:42:12 +0200
Subject: [PATCH] Move EmailOnPush logic to async worker

Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
---
 .../emails_on_push_service.rb                 | 20 +--------------
 app/workers/emails_on_push_worker.rb          | 25 +++++++++++++++++++
 2 files changed, 26 insertions(+), 19 deletions(-)
 create mode 100644 app/workers/emails_on_push_worker.rb

diff --git a/app/models/project_services/emails_on_push_service.rb b/app/models/project_services/emails_on_push_service.rb
index 73458098400..2a46eff7846 100644
--- a/app/models/project_services/emails_on_push_service.rb
+++ b/app/models/project_services/emails_on_push_service.rb
@@ -33,24 +33,7 @@ class EmailsOnPushService < Service
   end
 
   def execute(push_data)
-    before_sha = push_data[:before]
-    after_sha = push_data[:after]
-    branch = push_data[:ref]
-    author_id = push_data[:user_id]
-
-    if before_sha =~ /^000000/ || after_sha =~ /^000000/
-      # skip if new branch was pushed or branch was removed
-      return true
-    end
-
-    compare = Gitlab::Git::Compare.new(project.repository.raw_repository, before_sha, after_sha)
-
-    # Do not send emails if git compare failed
-    return false unless compare && compare.commits.present?
-
-    recipients.split(" ").each do |recipient|
-      Notify.delay.repository_push_email(project_id, recipient, author_id, branch, compare)
-    end
+    EmailsOnPushWorker.perform_async(project_id, recipients, push_data)
   end
 
   def fields
@@ -59,4 +42,3 @@ class EmailsOnPushService < Service
     ]
   end
 end
-
diff --git a/app/workers/emails_on_push_worker.rb b/app/workers/emails_on_push_worker.rb
new file mode 100644
index 00000000000..9982b362a10
--- /dev/null
+++ b/app/workers/emails_on_push_worker.rb
@@ -0,0 +1,25 @@
+class EmailsOnPushWorker
+  include Sidekiq::Worker
+
+  def perform(project_id, recipients, push_data)
+    project = Project.find(project_id)
+    before_sha = push_data["before"]
+    after_sha = push_data["after"]
+    branch = push_data["ref"]
+    author_id = push_data["user_id"]
+
+    if before_sha =~ /^000000/ || after_sha =~ /^000000/
+      # skip if new branch was pushed or branch was removed
+      return true
+    end
+
+    compare = Gitlab::Git::Compare.new(project.repository.raw_repository, before_sha, after_sha)
+
+    # Do not send emails if git compare failed
+    return false unless compare && compare.commits.present?
+
+    recipients.split(" ").each do |recipient|
+      Notify.delay.repository_push_email(project_id, recipient, author_id, branch, compare)
+    end
+  end
+end
-- 
GitLab