class GroupMember < Member SOURCE_TYPE = 'Namespace'.freeze belongs_to :group, foreign_key: 'source_id' # Make sure group member points only to group as it source default_value_for :source_type, SOURCE_TYPE validates :source_type, format: { with: /\ANamespace\z/ } default_scope { where(source_type: SOURCE_TYPE) } def self.access_level_roles Gitlab::Access.options_with_owner end def self.access_levels Gitlab::Access.sym_options_with_owner end def self.add_users_to_group(group, users, access_level, current_user: nil, expires_at: nil) self.transaction do add_users_to_source( group, users, access_level, current_user: current_user, expires_at: expires_at ) end end def group source end def access_field access_level end # Because source_type is `Namespace`... def real_source_type 'Group' end private def send_invite notification_service.invite_group_member(self, @raw_invite_token) super end def post_create_hook notification_service.new_group_member(self) super end def post_update_hook if access_level_changed? notification_service.update_group_member(self) end super end def after_accept_invite notification_service.accept_group_invite(self) super end def after_decline_invite notification_service.decline_group_invite(self) super end end