gitlab-org--gitlab-foss/app/models/project_team.rb

208 lines
4.5 KiB
Ruby
Raw Normal View History

2013-01-19 18:52:55 +00:00
class ProjectTeam
2013-01-03 19:09:18 +00:00
attr_accessor :project
def initialize(project)
@project = project
end
# Shortcut to add users
#
# Use:
# @team << [@user, :master]
# @team << [@users, :master]
#
def <<(args)
users, access, current_user = *args
if users.respond_to?(:each)
add_users(users, access, current_user: current_user)
else
add_user(users, access, current_user: current_user)
end
2013-01-03 19:09:18 +00:00
end
def add_guest(user, current_user: nil)
self << [user, :guest, current_user]
end
def add_reporter(user, current_user: nil)
self << [user, :reporter, current_user]
end
def add_developer(user, current_user: nil)
self << [user, :developer, current_user]
end
def add_master(user, current_user: nil)
self << [user, :master, current_user]
end
2015-03-13 15:23:45 +00:00
def find_member(user_id)
member = project.members.find_by(user_id: user_id)
# If user is not in project members
# we should check for group membership
2015-03-13 15:23:45 +00:00
if group && !member
member = group.members.find_by(user_id: user_id)
end
2015-03-13 15:23:45 +00:00
member
2013-01-22 17:45:13 +00:00
end
def add_users(users, access_level, current_user: nil, expires_at: nil)
ProjectMember.add_users(
project,
users,
access_level,
current_user: current_user,
expires_at: expires_at
2013-01-03 19:09:18 +00:00
)
end
def add_user(user, access_level, current_user: nil, expires_at: nil)
ProjectMember.add_user(
project,
user,
access_level,
current_user: current_user,
expires_at: expires_at
)
end
2013-01-03 19:09:18 +00:00
# Remove all users from project team
def truncate
ProjectMember.truncate_team(project)
2013-01-03 19:09:18 +00:00
end
def members
2013-06-22 09:57:05 +00:00
@members ||= fetch_members
2013-01-03 19:09:18 +00:00
end
alias_method :users, :members
2013-01-03 19:09:18 +00:00
def guests
@guests ||= fetch_members(Gitlab::Access::GUEST)
2013-01-03 19:09:18 +00:00
end
def reporters
@reporters ||= fetch_members(Gitlab::Access::REPORTER)
2013-01-03 19:09:18 +00:00
end
def developers
@developers ||= fetch_members(Gitlab::Access::DEVELOPER)
2013-01-03 19:09:18 +00:00
end
def masters
@masters ||= fetch_members(Gitlab::Access::MASTER)
2013-01-03 19:09:18 +00:00
end
def import(source_project, current_user = nil)
target_project = project
2015-03-13 15:23:45 +00:00
source_members = source_project.project_members.to_a
target_user_ids = target_project.project_members.pluck(:user_id)
2015-03-13 15:23:45 +00:00
source_members.reject! do |member|
# Skip if user already present in team
2015-04-10 13:26:53 +00:00
!member.invite? && target_user_ids.include?(member.user_id)
end
2015-03-13 15:23:45 +00:00
source_members.map! do |member|
new_member = member.dup
new_member.id = nil
new_member.source = target_project
new_member.created_by = current_user
2015-03-13 15:23:45 +00:00
new_member
end
ProjectMember.transaction do
2015-03-13 15:23:45 +00:00
source_members.each do |member|
member.save
end
end
true
rescue
false
end
def guest?(user)
2015-03-13 15:23:45 +00:00
max_member_access(user.id) == Gitlab::Access::GUEST
end
def reporter?(user)
2015-03-13 15:23:45 +00:00
max_member_access(user.id) == Gitlab::Access::REPORTER
end
def developer?(user)
2015-03-13 15:23:45 +00:00
max_member_access(user.id) == Gitlab::Access::DEVELOPER
end
def master?(user)
2015-03-13 15:23:45 +00:00
max_member_access(user.id) == Gitlab::Access::MASTER
end
# Checks if `user` is authorized for this project, with at least the
# `min_access_level` (if given).
def member?(user, min_access_level = Gitlab::Access::GUEST)
return false unless user
max_member_access(user.id) >= min_access_level
2014-10-08 13:44:25 +00:00
end
def human_max_access(user_id)
Gitlab::Access.human_access(max_member_access(user_id))
end
# Determine the maximum access level for a group of users in bulk.
#
2016-07-27 00:07:51 +00:00
# Returns a Hash mapping user ID -> maximum access level.
def max_member_access_for_user_ids(user_ids)
user_ids = user_ids.uniq
key = "max_member_access:#{project.id}"
access = {}
if RequestStore.active?
RequestStore.store[key] ||= {}
access = RequestStore.store[key]
end
# Look up only the IDs we need
user_ids = user_ids - access.keys
return access if user_ids.empty?
2017-06-21 13:48:12 +00:00
users_access = project.project_authorizations
.where(user: user_ids)
.group(:user_id)
.maximum(:access_level)
access.merge!(users_access)
missing_user_ids = user_ids - users_access.keys
missing_user_ids.each do |user_id|
access[user_id] = Gitlab::Access::NO_ACCESS
end
access
end
def max_member_access(user_id)
max_member_access_for_user_ids([user_id])[user_id] || Gitlab::Access::NO_ACCESS
end
private
def fetch_members(level = nil)
members = project.authorized_users
members = members.where(project_authorizations: { access_level: level }) if level
members
end
def group
project.group
end
2013-01-03 19:09:18 +00:00
end