Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/app
diff options
context:
space:
mode:
authorLin Jen-Shin <godfat@godfat.org>2016-11-16 15:31:08 +0300
committerLin Jen-Shin <godfat@godfat.org>2016-11-16 15:31:23 +0300
commita9765fb47fbbd1e1070434fc06cc76b25a42caa6 (patch)
tree30ffc7e93c5721c6ac7743daf6f705a4566efa98 /app
parent721478123068c6718ec73c72a7b7d32c00c816df (diff)
Introduce has_access_to? so that we could reuse it
Feedback: https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/7383#note_18439108
Diffstat (limited to 'app')
-rw-r--r--app/helpers/projects_helper.rb4
-rw-r--r--app/models/deploy_key.rb6
-rw-r--r--app/models/user.rb4
3 files changed, 11 insertions, 3 deletions
diff --git a/app/helpers/projects_helper.rb b/app/helpers/projects_helper.rb
index 42c00ec3cd5..5b08fc78cfc 100644
--- a/app/helpers/projects_helper.rb
+++ b/app/helpers/projects_helper.rb
@@ -93,10 +93,10 @@ module ProjectsHelper
end
def project_for_deploy_key(deploy_key)
- if deploy_key.projects.include?(@project)
+ if deploy_key.has_access_to?(@project)
@project
else
- deploy_key.projects.find { |project| can?(current_user, :read_project, project) }
+ deploy_key.projects.find(&current_user.method(:has_access_to?))
end
end
diff --git a/app/models/deploy_key.rb b/app/models/deploy_key.rb
index 503398f5cca..aaacbd28470 100644
--- a/app/models/deploy_key.rb
+++ b/app/models/deploy_key.rb
@@ -21,7 +21,11 @@ class DeployKey < Key
self.private?
end
+ def has_access_to?(project)
+ projects.include?(project)
+ end
+
def can_push_to?(project)
- can_push? && projects.include?(project)
+ can_push? && has_access_to?(project)
end
end
diff --git a/app/models/user.rb b/app/models/user.rb
index 3813df6684e..0e96ad88638 100644
--- a/app/models/user.rb
+++ b/app/models/user.rb
@@ -501,6 +501,10 @@ class User < ActiveRecord::Base
several_namespaces? || admin
end
+ def has_access_to?(project)
+ can?(:read_project, project)
+ end
+
def can?(action, subject)
Ability.allowed?(self, action, subject)
end