# == Schema Information # # Table name: members # # id :integer not null, primary key # access_level :integer not null # source_id :integer not null # source_type :string(255) not null # user_id :integer not null # notification_level :integer not null # type :string(255) # created_at :datetime # updated_at :datetime # class GroupMember < Member SOURCE_TYPE = 'Namespace' belongs_to :group, class_name: 'Group', foreign_key: 'source_id' # Make sure group member points only to group as it source default_value_for :source_type, SOURCE_TYPE default_value_for :notification_level, Notification::N_GLOBAL validates_format_of :source_type, with: /\ANamespace\z/ default_scope { where(source_type: SOURCE_TYPE) } scope :with_group, ->(group) { where(source_id: group.id) } scope :with_user, ->(user) { where(user_id: user.id) } after_create :post_create_hook after_update :notify_update after_destroy :post_destroy_hook def self.access_level_roles Gitlab::Access.options_with_owner end def group source end def access_field access_level end def post_create_hook notification_service.new_group_member(self) system_hook_service.execute_hooks_for(self, :create) end def notify_update if access_level_changed? notification_service.update_group_member(self) end end def post_destroy_hook system_hook_service.execute_hooks_for(self, :destroy) end def system_hook_service SystemHooksService.new end def notification_service NotificationService.new end end