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