rosa-build/app/models/group.rb

67 lines
2.1 KiB
Ruby
Raw Normal View History

class Group < Avatar
include ActsLikeMember
include PersonalRepository
2014-01-21 04:51:49 +00:00
belongs_to :owner, class_name: 'User'
2014-01-21 04:51:49 +00:00
has_many :relations, as: :actor, dependent: :destroy, dependent: :destroy
has_many :actors, as: :target, class_name: 'Relation', dependent: :destroy
has_many :targets, as: :actor, class_name: 'Relation', dependent: :destroy
2014-01-21 04:51:49 +00:00
has_many :members, through: :actors, source: :actor, source_type: 'User', autosave: true
has_many :projects, through: :targets, source: :target, source_type: 'Project', autosave: true
2014-01-21 04:51:49 +00:00
has_many :own_projects, as: :owner, class_name: 'Project', dependent: :destroy
has_many :own_platforms, as: :owner, class_name: 'Platform', dependent: :destroy
2011-10-16 21:39:45 +01:00
2014-01-21 04:51:49 +00:00
validates :owner, presence: true
validates :uname, presence: true, uniqueness: {case_sensitive: false}, format: {with: /\A[a-z0-9_]+\z/}, reserved_name: true
validate { errors.add(:uname, :taken) if User.by_uname(uname).present? }
scope :opened, -> { scoped }
scope :by_owner, ->(owner) { where(owner_id: owner.id) }
scope :by_admin, ->(admin) {
joins(:actors).where('relations.role' => 'admin', 'relations.actor_id' => admin.id, 'relations.actor_type' => 'User')
}
scope :by_admin_and_writer, ->(actor) {
joins(:actors).where('relations.role' => ['admin', 'writer'], 'relations.actor_id' => actor.id, 'relations.actor_type' => 'User')
}
attr_accessible :uname, :description
attr_readonly :uname
delegate :email, :user_appeal, to: :owner
2011-10-18 16:00:06 +01:00
2011-11-30 15:27:19 +00:00
after_create :add_owner_to_members
def self.can_own_project(user)
(by_owner(user) | by_admin_and_writer(user))
end
2012-03-02 10:39:48 +00:00
def name
uname
end
def add_member(member, role = 'admin')
2012-10-17 14:46:16 +01:00
Relation.add_member(member, self, role, :actors)
end
def remove_member(member)
Relation.remove_member(member, self)
end
2012-12-27 18:27:50 +00:00
def system?
false
end
def fullname
return description.present? ? "#{uname} (#{description})" : uname
end
2011-11-30 15:27:19 +00:00
protected
def add_owner_to_members
2014-01-21 04:51:49 +00:00
Relation.create_with_role(self.owner, self, 'admin') # members << self.owner if !members.exists?(id: self.owner.id)
end
end