per request project rules caching
This commit is contained in:
parent
a5cbb4cb82
commit
8ec02ed9aa
3 changed files with 33 additions and 28 deletions
1
Gemfile
1
Gemfile
|
@ -174,6 +174,7 @@ gem "font-awesome-rails", '~> 3.2'
|
|||
gem "gitlab_emoji", "~> 0.0.1.1"
|
||||
gem "gon", '~> 5.0.0'
|
||||
gem 'nprogress-rails'
|
||||
gem 'request_store'
|
||||
|
||||
group :development do
|
||||
gem "annotate", "~> 2.6.0.beta2"
|
||||
|
|
|
@ -412,6 +412,7 @@ GEM
|
|||
redis-store (1.1.4)
|
||||
redis (>= 2.2)
|
||||
ref (1.0.5)
|
||||
request_store (1.0.5)
|
||||
require_all (1.3.2)
|
||||
rest-client (1.6.7)
|
||||
mime-types (>= 1.16)
|
||||
|
@ -650,6 +651,7 @@ DEPENDENCIES
|
|||
rb-inotify
|
||||
redcarpet (~> 2.2.2)
|
||||
redis-rails
|
||||
request_store
|
||||
rspec-rails
|
||||
sanitize (~> 2.0)
|
||||
sass-rails (~> 4.0.2)
|
||||
|
|
|
@ -67,40 +67,42 @@ class Ability
|
|||
|
||||
def project_abilities(user, project)
|
||||
rules = []
|
||||
key = "/user/#{user.id}/project/#{project.id}"
|
||||
RequestStore.store[key] ||= begin
|
||||
team = project.team
|
||||
|
||||
team = project.team
|
||||
# Rules based on role in project
|
||||
if team.master?(user)
|
||||
rules += project_master_rules
|
||||
|
||||
# Rules based on role in project
|
||||
if team.master?(user)
|
||||
rules += project_master_rules
|
||||
elsif team.developer?(user)
|
||||
rules += project_dev_rules
|
||||
|
||||
elsif team.developer?(user)
|
||||
rules += project_dev_rules
|
||||
elsif team.reporter?(user)
|
||||
rules += project_report_rules
|
||||
|
||||
elsif team.reporter?(user)
|
||||
rules += project_report_rules
|
||||
elsif team.guest?(user)
|
||||
rules += project_guest_rules
|
||||
end
|
||||
|
||||
elsif team.guest?(user)
|
||||
rules += project_guest_rules
|
||||
if project.public? || project.internal?
|
||||
rules += public_project_rules
|
||||
end
|
||||
|
||||
if project.owner == user || user.admin?
|
||||
rules += project_admin_rules
|
||||
end
|
||||
|
||||
if project.group && project.group.has_owner?(user)
|
||||
rules += project_admin_rules
|
||||
end
|
||||
|
||||
if project.archived?
|
||||
rules -= project_archived_rules
|
||||
end
|
||||
|
||||
rules
|
||||
end
|
||||
|
||||
if project.public? || project.internal?
|
||||
rules += public_project_rules
|
||||
end
|
||||
|
||||
if project.owner == user || user.admin?
|
||||
rules += project_admin_rules
|
||||
end
|
||||
|
||||
if project.group && project.group.has_owner?(user)
|
||||
rules += project_admin_rules
|
||||
end
|
||||
|
||||
if project.archived?
|
||||
rules -= project_archived_rules
|
||||
end
|
||||
|
||||
rules
|
||||
end
|
||||
|
||||
def public_project_rules
|
||||
|
|
Loading…
Reference in a new issue