To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.
root / app / models / member.rb @ 912:5e80956cc792
History | View | Annotate | Download (2.97 KB)
| 1 | 0:513646585e45 | Chris | # Redmine - project management software
|
|---|---|---|---|
| 2 | 909:cbb26bc654de | Chris | # Copyright (C) 2006-2011 Jean-Philippe Lang
|
| 3 | 0:513646585e45 | Chris | #
|
| 4 | # This program is free software; you can redistribute it and/or
|
||
| 5 | # modify it under the terms of the GNU General Public License
|
||
| 6 | # as published by the Free Software Foundation; either version 2
|
||
| 7 | # of the License, or (at your option) any later version.
|
||
| 8 | 909:cbb26bc654de | Chris | #
|
| 9 | 0:513646585e45 | Chris | # This program is distributed in the hope that it will be useful,
|
| 10 | # but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
| 11 | # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||
| 12 | # GNU General Public License for more details.
|
||
| 13 | 909:cbb26bc654de | Chris | #
|
| 14 | 0:513646585e45 | Chris | # You should have received a copy of the GNU General Public License
|
| 15 | # along with this program; if not, write to the Free Software
|
||
| 16 | # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
| 17 | |||
| 18 | class Member < ActiveRecord::Base |
||
| 19 | belongs_to :user
|
||
| 20 | belongs_to :principal, :foreign_key => 'user_id' |
||
| 21 | has_many :member_roles, :dependent => :destroy |
||
| 22 | has_many :roles, :through => :member_roles |
||
| 23 | belongs_to :project
|
||
| 24 | |||
| 25 | validates_presence_of :principal, :project |
||
| 26 | validates_uniqueness_of :user_id, :scope => :project_id |
||
| 27 | |||
| 28 | after_destroy :unwatch_from_permission_change
|
||
| 29 | 909:cbb26bc654de | Chris | |
| 30 | 0:513646585e45 | Chris | def name |
| 31 | self.user.name
|
||
| 32 | end
|
||
| 33 | 909:cbb26bc654de | Chris | |
| 34 | 0:513646585e45 | Chris | alias :base_role_ids= :role_ids= |
| 35 | def role_ids=(arg) |
||
| 36 | ids = (arg || []).collect(&:to_i) - [0] |
||
| 37 | # Keep inherited roles
|
||
| 38 | ids += member_roles.select {|mr| !mr.inherited_from.nil?}.collect(&:role_id)
|
||
| 39 | 909:cbb26bc654de | Chris | |
| 40 | 0:513646585e45 | Chris | new_role_ids = ids - role_ids |
| 41 | # Add new roles
|
||
| 42 | new_role_ids.each {|id| member_roles << MemberRole.new(:role_id => id) }
|
||
| 43 | # Remove roles (Rails' #role_ids= will not trigger MemberRole#on_destroy)
|
||
| 44 | member_roles_to_destroy = member_roles.select {|mr| !ids.include?(mr.role_id)}
|
||
| 45 | if member_roles_to_destroy.any?
|
||
| 46 | member_roles_to_destroy.each(&:destroy)
|
||
| 47 | unwatch_from_permission_change |
||
| 48 | end
|
||
| 49 | end
|
||
| 50 | 909:cbb26bc654de | Chris | |
| 51 | 0:513646585e45 | Chris | def <=>(member) |
| 52 | a, b = roles.sort.first, member.roles.sort.first |
||
| 53 | a == b ? (principal <=> member.principal) : (a <=> b) |
||
| 54 | end
|
||
| 55 | 909:cbb26bc654de | Chris | |
| 56 | 0:513646585e45 | Chris | def deletable? |
| 57 | member_roles.detect {|mr| mr.inherited_from}.nil?
|
||
| 58 | end
|
||
| 59 | 909:cbb26bc654de | Chris | |
| 60 | 0:513646585e45 | Chris | def include?(user) |
| 61 | if principal.is_a?(Group) |
||
| 62 | !user.nil? && user.groups.include?(principal) |
||
| 63 | else
|
||
| 64 | self.user == user
|
||
| 65 | end
|
||
| 66 | end
|
||
| 67 | 909:cbb26bc654de | Chris | |
| 68 | 0:513646585e45 | Chris | def before_destroy |
| 69 | if user
|
||
| 70 | # remove category based auto assignments for this member
|
||
| 71 | IssueCategory.update_all "assigned_to_id = NULL", ["project_id = ? AND assigned_to_id = ?", project.id, user.id] |
||
| 72 | end
|
||
| 73 | end
|
||
| 74 | |||
| 75 | # Find or initilize a Member with an id, attributes, and for a Principal
|
||
| 76 | def self.edit_membership(id, new_attributes, principal=nil) |
||
| 77 | @membership = id.present? ? Member.find(id) : Member.new(:principal => principal) |
||
| 78 | @membership.attributes = new_attributes
|
||
| 79 | @membership
|
||
| 80 | end
|
||
| 81 | 909:cbb26bc654de | Chris | |
| 82 | 0:513646585e45 | Chris | protected |
| 83 | 909:cbb26bc654de | Chris | |
| 84 | 0:513646585e45 | Chris | def validate |
| 85 | 14:1d32c0a0efbf | Chris | errors.add_on_empty :role if member_roles.empty? && roles.empty? |
| 86 | 0:513646585e45 | Chris | end
|
| 87 | 909:cbb26bc654de | Chris | |
| 88 | 0:513646585e45 | Chris | private |
| 89 | 909:cbb26bc654de | Chris | |
| 90 | 0:513646585e45 | Chris | # Unwatch things that the user is no longer allowed to view inside project
|
| 91 | def unwatch_from_permission_change |
||
| 92 | if user
|
||
| 93 | Watcher.prune(:user => user, :project => project) |
||
| 94 | end
|
||
| 95 | end
|
||
| 96 | end |