All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.sonar.db.component.ComponentMapper Maven / Gradle / Ivy

/*
 * SonarQube
 * Copyright (C) 2009-2016 SonarSource SA
 * mailto:contact AT sonarsource DOT com
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 3 of the License, or (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public License
 * along with this program; if not, write to the Free Software Foundation,
 * Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 */
package org.sonar.db.component;

import java.util.Collection;
import java.util.List;
import java.util.Map;
import javax.annotation.CheckForNull;
import javax.annotation.Nullable;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.session.RowBounds;

/**
 * @since 4.3
 */
public interface ComponentMapper {

  @CheckForNull
  ComponentDto selectByKey(String key);

  @CheckForNull
  ComponentDto selectById(long id);

  @CheckForNull
  ComponentDto selectByUuid(String uuid);

  /**
   * Return sub project of component keys
   */
  List selectSubProjectsByComponentUuids(@Param("uuids") Collection uuids);

  List selectByKeys(@Param("keys") Collection keys);

  List selectByIds(@Param("ids") Collection ids);

  List selectByUuids(@Param("uuids") Collection uuids);

  List selectByProjectUuid(@Param("projectUuid") String projectUuid);

  List selectExistingUuids(@Param("uuids") Collection uuids);

  List selectComponentsByQualifiers(@Param("qualifiers") Collection qualifiers);

  List selectByQuery(@Param("query") ComponentQuery query, RowBounds rowBounds);

  int countByQuery(@Param("query") ComponentQuery query);

  /**
   * Return direct children components
   */
  List selectDirectChildren(@Param("query") ComponentTreeQuery componentTreeQuery, RowBounds rowBounds);

  int countDirectChildren(@Param("query") ComponentTreeQuery componentTreeQuery);

  /**
   * Return all children components.
   */
  List selectAllChildren(@Param("query") ComponentTreeQuery componentTreeQuery,
                                       RowBounds rowBounds);

  int countAllChildren(@Param("query") ComponentTreeQuery componentTreeQuery);

  /**
   * Return all project (PRJ/TRK) uuids
   */
  List selectProjectUuids();

  /**
   * Returns all enabled projects (Scope {@link org.sonar.api.resources.Scopes#PROJECT} and qualifier
   * {@link org.sonar.api.resources.Qualifiers#PROJECT}) no matter if they are ghost project, provisioned projects or
   * regular ones.
   */
  List selectProjects();

  List selectComponents(Map parameters, RowBounds rowBounds);

  int countRootComponents(Map parameters);

  /**
   * Return all descendant modules (including itself) from a given component uuid and scope
   */
  List selectDescendantModules(@Param("moduleUuid") String moduleUuid, @Param(value = "scope") String scope,
    @Param(value = "excludeDisabled") boolean excludeDisabled);

  /**
   * Return all files from a given project uuid and scope
   */
  List selectEnabledFilesFromProject(@Param("projectUuid") String projectUuid);

  /**
   * Return all descendant files from a given module uuid and scope
   */
  List selectDescendantFiles(@Param("moduleUuid") String moduleUuid, @Param(value = "scope") String scope,
    @Param(value = "excludeDisabled") boolean excludeDisabled);

  /**
   * Return uuids and project uuids from list of qualifiers
   * 

* It's using a join on snapshots in order to use he indexed columns snapshots.qualifier */ List selectUuidsForQualifiers(@Param("qualifiers") String... qualifiers); /** * Return components of a given scope of a project * * @param scope scope of components to return. If null, all components are returned */ List selectComponentsFromProjectKeyAndScope(@Param("projectKey") String projectKey, @Nullable @Param("scope") String scope, @Param(value = "excludeDisabled") boolean excludeDisabled); /** * Return technical projects from a view or a sub-view */ List selectProjectsFromView(@Param("viewUuidLikeQuery") String viewUuidLikeQuery, @Param("projectViewUuid") String projectViewUuid); long countById(long id); List selectProvisionedProjects(Map parameters, RowBounds rowBounds); int countProvisionedProjects(Map parameters); List selectGhostProjects(Map parameters, RowBounds rowBounds); List selectComponentsHavingSameKeyOrderedById(String key); long countGhostProjects(Map parameters); void insert(ComponentDto componentDto); void insertBatch(ComponentDto componentDto); void update(ComponentDto componentDto); void delete(long componentId); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy