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

net.nemerosa.ontrack.model.structure.StructureService.kt Maven / Gradle / Ivy

package net.nemerosa.ontrack.model.structure

import net.nemerosa.ontrack.common.Document
import net.nemerosa.ontrack.model.Ack
import net.nemerosa.ontrack.model.pagination.PaginatedList
import org.springframework.security.access.AccessDeniedException
import java.util.*
import java.util.function.BiFunction

interface StructureService {

    val projectStatusViews: List

    val projectList: List

    // Projects

    fun newProject(project: Project): Project

    /**
     * Looks for a project using its ID.
     * @param projectId ID of the project
     * @return Project or `null` if not found
     */
    fun findProjectByID(projectId: ID): Project?

    fun getProject(projectId: ID): Project

    fun saveProject(project: Project)

    fun disableProject(project: Project): Project

    fun enableProject(project: Project): Project

    fun deleteProject(projectId: ID): Ack

    // Branches

    /**
     * Looks for a branch using its ID.
     * @param branchId ID of the branch
     * @return Branch or `null` if not found
     */
    fun findBranchByID(branchId: ID): Branch?

    fun getBranch(branchId: ID): Branch

    fun getBranchesForProject(projectId: ID): List

    fun newBranch(branch: Branch): Branch

    fun getBranchStatusViews(projectId: ID): List

    fun getBranchStatusView(branch: Branch): BranchStatusView

    fun saveBranch(branch: Branch)

    fun disableBranch(branch: Branch): Branch

    fun enableBranch(branch: Branch): Branch

    fun deleteBranch(branchId: ID): Ack

    // Builds

    fun newBuild(build: Build): Build

    fun saveBuild(build: Build): Build

    /**
     * Looks for a build using its ID.
     * @param buildId ID of the build
     * @return Build or `null` if not found
     */
    fun findBuildByID(buildId: ID): Build?

    fun getBuild(buildId: ID): Build

    // TODO Replace by Build?
    fun findBuildByName(project: String, branch: String, build: String): Optional

    fun getEarliestPromotionsAfterBuild(build: Build): BranchStatusView

    /**
     * Finds a build on a branch whose name is the closest. It assumes that build names
     * are in a numeric format.
     */
    // TODO Replace by Build?
    fun findBuildAfterUsingNumericForm(id: ID, buildName: String): Optional

    /**
     * Gets an aggregated view of a build, with its promotion runs, validation stamps and decorations.
     */
    fun getBuildView(build: Build, withDecorations: Boolean): BuildView

    fun getLastBuildForBranch(branch: Branch): Build?

    /**
     * Gets the number of builds for a branch.
     */
    fun getBuildCount(branch: Branch): Int

    fun deleteBuild(buildId: ID): Ack

    // TODO Replace by Build?
    fun getPreviousBuild(buildId: ID): Optional

    // TODO Replace by Build?
    fun getNextBuild(buildId: ID): Optional

    /**
     * Build links
     */

    fun addBuildLink(fromBuild: Build, toBuild: Build)

    fun deleteBuildLink(fromBuild: Build, toBuild: Build)

    /**
     * Gets the builds used by the given one.
     *
     * @param build  Source build
     * @param offset Offset for pagination
     * @param size   Page size for pagination
     * @param filter Optional filter on the builds
     * @return List of builds which are used by the given one
     */
    fun getBuildsUsedBy(build: Build, offset: Int = 0, size: Int = 10, filter: (Build) -> Boolean = { true }): PaginatedList

    /**
     * Gets the builds which use the given one.
     *
     * @param build  Source build
     * @param offset Offset for pagination
     * @param size   Page size for pagination
     * @param filter Optional filter on the builds
     * @return List of builds which use the given one
     */
    fun getBuildsUsing(build: Build, offset: Int = 0, size: Int = 10, filter: (Build) -> Boolean = { true }): PaginatedList

    fun searchBuildsLinkedTo(projectName: String, buildPattern: String): List

