summaryrefslogtreecommitdiff
path: root/app/services/protected_branches
diff options
context:
space:
mode:
authorTimothy Andrew <mail@timothyandrew.net>2016-07-07 13:06:28 +0530
committerTimothy Andrew <mail@timothyandrew.net>2016-07-29 15:20:39 +0530
commit134fe5af83167f95205a080f7932452de7d77496 (patch)
tree6f253ad95afc8fc0525c6501ce9345294dd1ff45 /app/services/protected_branches
parent21bece443d5f871680a3d7649c2d16861035196d (diff)
downloadgitlab-ce-134fe5af83167f95205a080f7932452de7d77496.tar.gz
Use the `{Push,Merge}AccessLevel` models in the UI.
1. Improve error handling while creating protected branches. 2. Modify coffeescript code so that the "Developers can *" checkboxes send a '1' or '0' even when using AJAX. This lets us keep the backend code simpler. 3. Use services for both creating and updating protected branches. Destruction is taken care of with `dependent: :destroy`
Diffstat (limited to 'app/services/protected_branches')
-rw-r--r--app/services/protected_branches/base_service.rb17
-rw-r--r--app/services/protected_branches/create_service.rb19
-rw-r--r--app/services/protected_branches/update_service.rb21
3 files changed, 57 insertions, 0 deletions
diff --git a/app/services/protected_branches/base_service.rb b/app/services/protected_branches/base_service.rb
new file mode 100644
index 00000000000..d4be8698a5f
--- /dev/null
+++ b/app/services/protected_branches/base_service.rb
@@ -0,0 +1,17 @@
+module ProtectedBranches
+ class BaseService < ::BaseService
+ def set_access_levels!
+ if params[:developers_can_push] == '0'
+ @protected_branch.push_access_level.masters!
+ elsif params[:developers_can_push] == '1'
+ @protected_branch.push_access_level.developers!
+ end
+
+ if params[:developers_can_merge] == '0'
+ @protected_branch.merge_access_level.masters!
+ elsif params[:developers_can_merge] == '1'
+ @protected_branch.merge_access_level.developers!
+ end
+ end
+ end
+end
diff --git a/app/services/protected_branches/create_service.rb b/app/services/protected_branches/create_service.rb
new file mode 100644
index 00000000000..743f7bd2ce1
--- /dev/null
+++ b/app/services/protected_branches/create_service.rb
@@ -0,0 +1,19 @@
+class ProtectedBranches::CreateService < BaseService
+ attr_reader :protected_branch
+
+ def execute
+ ProtectedBranch.transaction do
+ @protected_branch = project.protected_branches.new(name: params[:name])
+ @protected_branch.save!
+
+ @protected_branch.create_push_access_level!
+ @protected_branch.create_merge_access_level!
+
+ set_access_levels!
+ end
+
+ true
+ rescue ActiveRecord::RecordInvalid
+ false
+ end
+end
diff --git a/app/services/protected_branches/update_service.rb b/app/services/protected_branches/update_service.rb
new file mode 100644
index 00000000000..ed59b06b79a
--- /dev/null
+++ b/app/services/protected_branches/update_service.rb
@@ -0,0 +1,21 @@
+module ProtectedBranches
+ class UpdateService < BaseService
+ attr_reader :protected_branch
+
+ def initialize(project, current_user, id, params = {})
+ super(project, current_user, params)
+ @id = id
+ end
+
+ def execute
+ ProtectedBranch.transaction do
+ @protected_branch = ProtectedBranch.find(@id)
+ set_access_levels!
+ end
+
+ true
+ rescue ActiveRecord::RecordInvalid
+ false
+ end
+ end
+end