gitlabhq/app/models/users_project.rb

103 lines
2.5 KiB
Ruby
Raw Normal View History

2011-10-09 00:36:38 +03:00
class UsersProject < ActiveRecord::Base
include GitHost
2012-02-16 09:03:55 +02:00
GUEST = 10
REPORTER = 20
DEVELOPER = 30
MASTER = 40
2012-02-15 23:51:04 +02:00
2011-10-09 00:36:38 +03:00
belongs_to :user
belongs_to :project
attr_protected :project_id, :project
after_save :update_repository
after_destroy :update_repository
2011-10-09 00:36:38 +03:00
validates_uniqueness_of :user_id, scope: [:project_id], message: "already exists in project"
2011-10-09 00:36:38 +03:00
validates_presence_of :user_id
validates_presence_of :project_id
delegate :name, :email, to: :user, prefix: true
2011-10-09 00:36:38 +03:00
def self.bulk_delete(project, user_ids)
UsersProject.transaction do
UsersProject.where(:user_id => user_ids, :project_id => project.id).each do |users_project|
2012-09-10 00:27:47 +03:00
users_project.destroy
end
end
end
def self.bulk_update(project, user_ids, project_access)
UsersProject.transaction do
UsersProject.where(:user_id => user_ids, :project_id => project.id).each do |users_project|
users_project.project_access = project_access
users_project.save
end
end
end
2012-03-06 00:26:40 +02:00
def self.bulk_import(project, user_ids, project_access)
UsersProject.transaction do
user_ids.each do |user_id|
users_project = UsersProject.new(
project_access: project_access,
user_id: user_id
)
users_project.project = project
users_project.save
end
end
end
2012-03-06 00:26:40 +02:00
def self.user_bulk_import(user, project_ids, project_access)
2012-02-11 19:56:18 +02:00
UsersProject.transaction do
project_ids.each do |project_id|
users_project = UsersProject.new(
project_access: project_access,
2012-02-11 19:56:18 +02:00
)
users_project.project_id = project_id
users_project.user_id = user.id
users_project.save
end
end
end
2012-02-15 23:51:04 +02:00
def self.access_roles
{
"Guest" => GUEST,
"Reporter" => REPORTER,
2012-02-15 23:51:04 +02:00
"Developer" => DEVELOPER,
"Master" => MASTER
2012-02-15 23:51:04 +02:00
}
end
def role_access
2012-02-16 09:03:55 +02:00
project_access
2012-02-15 23:51:04 +02:00
end
2011-12-05 09:43:53 +02:00
def update_repository
git_host.update_repository(project)
2011-10-09 00:36:38 +03:00
end
2012-02-05 21:26:04 +02:00
def project_access_human
Project.access_options.key(self.project_access)
end
def repo_access_human
2012-07-15 15:29:06 +03:00
self.class.access_roles.invert[self.project_access]
2012-02-05 21:26:04 +02:00
end
2011-10-09 00:36:38 +03:00
end
# == Schema Information
#
# Table name: users_projects
#
2012-06-26 21:23:09 +03:00
# id :integer(4) not null, primary key
# user_id :integer(4) not null
# project_id :integer(4) not null
# created_at :datetime not null
# updated_at :datetime not null
# project_access :integer(4) default(0), not null
2011-10-09 00:36:38 +03:00
#