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