    fun editBuildLinks(build: Build, form: BuildLinkForm)

    fun isLinkedFrom(build: Build, project: String, buildPattern: String): Boolean

    fun isLinkedTo(build: Build, project: String, buildPattern: String): Boolean

    /**
     * Loops over ALL the build links. Use this method with care, mostly for external indexation.
     */
    fun forEachBuildLink(code: (from: Build, to: Build) -> Unit)

    /**
     * Looks for the first build which matches a given predicate.
     *
     * @param branchId       Branch to look builds into
     * @param sortDirection  Build search direction
     * @param buildPredicate Predicate for a match
     * @return Build if found, `null` otherwise
     */
    fun findBuild(branchId: ID, sortDirection: BuildSortDirection, buildPredicate: (Build) -> Boolean): Build?

    /**
     * Loops over all the builds of a branch, stopping when [processor] returns `false`.
     *
     * @param branch Branch to look builds into
     * @param processor Must return `false` when the looping must stop
     * @param sortDirection  Build search direction
     */
    fun forEachBuild(branch: Branch, sortDirection: BuildSortDirection, processor: (Build) -> Boolean)

    // TODO Replace by Build?
    fun getLastBuild(branchId: ID): Optional

    fun buildSearch(projectId: ID, form: BuildSearchForm): List

    fun getValidationStampRunViewsForBuild(build: Build, offset: Int = 0, size: Int = 10): List

    // Promotion levels

    fun getPromotionLevelListForBranch(branchId: ID): List

    fun newPromotionLevel(promotionLevel: PromotionLevel): PromotionLevel

    fun getPromotionLevel(promotionLevelId: ID): PromotionLevel

    /**
     * Looks for a promotion level using its ID.
     * @param promotionLevelId ID of the promotion level
     * @return Promotion level or `null` if not found
     */
    fun findPromotionLevelByID(promotionLevelId: ID): PromotionLevel?

    fun getPromotionLevelImage(promotionLevelId: ID): Document

    fun setPromotionLevelImage(promotionLevelId: ID, document: Document?)

    fun savePromotionLevel(promotionLevel: PromotionLevel)

    fun deletePromotionLevel(promotionLevelId: ID): Ack

    fun reorderPromotionLevels(branchId: ID, reordering: Reordering)

    fun newPromotionLevelFromPredefined(branch: Branch, predefinedPromotionLevel: PredefinedPromotionLevel): PromotionLevel

    fun getOrCreatePromotionLevel(branch: Branch, promotionLevelId: Int?, promotionLevelName: String?): PromotionLevel

    // Promotion runs

    fun newPromotionRun(promotionRun: PromotionRun): PromotionRun

    fun getPromotionRun(promotionRunId: ID): PromotionRun

    /**
     * Looks for a promotion run using its ID.
     * @param promotionRunId ID of the promotion run
     * @return Promotion run or `null` if not found
     */
    fun findPromotionRunByID(promotionRunId: ID): PromotionRun?

    // TODO Replace by PromotionLevel?
    fun findPromotionLevelByName(project: String, branch: String, promotionLevel: String): Optional

    fun getPromotionRunsForBuild(buildId: ID): List

    fun getLastPromotionRunsForBuild(buildId: ID): List

    // TODO Replace by PromotionRun?
    fun getLastPromotionRunForBuildAndPromotionLevel(build: Build, promotionLevel: PromotionLevel): Optional

    fun getPromotionRunsForBuildAndPromotionLevel(build: Build, promotionLevel: PromotionLevel): List

    fun getLastPromotionRunForPromotionLevel(promotionLevel: PromotionLevel): PromotionRun?

    fun getPromotionRunView(promotionLevel: PromotionLevel): PromotionRunView

    fun deletePromotionRun(promotionRunId: ID): Ack

    // TODO Replace by PromotionRun?
    fun getEarliestPromotionRunAfterBuild(promotionLevel: PromotionLevel, build: Build): Optional

    fun getPromotionRunsForPromotionLevel(promotionLevelId: ID): List

    /**
     * Bulk update of all promotion levels in other projects/branches and in predefined promotion levels,
     * following the model designed by the promotion level ID.
     *
     * @param promotionLevelId ID of the promotion level model
     * @return Result of the update
     */
    fun bulkUpdatePromotionLevels(promotionLevelId: ID): Ack

    // Validation stamps

    fun getValidationStampListForBranch(branchId: ID): List

    fun newValidationStamp(validationStamp: ValidationStamp): ValidationStamp

    fun getValidationStamp(validationStampId: ID): ValidationStamp

    /**
     * Looks for a validation stamp using its ID.
     * @param validationStampId ID of the validation stamp
     * @return Validation stamp or `null` if not found
     */
    fun findValidationStampByID(validationStampId: ID): ValidationStamp?

    // TODO Replace by ValidationStamp?
    fun findValidationStampByName(project: String, branch: String, validationStamp: String): Optional

    fun getValidationStampImage(validationStampId: ID): Document

    fun setValidationStampImage(validationStampId: ID, document: Document?)

    fun saveValidationStamp(validationStamp: ValidationStamp)

    fun deleteValidationStamp(validationStampId: ID): Ack

    fun reorderValidationStamps(branchId: ID, reordering: Reordering)

    fun newValidationStampFromPredefined(branch: Branch, stamp: PredefinedValidationStamp): ValidationStamp

    fun getOrCreateValidationStamp(branch: Branch, validationStampName: String): ValidationStamp

    /**
     * Bulk update of all validation stamps in other projects/branches and in predefined validation stamps,
     * following the model designed by the validation stamp ID.
     *
     * @param validationStampId ID of the validation stamp model
     * @return Result of the update
     */
    fun bulkUpdateValidationStamps(validationStampId: ID): Ack

    // Validation runs

    fun newValidationRun(build: Build, validationRunRequest: ValidationRunRequest): ValidationRun

    fun getValidationRun(validationRunId: ID): ValidationRun

    /**
     * Looks for a validation run using its ID.
     * @param validationRunId ID of the validation run
     * @return Validation run or `null` if not found
     */
    fun findValidationRunByID(validationRunId: ID): ValidationRun?

    /**
     * Gets the list of validation runs for a build.
     *
     * @param buildId ID of the build
     * @param offset  Offset in the list
     * @param count   Maximum number of elements to return
     * @return List of validation runs
     */
    fun getValidationRunsForBuild(buildId: ID, offset: Int, count: Int): List

    /**
     * Gets the number of validation runs for a build.
     *
     * @param buildId ID of the build
     * @return Number of validation runs
     */
    fun getValidationRunsCountForBuild(buildId: ID): Int

    /**
     * Gets the list of validation runs for a build and a validation stamp.
     *
     * @param buildId           ID of the build
     * @param validationStampId ID of the validation stamp
     * @param offset            Offset in the list
     * @param count             Maximum number of elemnts to return
     * @return List of validation runs
     */
    fun getValidationRunsForBuildAndValidationStamp(buildId: ID, validationStampId: ID, offset: Int, count: Int): List

    /**
     * Gets the list of validation runs for a build and a validation stamp, and a list of accepted statuses
     *
     * @param buildId           ID of the build
     * @param validationStampId ID of the validation stamp
     * @param statuses          List of statuses for the last status of the run
     * @param offset            Offset in the list
     * @param count             Maximum number of elemnts to return
     * @return List of validation runs
     */
    fun getValidationRunsForBuildAndValidationStampAndStatus(
            buildId: ID,
            validationStampId: ID,
            statuses: List,
            offset: Int,
            count: Int
    ): List

    fun getValidationRunsForValidationStamp(validationStamp: ValidationStamp, offset: Int, count: Int): List

    fun getValidationRunsForValidationStamp(validationStampId: ID, offset: Int, count: Int): List

    /**
     * Gets the list of validation runs for a given validation stamp and a list of statuses.
     * @param validationStamp   Validation stamp
     * @param statuses          List of statuses for the last status of the run
     * @param offset            Offset in the list
     * @param count             Maximum number of elemnts to return
     * @return List of validation runs
     */
    fun getValidationRunsForValidationStampAndStatus(
            validationStamp: ValidationStamp,
            statuses: List,
            offset: Int,
            count: Int
    ): List

    /**
     * Gets the list of validation runs for a given validation stamp and a list of statuses.
     * @param validationStampId ID of the validation stamp
     * @param statuses          List of statuses for the last status of the run
     * @param offset            Offset in the list
     * @param count             Maximum number of elemnts to return
     * @return List of validation runs
     */
    fun getValidationRunsForValidationStampAndStatus(
            validationStampId: ID,
            statuses: List,
            offset: Int,
            count: Int
    ): List

    /**
     * Gets the list of validation runs for a branch and a list of statuses.
     * @param branchId ID of the branch
     * @param statuses          List of statuses for the last status of the run
     * @param offset            Offset in the list
     * @param count             Maximum number of elemnts to return
     * @return List of validation runs
     */
    fun getValidationRunsForStatus(
            branchId: ID,
            statuses: List,
            offset: Int,
            count: Int
    ): List

    fun newValidationRunStatus(validationRun: ValidationRun, runStatus: ValidationRunStatus): ValidationRun

    /**
     * Re-exporting all validation run data metrics.
     */
    fun restoreValidationRunDataMetrics(logger: (String) -> Unit = {})

    /**
     * Gets the parent validation run for a given validation run status ID
     *
     * @param validationRunStatusId ID of the validation run status ID
     * @param checkForAccess `false` if the access for view must be checked
     * @return Validation run which contains the status ID or `null` if the current user
     * has no access to it. Never `null` if the [checkForAccess] if `true`.
     */
    fun getParentValidationRun(validationRunStatusId: ID, checkForAccess: Boolean = true): ValidationRun?

    /**
     * Gets a validation run status using its ID.
     *
     * @param id ID of the validation run status
     * @return Validation run status
     */
    fun getValidationRunStatus(id: ID): ValidationRunStatus

    /**
     * Edits a validation run status comment.
     *
     * @param run Parent validation run
     * @param runStatusId ID of the specific run status to edit
     * @param comment New comment
     * @return Updated validation run
     */
    fun saveValidationRunStatusComment(run: ValidationRun, runStatusId: ID, comment: String): ValidationRun

    /**
     * Checks if the validation run status comment is editable by the current user
     */
    fun isValidationRunStatusCommentEditable(validationRunStatus: ID): Boolean

    /**
     * Gets the total number of validation runs for a build and a validation stamp
     *
     * @param buildId           ID of the build
     * @param validationStampId ID of the validation stamp
     * @return Number of validation runs for the validation stamp
     */
    fun getValidationRunsCountForBuildAndValidationStamp(buildId: ID, validationStampId: ID): Int

    /**
     * Gets the total number of validation runs for a validation stamp
     *
     * @param validationStampId ID of the validation stamp
     * @return Number of validation runs for the validation stamp
     */
    fun getValidationRunsCountForValidationStamp(validationStampId: ID): Int

    // Entity searches by name

    // TODO Replace by Project?
    fun findProjectByName(project: String): Optional

    /**
     * Gets the project by its name if authorized to access it. If it does exist, but the user is
     * not authorized to see it, throws an [AccessDeniedException]
     *
     * @param project Name of the project to look for
     * @return Project if it exists and is authorized, or null if if does not exist
     * @throws AccessDeniedException If the project does exist but the user has no access to it
     */
    fun findProjectByNameIfAuthorized(project: String): Project?

    // TODO Replace by Branch?
    fun findBranchByName(project: String, branch: String): Optional

    fun entityLoader(): BiFunction

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy