2013-01-31 09:11:35 +02:00
|
|
|
# == Schema Information
|
|
|
|
#
|
|
|
|
# Table name: user_teams
|
|
|
|
#
|
2013-03-15 15:16:02 +02:00
|
|
|
# id :integer not null, primary key
|
|
|
|
# name :string(255)
|
|
|
|
# path :string(255)
|
|
|
|
# owner_id :integer
|
|
|
|
# created_at :datetime not null
|
|
|
|
# updated_at :datetime not null
|
|
|
|
# description :string(255) default(""), not null
|
2013-01-31 09:11:35 +02:00
|
|
|
#
|
|
|
|
|
2013-01-19 21:06:50 +04:00
|
|
|
class UserTeam < ActiveRecord::Base
|
2013-02-07 15:10:14 +04:00
|
|
|
attr_accessible :name, :description, :owner_id, :path
|
2013-01-19 21:06:50 +04:00
|
|
|
|
|
|
|
belongs_to :owner, class_name: User
|
|
|
|
|
|
|
|
has_many :user_team_project_relationships, dependent: :destroy
|
|
|
|
has_many :user_team_user_relationships, dependent: :destroy
|
|
|
|
|
|
|
|
has_many :projects, through: :user_team_project_relationships
|
|
|
|
has_many :members, through: :user_team_user_relationships, source: :user
|
|
|
|
|
|
|
|
validates :owner, presence: true
|
2013-02-18 09:28:18 +02:00
|
|
|
validates :name, presence: true, uniqueness: true,
|
|
|
|
length: { within: 0..255 },
|
|
|
|
format: { with: Gitlab::Regex.name_regex,
|
|
|
|
message: "only letters, digits, spaces & '_' '-' '.' allowed." }
|
2013-02-07 15:10:14 +04:00
|
|
|
validates :description, length: { within: 0..255 }
|
2013-01-19 21:06:50 +04:00
|
|
|
validates :path, uniqueness: true, presence: true, length: { within: 1..255 },
|
|
|
|
format: { with: Gitlab::Regex.path_regex,
|
|
|
|
message: "only letters, digits & '_' '-' '.' allowed. Letter should be first" }
|
|
|
|
|
|
|
|
scope :with_member, ->(user){ joins(:user_team_user_relationships).where(user_team_user_relationships: {user_id: user.id}) }
|
2013-01-23 18:14:20 +04:00
|
|
|
scope :with_project, ->(project){ joins(:user_team_project_relationships).where(user_team_project_relationships: {project_id: project})}
|
2013-01-24 11:19:09 +02:00
|
|
|
scope :without_project, ->(project){ where("user_teams.id NOT IN (:ids)", ids: (a = with_project(project); a.blank? ? 0 : a))}
|
2013-01-19 21:06:50 +04:00
|
|
|
scope :created_by, ->(user){ where(owner_id: user) }
|
|
|
|
|
|
|
|
class << self
|
|
|
|
def search query
|
|
|
|
where("name LIKE :query OR path LIKE :query", query: "%#{query}%")
|
|
|
|
end
|
|
|
|
|
|
|
|
def global_id
|
|
|
|
'GLN'
|
|
|
|
end
|
|
|
|
|
|
|
|
def access_roles
|
|
|
|
UsersProject.access_roles
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def to_param
|
|
|
|
path
|
|
|
|
end
|
|
|
|
|
|
|
|
def assign_to_projects(projects, access)
|
|
|
|
projects.each do |project|
|
|
|
|
assign_to_project(project, access)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def assign_to_project(project, access)
|
|
|
|
Gitlab::UserTeamManager.assign(self, project, access)
|
|
|
|
end
|
|
|
|
|
|
|
|
def resign_from_project(project)
|
|
|
|
Gitlab::UserTeamManager.resign(self, project)
|
|
|
|
end
|
|
|
|
|
|
|
|
def add_members(users, access, group_admin)
|
2013-03-13 22:32:04 +02:00
|
|
|
# reject existing users
|
|
|
|
users.reject! { |id| member_ids.include?(id.to_i) }
|
|
|
|
|
2013-01-19 21:06:50 +04:00
|
|
|
users.each do |user|
|
|
|
|
add_member(user, access, group_admin)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def add_member(user, access, group_admin)
|
|
|
|
Gitlab::UserTeamManager.add_member_into_team(self, user, access, group_admin)
|
|
|
|
end
|
|
|
|
|
|
|
|
def remove_member(user)
|
|
|
|
Gitlab::UserTeamManager.remove_member_from_team(self, user)
|
|
|
|
end
|
|
|
|
|
2013-01-20 15:25:16 +04:00
|
|
|
def update_membership(user, options)
|
|
|
|
Gitlab::UserTeamManager.update_team_user_membership(self, user, options)
|
|
|
|
end
|
|
|
|
|
2013-01-21 01:03:29 +04:00
|
|
|
def update_project_access(project, permission)
|
|
|
|
Gitlab::UserTeamManager.update_project_greates_access(self, project, permission)
|
|
|
|
end
|
|
|
|
|
2013-01-19 21:06:50 +04:00
|
|
|
def max_project_access(project)
|
|
|
|
user_team_project_relationships.find_by_project_id(project).greatest_access
|
|
|
|
end
|
|
|
|
|
|
|
|
def human_max_project_access(project)
|
|
|
|
self.class.access_roles.invert[max_project_access(project)]
|
|
|
|
end
|
|
|
|
|
|
|
|
def default_projects_access(member)
|
|
|
|
user_team_user_relationships.find_by_user_id(member).permission
|
|
|
|
end
|
|
|
|
|
|
|
|
def human_default_projects_access(member)
|
|
|
|
self.class.access_roles.invert[default_projects_access(member)]
|
|
|
|
end
|
|
|
|
|
|
|
|
def admin?(member)
|
|
|
|
user_team_user_relationships.with_user(member).first.group_admin?
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|