7b2ad2d5b9
1. Remove `master_or_greater?` and `developer_or_greater?` in favor of `max_member_access`, which is a lot nicer. 2. Remove a number of instances of `include Gitlab::Database::MigrationHelpers` in migrations that don't need this module. Also remove comments where not necessary. 3. Remove duplicate entry in CHANGELOG. 4. Move `ProtectedBranchAccessSelect` from Coffeescript to ES6. 5. Split the `set_access_levels!` method in two - one each for `merge` and `push` access levels.
29 lines
750 B
Ruby
29 lines
750 B
Ruby
class ProtectedBranch::MergeAccessLevel < ActiveRecord::Base
|
|
belongs_to :protected_branch
|
|
delegate :project, to: :protected_branch
|
|
|
|
enum access_level: [:masters, :developers]
|
|
|
|
def self.human_access_levels
|
|
{
|
|
"masters" => "Masters",
|
|
"developers" => "Developers + Masters"
|
|
}.with_indifferent_access
|
|
end
|
|
|
|
def check_access(user)
|
|
return true if user.is_admin?
|
|
|
|
min_member_access = if masters?
|
|
Gitlab::Access::MASTER
|
|
elsif developers?
|
|
Gitlab::Access::DEVELOPER
|
|
end
|
|
|
|
project.team.max_member_access(user.id) >= min_member_access
|
|
end
|
|
|
|
def humanize
|
|
self.class.human_access_levels[self.access_level]
|
|
end
|
|
end
|