Enable unsubscribe for admin emails

parent 44cced4a
module Public
class UnsubscribesController < ApplicationController
skip_before_filter :authenticate_user!,
:reject_blocked, :set_current_user_for_observers,
:add_abilities
layout 'public_users'
def show
@user = get_user
end
def create
@user = get_user
@user.admin_unsubscribe!
redirect_to new_user_session_path, notice: 'You have been unsubscribed'
end
protected
def get_user
@email = "#{params[:email]}.#{params[:format]}"
User.where(email: @email).first!
end
end
end
\ No newline at end of file
...@@ -175,6 +175,7 @@ class User < ActiveRecord::Base ...@@ -175,6 +175,7 @@ class User < ActiveRecord::Base
scope :not_in_project, ->(project) { project.users.present? ? where("id not in (:ids)", ids: project.users.map(&:id) ) : all } scope :not_in_project, ->(project) { project.users.present? ? where("id not in (:ids)", ids: project.users.map(&:id) ) : all }
scope :without_projects, -> { where('id NOT IN (SELECT DISTINCT(user_id) FROM users_projects)') } scope :without_projects, -> { where('id NOT IN (SELECT DISTINCT(user_id) FROM users_projects)') }
scope :ldap, -> { where(provider: 'ldap') } scope :ldap, -> { where(provider: 'ldap') }
scope :subscribed_for_admin_email, -> { where(admin_email_unsubscribed_at: nil) }
scope :potential_team_members, ->(team) { team.members.any? ? active.not_in_team(team) : active } scope :potential_team_members, ->(team) { team.members.any? ? active.not_in_team(team) : active }
...@@ -509,4 +510,8 @@ class User < ActiveRecord::Base ...@@ -509,4 +510,8 @@ class User < ActiveRecord::Base
def system_hook_service def system_hook_service
SystemHooksService.new SystemHooksService.new
end end
def admin_unsubscribe!
update_column :admin_email_unsubscribed_at, Time.now
end
end end
%h3.page-title Unsubscribe from Admin notifications
%p
Don't want to receive any updates from your system administrator.
By clicking the confirmation button you'll no longer receive these notifications
%hr
= form_tag public_unsubscribe_path(@email) do
%p
Yes, I want to unsubscribe
%strong= @email
from any further admin emails.
.form-actions
= submit_tag 'Unsubscribe', class: 'btn btn-create'
...@@ -11,11 +11,11 @@ class AdminEmailsWorker ...@@ -11,11 +11,11 @@ class AdminEmailsWorker
def recipient_list(recipient_id) def recipient_list(recipient_id)
case recipient_id case recipient_id
when 'all' when 'all'
User.where(nil) User.subscribed_for_admin_email
when /group-(\d+)\z/ when /group-(\d+)\z/
Group.find($1).users Group.find($1).users.subscribed_for_admin_email
when /project-(\d+)\z/ when /project-(\d+)\z/
Project.find($1).users Project.find($1).users.subscribed_for_admin_email
end end
end end
end end
\ No newline at end of file
...@@ -52,6 +52,8 @@ Gitlab::Application.routes.draw do ...@@ -52,6 +52,8 @@ Gitlab::Application.routes.draw do
# #
namespace :public do namespace :public do
resources :projects, only: [:index] resources :projects, only: [:index]
get 'unsubscribes/:email', to: 'unsubscribes#show', as: :unsubscribe
post 'unsubscribes/:email', to: 'unsubscribes#create'
root to: "projects#index" root to: "projects#index"
end end
......
require 'spec_helper'
describe AdminEmailsWorker do
context "recipients" do
let(:recipient_id) { "group-#{group.id}" }
let(:group) { create :group }
before do
2.times do
group.add_user(create(:user), Gitlab::Access::DEVELOPER)
end
unsubscribed_user = create(:user, admin_email_unsubscribed_at: 5.days.ago)
group.add_user(unsubscribed_user, Gitlab::Access::DEVELOPER)
ActionMailer::Base.deliveries = []
end
it "sends email to subscribed users" do
AdminEmailsWorker.new.perform(recipient_id, 'subject', 'body')
expect(ActionMailer::Base.deliveries.count).to eql 2
end
end
end
\ No newline at end of file
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment