summaryrefslogtreecommitdiff
path: root/app/mailers
diff options
context:
space:
mode:
authorRémy Coutable <remy@rymai.me>2016-04-18 18:53:32 +0200
committerRémy Coutable <remy@rymai.me>2016-06-14 13:07:26 +0200
commitd26f81239a33b80694783ee35f0da0e2ed082c9b (patch)
treef092e818d4b81805a16879b13407a335bbda0054 /app/mailers
parent17c22156c5fa5663aae65178ed38cbeef9a80b7e (diff)
downloadgitlab-ce-d26f81239a33b80694783ee35f0da0e2ed082c9b.tar.gz
Add request access for groups
Signed-off-by: Rémy Coutable <remy@rymai.me>
Diffstat (limited to 'app/mailers')
-rw-r--r--app/mailers/emails/groups.rb51
-rw-r--r--app/mailers/emails/projects.rb75
2 files changed, 63 insertions, 63 deletions
diff --git a/app/mailers/emails/groups.rb b/app/mailers/emails/groups.rb
index 1c43f95dc8c..fe218bfbe05 100644
--- a/app/mailers/emails/groups.rb
+++ b/app/mailers/emails/groups.rb
@@ -1,22 +1,38 @@
module Emails
module Groups
+ def group_access_requested_email(group_member_id)
+ setup_group_member_mail(group_member_id)
+
+ @requester = @group_member.created_by
+
+ group_admins = User.where(id: @group.group_members.admins.pluck(:user_id)).pluck(:notification_email)
+
+ mail(to: group_admins,
+ subject: subject("Request to join #{@group.name} group"))
+ end
+
def group_access_granted_email(group_member_id)
- @group_member = GroupMember.find(group_member_id)
- @group = @group_member.group
+ setup_group_member_mail(group_member_id)
- @target_url = group_url(@group)
@current_user = @group_member.user
- mail(to: @group_member.user.notification_email,
- subject: subject("Access to group was granted"))
+ mail(to: @current_user.notification_email,
+ subject: subject("Access to #{@group.name} group was granted"))
+ end
+
+ def group_access_denied_email(group_id, user_id)
+ @group = Group.find(group_id)
+ @current_user = User.find(user_id)
+ @target_url = group_url(@group)
+
+ mail(to: @current_user.notification_email,
+ subject: subject("Access to #{@group.name} group was denied"))
end
def group_member_invited_email(group_member_id, token)
- @group_member = GroupMember.find group_member_id
- @group = @group_member.group
- @token = token
+ setup_group_member_mail(group_member_id)
- @target_url = group_url(@group)
+ @token = token
@current_user = @group_member.user
mail(to: @group_member.invite_email,
@@ -24,15 +40,12 @@ module Emails
end
def group_invite_accepted_email(group_member_id)
- @group_member = GroupMember.find group_member_id
+ setup_group_member_mail(group_member_id)
return if @group_member.created_by.nil?
- @group = @group_member.group
-
- @target_url = group_url(@group)
@current_user = @group_member.created_by
- mail(to: @group_member.created_by.notification_email,
+ mail(to: @current_user.notification_email,
subject: subject("Invitation accepted"))
end
@@ -43,10 +56,18 @@ module Emails
@current_user = @created_by = User.find(created_by_id)
@access_level = access_level
@invite_email = invite_email
-
+
@target_url = group_url(@group)
mail(to: @created_by.notification_email,
subject: subject("Invitation declined"))
end
+
+ private
+
+ def setup_group_member_mail(group_member_id)
+ @group_member = GroupMember.find(group_member_id)
+ @group = @group_member.group
+ @target_url = group_url(@group)
+ end
end
end
diff --git a/app/mailers/emails/projects.rb b/app/mailers/emails/projects.rb
index 6662c407c2c..43a2a7e80a8 100644
--- a/app/mailers/emails/projects.rb
+++ b/app/mailers/emails/projects.rb
@@ -1,64 +1,38 @@
module Emails
module Projects
- def project_access_granted_email(project_member_id)
- @project_member = ProjectMember.find project_member_id
- @project = @project_member.project
-
- @target_url = namespace_project_url(@project.namespace, @project)
- @current_user = @project_member.user
+ def project_access_requested_email(project_member_id)
+ setup_project_member_mail(project_member_id)
- mail(to: @project_member.user.notification_email,
- subject: subject("Access to project was granted"))
- end
+ @requester = @project_member.created_by
- def project_member_requested_access(project_member_id)
- @project_member = ProjectMember.find project_member_id
- @project = @project_member.project
- @target_url = namespace_project_url(@project.namespace, @project)
+ project_admins = User.where(id: @project.project_members.admins.pluck(:user_id)).pluck(:notification_email)
- project_admins = ProjectMember.in_project(@project)
- .where(access_level: [Gitlab::Access::OWNER, Gitlab::Access::MASTER])
- .pluck(:notification_email)
-
- project_admins.each do |address|
- mail(to: address,
- subject: subject("Request to join project: #{@project.name_with_namespace}"))
- end
+ mail(to: project_admins,
+ subject: subject("Request to join #{@project.name_with_namespace} project"))
end
- def project_request_access_accepted_email(project_member_id)
- @project_member = ProjectMember.find project_member_id
- return if @project_member.created_by.nil?
-
- @project = @project_member.project
+ def project_access_granted_email(project_member_id)
+ setup_project_member_mail(project_member_id)
- @target_url = namespace_project_url(@project.namespace, @project)
- @current_user = @project_member.created_by
+ @current_user = @project_member.user
- mail(to: @project_member.created_by.notification_email,
- subject: subject('Request for access granted'))
+ mail(to: @current_user.notification_email,
+ subject: subject("Access to #{@project.name_with_namespace} project was granted"))
end
- def project_request_access_declined_email(project_member_id)
- @project_member = ProjectMember.find project_member_id
- return if @project_member.created_by.nil?
-
- @project = @project_member.project
-
+ def project_access_denied_email(project_id, user_id)
+ @project = Project.find(project_id)
+ @current_user = User.find(user_id)
@target_url = namespace_project_url(@project.namespace, @project)
- @current_user = @project_member.created_by
- mail(to: @project_member.created_by.notification_email,
- subject: subject('Request for access declined'))
+ mail(to: @current_user.notification_email,
+ subject: subject("Access to #{@project.name_with_namespace} project was denied"))
end
-
def project_member_invited_email(project_member_id, token)
- @project_member = ProjectMember.find project_member_id
- @project = @project_member.project
- @token = token
+ setup_project_member_mail(project_member_id)
- @target_url = namespace_project_url(@project.namespace, @project)
+ @token = token
@current_user = @project_member.user
mail(to: @project_member.invite_email,
@@ -66,12 +40,9 @@ module Emails
end
def project_invite_accepted_email(project_member_id)
- @project_member = ProjectMember.find project_member_id
+ setup_project_member_mail(project_member_id)
return if @project_member.created_by.nil?
- @project = @project_member.project
-
- @target_url = namespace_project_url(@project.namespace, @project)
@current_user = @project_member.created_by
mail(to: @project_member.created_by.notification_email,
@@ -117,5 +88,13 @@ module Emails
reply_to: @message.reply_to,
subject: @message.subject)
end
+
+ private
+
+ def setup_project_member_mail(project_member_id)
+ @project_member = ProjectMember.find(project_member_id)
+ @project = @project_member.project
+ @target_url = namespace_project_url(@project.namespace, @project)
+ end
end
end