gitlabhq/app/models/users_project.rb

71 lines
1.8 KiB
Ruby
Raw Normal View History

2011-10-09 00:36:38 +03:00
class UsersProject < ActiveRecord::Base
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]
validates_presence_of :user_id
validates_presence_of :project_id
2011-10-09 00:36:38 +03:00
delegate :name, :email, :to => :user, :prefix => true
def self.bulk_import(project, user_ids, project_access, repo_access)
UsersProject.transaction do
user_ids.each do |user_id|
users_project = UsersProject.new(
:repo_access => repo_access,
:project_access => project_access,
:user_id => user_id
)
users_project.project = project
users_project.save
end
end
end
2012-02-11 19:56:18 +02:00
def self.user_bulk_import(user, project_ids, project_access, repo_access)
UsersProject.transaction do
project_ids.each do |project_id|
users_project = UsersProject.new(
:repo_access => repo_access,
:project_access => project_access,
)
users_project.project_id = project_id
users_project.user_id = user.id
users_project.save
end
end
end
2011-12-05 09:43:53 +02:00
def update_repository
Gitlabhq::GitHost.system.new.configure do |c|
c.update_project(project.path, project)
2011-10-09 00:36:38 +03:00
end
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
Repository.access_options.key(self.repo_access)
end
2011-10-09 00:36:38 +03:00
end
# == Schema Information
#
# Table name: users_projects
#
2011-12-18 16:09:16 +02:00
# id :integer not null, primary key
# user_id :integer not null
# project_id :integer not null
# created_at :datetime
# updated_at :datetime
# repo_access :integer default(0), not null
# project_access :integer default(0), not null
2011-10-09 00:36:38 +03:00
#