net.nemerosa.ontrack.model.structure.StructureService 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.buildfilter.BuildFilter;
import java.util.List;
import java.util.Optional;
import java.util.function.Predicate;
public interface StructureService {
List getProjectStatusViews();
// Projects
Project newProject(Project project);
List getProjectList();
Project getProject(ID projectId);
void saveProject(Project project);
Ack deleteProject(ID projectId);
// Branches
Branch getBranch(ID branchId);
List getBranchesForProject(ID projectId);
Branch newBranch(Branch branch);
List getBranchStatusViews(ID projectId);
BranchStatusView getBranchStatusView(Branch branch);
void saveBranch(Branch branch);
Ack deleteBranch(ID branchId);
// Builds
Build newBuild(Build build);
Build saveBuild(Build build);
Build getBuild(ID buildId);
Optional findBuildByName(String project, String branch, String build);
BranchStatusView getEarliestPromotionsAfterBuild(Build build);
/**
* Finds a build on a branch whose name is the closest. It assumes that build names
* are in a numeric format.
*/
Optional findBuildAfterUsingNumericForm(ID id, String buildName);
/**
* Gets an aggregated view of a build, with its promotion runs, validation stamps and decorations.
*/
BuildView getBuildView(Build build, boolean withDecorations);
Build getLastBuildForBranch(Branch branch);
/**
* Gets the number of builds for a branch.
*/
int getBuildCount(Branch branch);
Ack deleteBuild(ID buildId);
Optional getPreviousBuild(ID buildId);
Optional getNextBuild(ID buildId);
/**
* Build links
*/
void addBuildLink(Build fromBuild, Build toBuild);
void deleteBuildLink(Build fromBuild, Build toBuild);
List getBuildLinksFrom(Build build);
List getBuildLinksTo(Build build);
List searchBuildsLinkedTo(String projectName, String buildPattern);
void editBuildLinks(Build build, BuildLinkForm form);
boolean isLinkedFrom(Build build, String project, String buildPattern);
boolean isLinkedTo(Build build, String project, String buildPattern);
/**
* Looks for the first build which matches a given predicate.
*
* @param branchId Branch to look builds into
* @param buildPredicate Predicate for a match
* @param sortDirection Build search direction
* @return Build if found, empty otherwise
*/
Optional findBuild(ID branchId, Predicate buildPredicate, BuildSortDirection sortDirection);
List getFilteredBuilds(ID branchId, BuildFilter buildFilter);
Optional getLastBuild(ID branchId);
List buildSearch(ID projectId, BuildSearchForm form);
List getValidationStampRunViewsForBuild(Build build);
// Promotion levels
List getPromotionLevelListForBranch(ID branchId);
PromotionLevel newPromotionLevel(PromotionLevel promotionLevel);
PromotionLevel getPromotionLevel(ID promotionLevelId);
Document getPromotionLevelImage(ID promotionLevelId);
void setPromotionLevelImage(ID promotionLevelId, Document document);
void savePromotionLevel(PromotionLevel promotionLevel);
Ack deletePromotionLevel(ID promotionLevelId);
void reorderPromotionLevels(ID branchId, Reordering reordering);
PromotionLevel newPromotionLevelFromPredefined(Branch branch, PredefinedPromotionLevel predefinedPromotionLevel);
PromotionLevel getOrCreatePromotionLevel(Branch branch, Integer promotionLevelId, String promotionLevelName);
// Promotion runs
PromotionRun newPromotionRun(PromotionRun promotionRun);
PromotionRun getPromotionRun(ID promotionRunId);
Optional findPromotionLevelByName(String project, String branch, String promotionLevel);
List getPromotionRunsForBuild(ID buildId);
List getLastPromotionRunsForBuild(ID buildId);
Optional getLastPromotionRunForBuildAndPromotionLevel(Build build, PromotionLevel promotionLevel);
List getPromotionRunsForBuildAndPromotionLevel(Build build, PromotionLevel promotionLevel);
PromotionRun getLastPromotionRunForPromotionLevel(PromotionLevel promotionLevel);
PromotionRunView getPromotionRunView(PromotionLevel promotionLevel);
Ack deletePromotionRun(ID promotionRunId);
Optional getEarliestPromotionRunAfterBuild(PromotionLevel promotionLevel, Build build);
// Validation stamps
List getValidationStampListForBranch(ID branchId);
ValidationStamp newValidationStamp(ValidationStamp validationStamp);
ValidationStamp getValidationStamp(ID validationStampId);
Optional findValidationStampByName(String project, String branch, String validationStamp);
Document getValidationStampImage(ID validationStampId);
void setValidationStampImage(ID validationStampId, Document document);
void saveValidationStamp(ValidationStamp validationStamp);
Ack deleteValidationStamp(ID validationStampId);
void reorderValidationStamps(ID branchId, Reordering reordering);
ValidationStamp newValidationStampFromPredefined(Branch branch, PredefinedValidationStamp stamp);
ValidationStamp getOrCreateValidationStamp(Branch branch, Integer validationStampId, String validationStampName);
// Validation runs
ValidationRun newValidationRun(ValidationRun validationRun);
ValidationRun getValidationRun(ID validationRunId);
List getValidationRunsForBuild(ID buildId);
List getValidationRunsForBuildAndValidationStamp(ID buildId, ID validationStampId);
List getValidationRunsForValidationStamp(ID validationStampId, int offset, int count);
ValidationRun newValidationRunStatus(ValidationRun validationRun, ValidationRunStatus runStatus);
// Entity searches by name
Optional findProjectByName(String project);
Optional findBranchByName(String project, String branch);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy