Skip to content
Snippets Groups Projects
project_team.rb 4.36 KiB
Newer Older
  • Learn to ignore specific revisions
  • class ProjectTeam
    
      attr_accessor :project
    
      def initialize(project)
        @project = project
    
      end
    
      # Shortcut to add users
      #
      # Use:
      #   @team << [@user, :master]
      #   @team << [@users, :master]
      #
    
        users, access, current_user = *args
    
    
        if users.respond_to?(:each)
    
          add_users(users, access, current_user: current_user)
    
          add_user(users, access, current_user: current_user)
    
      def add_guest(user, current_user: nil)
        self << [user, :guest, current_user]
      end
    
      def add_reporter(user, current_user: nil)
        self << [user, :reporter, current_user]
      end
    
      def add_developer(user, current_user: nil)
        self << [user, :developer, current_user]
      end
    
      def add_master(user, current_user: nil)
        self << [user, :master, current_user]
      end
    
    
      def find_member(user_id)
    
        member = project.members.find_by(user_id: user_id)
    
    
        # If user is not in project members
        # we should check for group membership
    
        if group && !member
    
          member = group.members.find_by(user_id: user_id)
    
        member
    
      def add_users(users, access_level, current_user: nil, expires_at: nil)
    
        ProjectMember.add_users_to_projects(
    
          [project.id],
    
          current_user: current_user,
          expires_at: expires_at
    
      def add_user(user, access_level, current_user: nil, expires_at: nil)
        ProjectMember.add_user(
          project,
          user,
          access_level,
          current_user: current_user,
          expires_at: expires_at
        )
    
      # Remove all users from project team
      def truncate
    
        ProjectMember.truncate_team(project)
    
      end
    
      def members
    
        @members ||= fetch_members
    
      alias_method :users, :members
    
    
      def guests
    
        @guests ||= fetch_members(Gitlab::Access::GUEST)
    
      end
    
      def reporters
    
        @reporters ||= fetch_members(Gitlab::Access::REPORTER)
    
      end
    
      def developers
    
        @developers ||= fetch_members(Gitlab::Access::DEVELOPER)
    
      end
    
      def masters
    
        @masters ||= fetch_members(Gitlab::Access::MASTER)
    
      def import(source_project, current_user = nil)
    
        target_project = project
    
    
        source_members = source_project.project_members.to_a
    
        target_user_ids = target_project.project_members.pluck(:user_id)
    
        source_members.reject! do |member|
    
          # Skip if user already present in team
    
          !member.invite? && target_user_ids.include?(member.user_id)
    
        source_members.map! do |member|
          new_member = member.dup
          new_member.id = nil
          new_member.source = target_project
    
          new_member.created_by = current_user
    
          new_member
    
          source_members.each do |member|
            member.save
    
        max_member_access(user.id) == Gitlab::Access::GUEST
    
        max_member_access(user.id) == Gitlab::Access::REPORTER
    
        max_member_access(user.id) == Gitlab::Access::DEVELOPER
    
        max_member_access(user.id) == Gitlab::Access::MASTER
    
      # Checks if `user` is authorized for this project, with at least the
      # `min_access_level` (if given).
      def member?(user, min_access_level = Gitlab::Access::GUEST)
        return false unless user
    
        user.authorized_project?(project, min_access_level)
    
      def human_max_access(user_id)
        Gitlab::Access.options_with_owner.key(max_member_access(user_id))
      end
    
    
      # Determine the maximum access level for a group of users in bulk.
      #
    
    Stan Hu's avatar
    Stan Hu committed
      # Returns a Hash mapping user ID -> maximum access level.
    
      def max_member_access_for_user_ids(user_ids)
        user_ids = user_ids.uniq
        key = "max_member_access:#{project.id}"
    
    
        access = {}
    
        if RequestStore.active?
          RequestStore.store[key] ||= {}
          access = RequestStore.store[key]
        end
    
        # Lookup only the IDs we need
        user_ids = user_ids - access.keys
    
        users_access = project.project_authorizations.
          where(user: user_ids).
          group(:user_id).
          maximum(:access_level)
    
        access
      end
    
      def max_member_access(user_id)
    
        max_member_access_for_user_ids([user_id])[user_id] || Gitlab::Access::NO_ACCESS
    
        members = project.authorized_users
        members = members.where(project_authorizations: { access_level: level }) if level