public interface DeploymentVersionService
Modifier and Type | Method and Description |
---|---|
DeploymentVersion |
createDeploymentVersion(long deploymentProjectId,
PlanResultKey planResultKey)
Deprecated.
since 5.6 use
getOrCreateDeploymentVersion(long, PlanResultKey) |
DeploymentVersion |
createDeploymentVersion(long deploymentProjectId,
PlanResultKey planResultKey,
com.atlassian.user.User user,
String versionName,
String nextVersionName)
Create a deployment version with a specific name.
|
Map<DeploymentVersion,Integer> |
findLatestKnownVersionsForEnvironmentsOfDeploymentProject(DeploymentProject deploymentProject)
Find all
DeploymentVersion that are currently deployed on environments of a DeploymentProject
For each version found give number of environments it is present on. |
DeploymentVersion |
findNextVersionContainingResult(long deploymentProjectId,
PlanResultKey planResultKey)
Find the first version that is created from a result which is later than current result (not taking custom revision into account)
|
DeploymentVersion |
findPreviousVersion(long deploymentProjectId,
long versionId) |
List<DeploymentVersion> |
findVersionsAssociatedWithJiraIssue(long deploymentProjectId,
String issueKey)
Find all the versions of a
DeploymentProject that are associated with a JIRA issue |
com.google.common.collect.Multimap<DeploymentProject,DeploymentVersion> |
findVersionsAssociatedWithJiraIssue(String issueKey)
Find all the version that are associated with a JIRA issue, grouped by
DeploymentProject |
List<DeploymentVersion> |
findVersionsBetween(long deploymentProjectId,
DeploymentVersion version1,
DeploymentVersion version2)
Deprecated.
since 6.8 as it fetches variables, which is not efficient. Use
findVersionsBetweenNoVariables(long, DeploymentVersion, DeploymentVersion) instead. |
List<DeploymentVersion> |
findVersionsBetweenNoVariables(long deploymentProjectId,
DeploymentVersion version1,
DeploymentVersion version2)
Find versions created between version1 and version2.
|
List<DeploymentVersion> |
getDeploymentProjectVersions(long deploymentProjectId)
Deprecated.
since 6.7 for performance reasons use
getDeploymentProjectVersionsNoVariables(DeploymentProject) |
List<DeploymentVersion> |
getDeploymentProjectVersionsNoVariables(DeploymentProject deploymentProject)
Retrieves the list of all the version for the deployment project, sorted by CreationDate (the most recent
Deployment Versions will be returned as firsts)
|
List<DeploymentVersion> |
getDeploymentProjectVersionsNoVariables(DeploymentProject deploymentProject,
int offset,
int maxResults)
Retrieves the list of the version for the deployment project, sorted by CreationDate (the most recent
Deployment Versions will be returned as firsts).
|
DeploymentVersion |
getDeploymentVersion(long deploymentVersionId)
Get DeploymentVersion by id
|
DeploymentVersion |
getDeploymentVersionByName(String existingVersion,
long deploymentProjectId)
Get a specific version by name
|
String |
getEvaluatedVersionName(String nextVersionName,
Map<String,VariableDefinitionContext> variables,
Set<String> variablesToIncrement) |
String |
getIncrementedVersionName(String versionName)
Calculates an increment of a version name.
|
DeploymentVersion |
getLatestVersionForProject(long deploymentProjectId)
Deprecated.
since 5.1 use
getLatestVersionForProject(long, PlanKey) |
DeploymentVersion |
getLatestVersionForProject(long deploymentProjectId,
PlanKey branchKey)
Find the latest version for a deployment project.
|
DeploymentVersionStatus |
getLatestVersionStatus(long deploymentVersionId) |
Map<Long,DeploymentVersionStatus> |
getLatestVersionStatuses(List<Long> deploymentVersionIds)
Find a latest version status for each version id.
|
DeploymentVersion |
getOrCreateDeploymentVersion(long deploymentProjectId,
PlanResultKey planResultKey)
Given a build result, find a deployment version that matches it, or create it if it doesn't exist.
|
Map<String,VariableDefinitionContext> |
getPossibleVersionVariables(ImmutablePlan linkedPlan,
boolean includeUndeterminable)
Provides a map of variables which might show up on a version.
|
Map<String,VariableDefinitionContext> |
getPossibleVersionVariables(ImmutablePlan linkedPlan,
PlanResultKey planResultKey,
boolean includeUndeterminable)
Provides a map of variables which might show up on a version.
|
Set<PlanResultKey> |
getRelatedPlanResultKeys(long deploymentVersionId) |
DeploymentVersion |
getRelatedVersion(long deploymentProjectId,
PlanResultKey planResultKey)
Find latest version of a deployment project that is related to specific plan result.
|
Set<String> |
getResultPlanKeysHavingDeploymentProjectVersions(long deploymentProjectId)
Returns keys of result plans (branch) that have at least one deployment project version (release)
|
com.google.common.collect.ImmutableList<VariableSubstitutionContext> |
getVariableContextForVersion(long deploymentVersionId)
Fetch variable context associated with a version.
|
com.google.common.collect.Multimap<String,Artifact> |
getVersionArtifacts(DeploymentVersion deploymentVersion)
Find all
Artifact related to a version. |
String |
getVersionNamePreview(ResultsSummary resultsSummary,
String versionName)
Given a version name and a result summary, what would the version name look like after substitution.
|
int |
getVersionsCount()
Count all versions
|
int |
getVersionsCountForProject(long deploymentProjectId)
Count versions related to deployment project
|
int |
getVersionsCountForProjectAndBranch(long deploymentProjectId,
PlanKey branchKey)
Count versions related to deployment project and a specified plan branch
|
boolean |
hasVersionsUnrelatedToBranch(long deploymentProjectId,
PlanKey branchKey)
Test if there are
DeploymentVersion s in a DeploymentProject that are unrelated to given branch |
boolean |
isFromTheSameBranch(long firstVersionId,
long secondVersionId)
Checks if both deployment versions come from the same branch
|
boolean |
isFromTheSameBranch(String planKey,
long versionId)
Checks if the specified build result is on the same branch as the specified version ID
|
boolean |
isVersionNameConflicting(long deploymentProjectId,
String name)
Check whether the version name is already being used by another version within this project
|
DeploymentVersion |
renameVersion(long deploymentProjectId,
DeploymentVersion deploymentVersion,
String newVersionName)
Rename a version.
|
void |
resetVersionsAge(DeploymentVersion deploymentVersion)
Resets version's age to 0.
|
List<DeploymentVersion> |
searchVersionsByBranch(long deploymentProjectId,
PlanKey branchKey)
Deprecated.
since 6.7 for performance reasons use
searchVersionsByBranchNoVariables(DeploymentProject, PlanKey) |
List<DeploymentVersion> |
searchVersionsByBranchAndName(long deploymentProjectId,
PlanKey branchKey,
String searchTerm)
Deprecated.
since 6.7 for performance reasons use
searchVersionsByNameNoVariables(DeploymentProject, String) |
List<DeploymentVersion> |
searchVersionsByBranchAndNameNoVariables(DeploymentProject deploymentProject,
PlanKey branchKey,
String searchTerm)
Search for deployment versions in a project whose name contains the searchTerm and associated with a specific branch, sorted by CreationDate (the most recent
Deployment Versions will be returned as firsts)
|
List<DeploymentVersion> |
searchVersionsByBranchNoVariables(DeploymentProject deploymentProject,
PlanKey branchKey)
Search for deployment versions in a project associated with a specific branch, sorted by CreationDate (the most recent
Deployment Versions will be returned as firsts)
|
List<DeploymentVersion> |
searchVersionsByBranchNoVariables(DeploymentProject deploymentProject,
PlanKey branchKey,
int startIndex,
int maxResults)
Search for deployment versions in a project associated with a specific branch, sorted by CreationDate (the most recent
Deployment Versions will be returned as firsts)
|
List<DeploymentVersion> |
searchVersionsByName(long deploymentProjectId,
String searchTerm)
Deprecated.
since 6.7 for performance reasons use
searchVersionsByNameNoVariables(DeploymentProject, String) |
List<DeploymentVersion> |
searchVersionsByNameNoVariables(DeploymentProject deploymentProject,
String searchTerm)
Search for deployment versions in a project whose name contains the searchTerm, sorted by CreationDate (the most recent
Deployment Versions will be returned as firsts)
|
void |
updatePlanKey(PlanKey originalPlanKey,
PlanKey newPlanKey)
Update planKey in DeploymentVersion's related entities when plan key has changed (ie after moving plan)
|
DeploymentVersionStatus |
updateVersionStatus(long deploymentVersionId,
DeploymentVersionState status,
String userName)
Updates the version status for given deployment version.
|
ErrorCollection |
validateCreateDeploymentVersion(long deploymentProjectId,
PlanResultKey planResultKey,
String name,
String nextVersionName)
Validates values to be used for creating a new version.
|
ErrorCollection |
validateDeploymentVersionRename(long deploymentProjectId,
DeploymentVersion deploymentVersion,
String name)
Validates values to be used for renaming version.
|
@NotNull ErrorCollection validateCreateDeploymentVersion(long deploymentProjectId, @NotNull PlanResultKey planResultKey, @Nullable String name, @Nullable String nextVersionName)
deploymentProjectId
- id of the deployment projectplanResultKey
- key of the build result on which this version is createdname
- version namenextVersionName
- name of the next versionboolean isVersionNameConflicting(long deploymentProjectId, @NotNull String name)
deploymentProjectId
- project to filter byname
- to check@NotNull ErrorCollection validateDeploymentVersionRename(long deploymentProjectId, @NotNull DeploymentVersion deploymentVersion, @Nullable String name)
deploymentProjectId
- deploymentVersion
- name
- @NotNull @Deprecated DeploymentVersion createDeploymentVersion(long deploymentProjectId, @NotNull PlanResultKey planResultKey) throws WebValidationException
getOrCreateDeploymentVersion(long, PlanResultKey)
deploymentProjectId
- of project to create version forplanResultKey
- of the result to pull artifacts fromWebValidationException
@NotNull DeploymentVersion getOrCreateDeploymentVersion(long deploymentProjectId, @NotNull PlanResultKey planResultKey) throws WebValidationException
deploymentProjectId
- of project to create version forplanResultKey
- of the result to pull artifacts fromWebValidationException
@NotNull DeploymentVersion createDeploymentVersion(long deploymentProjectId, @NotNull PlanResultKey planResultKey, @Nullable com.atlassian.user.User user, @Nullable String versionName, @Nullable String nextVersionName) throws WebValidationException
deploymentProjectId
- project the version is getting created forplanResultKey
- of the result to pull artifacts fromversionName
- name for the version to createnextVersionName
- the name for the next version (to be updated in version naming scheme)user
- the person who is creating this versionWebValidationException
@Nullable DeploymentVersion getDeploymentVersion(long deploymentVersionId)
@NotNull Set<String> getResultPlanKeysHavingDeploymentProjectVersions(long deploymentProjectId)
deploymentProjectId
- id of the deployment project@NotNull @Deprecated List<DeploymentVersion> getDeploymentProjectVersions(long deploymentProjectId)
getDeploymentProjectVersionsNoVariables(DeploymentProject)
This method fetches complete version data, getDeploymentProjectVersionsNoVariables(DeploymentProject)
should be preferred when variable data is not required, e.g. for displaying list of version in the UI.
deploymentProjectId
- id of the deployment project@NotNull @Deprecated List<DeploymentVersion> searchVersionsByName(long deploymentProjectId, @NotNull String searchTerm)
searchVersionsByNameNoVariables(DeploymentProject, String)
This method fetches complete version data, searchVersionsByNameNoVariables(DeploymentProject, String)
should be preferred when variable data is not required, e.g. for displaying list of version in the UI.
deploymentProjectId
- deployment project to search withinsearchTerm
- term to look for.@NotNull @Deprecated List<DeploymentVersion> searchVersionsByBranch(long deploymentProjectId, @NotNull PlanKey branchKey)
searchVersionsByBranchNoVariables(DeploymentProject, PlanKey)
This method fetches complete version data, searchVersionsByBranchNoVariables(DeploymentProject, PlanKey)
should be preferred when variable data is not required, e.g. for displaying list of version in the UI.
deploymentProjectId
- deployment project to search withinbranchKey
- plan branch to narrow search result@NotNull @Deprecated List<DeploymentVersion> searchVersionsByBranchAndName(long deploymentProjectId, @NotNull PlanKey branchKey, @NotNull String searchTerm)
searchVersionsByNameNoVariables(DeploymentProject, String)
This method fetches complete version data, searchVersionsByBranchAndNameNoVariables(DeploymentProject, PlanKey, String)
should be preferred when variable data is not required, e.g. for displaying list of version in the UI.
deploymentProjectId
- deployment project to search withinbranchKey
- plan branch to narrow search resultsearchTerm
- term to look for.@NotNull List<DeploymentVersion> searchVersionsByNameNoVariables(@NotNull DeploymentProject deploymentProject, @NotNull String searchTerm)
deploymentProject
- deployment project to search withinsearchTerm
- term to look for.@NotNull List<DeploymentVersion> searchVersionsByBranchNoVariables(@NotNull DeploymentProject deploymentProject, @NotNull PlanKey branchKey)
deploymentProject
- deployment project to search withinbranchKey
- plan branch to narrow search result@NotNull List<DeploymentVersion> searchVersionsByBranchNoVariables(@NotNull DeploymentProject deploymentProject, @NotNull PlanKey branchKey, int startIndex, int maxResults)
deploymentProject
- deployment project to search withinbranchKey
- plan branch to narrow search result@NotNull List<DeploymentVersion> searchVersionsByBranchAndNameNoVariables(@NotNull DeploymentProject deploymentProject, @NotNull PlanKey branchKey, @NotNull String searchTerm)
deploymentProject
- deployment project to search withinbranchKey
- plan branch to narrow search resultsearchTerm
- term to look for.@Nullable DeploymentVersion getDeploymentVersionByName(@NotNull String existingVersion, long deploymentProjectId)
existingVersion
- name of the versionSet<PlanResultKey> getRelatedPlanResultKeys(long deploymentVersionId)
boolean isFromTheSameBranch(long firstVersionId, long secondVersionId)
firstVersionId
- first deployment versionsecondVersionId
- second deployment versionboolean isFromTheSameBranch(String planKey, long versionId)
planKey
- the planKey of the build result you want to compareversionId
- the version ID of the version you want to compare@NotNull DeploymentVersionStatus updateVersionStatus(long deploymentVersionId, @NotNull DeploymentVersionState status, @NotNull String userName)
@Nullable DeploymentVersionStatus getLatestVersionStatus(long deploymentVersionId)
@Deprecated @NotNull List<DeploymentVersion> findVersionsBetween(long deploymentProjectId, @NotNull DeploymentVersion version1, @NotNull DeploymentVersion version2)
findVersionsBetweenNoVariables(long, DeploymentVersion, DeploymentVersion)
instead.DeploymentProject
The order of the argument is irrelevant: the method will determine which of the versions is the lower bound.
Lower bound is not included in result but upper bound is.
The result is sorted by creation date (newest first)IllegalArgumentException
- if any of the version doesn't exist@NotNull List<DeploymentVersion> findVersionsBetweenNoVariables(@NotNull long deploymentProjectId, @NotNull DeploymentVersion version1, @NotNull DeploymentVersion version2)
DeploymentProject
The order of the argument is irrelevant: the method will determine which of the versions is the lower bound.
Lower bound is not included in result but upper bound is.
The result is sorted by creation date (newest first)IllegalArgumentException
- if any of the version doesn't exist@Nullable DeploymentVersion findPreviousVersion(long deploymentProjectId, long versionId)
int getVersionsCount()
int getVersionsCountForProject(long deploymentProjectId)
deploymentProjectId
- id of deployment projectint getVersionsCountForProjectAndBranch(@NotNull long deploymentProjectId, @NotNull PlanKey branchKey)
deploymentProjectId
- id of deployment projectbranchKey
- plan branch key@NotNull List<DeploymentVersion> getDeploymentProjectVersionsNoVariables(@NotNull DeploymentProject deploymentProject)
deploymentProject
- deployment project@NotNull List<DeploymentVersion> getDeploymentProjectVersionsNoVariables(@NotNull DeploymentProject deploymentProject, int offset, int maxResults)
deploymentProject
- deployment projectoffset
- number of results to skipmaxResults
- maximum length of the returned list@Deprecated @Nullable DeploymentVersion getLatestVersionForProject(long deploymentProjectId)
getLatestVersionForProject(long, PlanKey)
deploymentProjectId
- of the deployment project@Nullable DeploymentVersion getLatestVersionForProject(long deploymentProjectId, @NotNull PlanKey branchKey)
deploymentProjectId
- of the deployment projectbranchKey
- key of the PlanBranch@NotNull com.google.common.collect.Multimap<String,Artifact> getVersionArtifacts(@NotNull DeploymentVersion deploymentVersion)
Artifact
related to a version.deploymentVersion
- @Nullable DeploymentVersion getRelatedVersion(long deploymentProjectId, @NotNull PlanResultKey planResultKey)
deploymentProjectId
- planResultKey
- DeploymentVersion findNextVersionContainingResult(long deploymentProjectId, @NotNull PlanResultKey planResultKey)
deploymentProjectId
- planResultKey
- @NotNull Map<String,VariableDefinitionContext> getPossibleVersionVariables(@NotNull ImmutablePlan linkedPlan, boolean includeUndeterminable)
linkedPlan
- plan the deployment project is linked toincludeUndeterminable
- if true include variables that we don't currently know the value, with a nice example (used for display purposes)@NotNull Map<String,VariableDefinitionContext> getPossibleVersionVariables(@NotNull ImmutablePlan linkedPlan, @Nullable PlanResultKey planResultKey, boolean includeUndeterminable)
linkedPlan
- plan the deployment project is linked toplanResultKey
- resultKey for result variables contextincludeUndeterminable
- if true include variables that we don't currently know the value, with a nice example (used for display purposes)@NotNull String getIncrementedVersionName(@NotNull String versionName)
versionName
- to increment@NotNull String getEvaluatedVersionName(String nextVersionName, Map<String,VariableDefinitionContext> variables, Set<String> variablesToIncrement)
nextVersionName
- variables
- variablesToIncrement
- void updatePlanKey(@NotNull PlanKey originalPlanKey, @NotNull PlanKey newPlanKey)
originalPlanKey
- original PlanKeynewPlanKey
- new PlanKey@NotNull DeploymentVersion renameVersion(long deploymentProjectId, @NotNull DeploymentVersion deploymentVersion, @NotNull String newVersionName) throws WebValidationException
deploymentProjectId
- deploymentVersion
- newVersionName
- WebValidationException
@NotNull List<DeploymentVersion> findVersionsAssociatedWithJiraIssue(long deploymentProjectId, @NotNull String issueKey)
DeploymentProject
that are associated with a JIRA issuedeploymentProjectId
- issueKey
- @NotNull com.google.common.collect.Multimap<DeploymentProject,DeploymentVersion> findVersionsAssociatedWithJiraIssue(@NotNull String issueKey)
DeploymentProject
issueKey
- @NotNull Map<DeploymentVersion,Integer> findLatestKnownVersionsForEnvironmentsOfDeploymentProject(DeploymentProject deploymentProject)
DeploymentVersion
that are currently deployed on environments of a DeploymentProject
For each version found give number of environments it is present on.deploymentProject
- boolean hasVersionsUnrelatedToBranch(long deploymentProjectId, @NotNull PlanKey branchKey)
DeploymentVersion
s in a DeploymentProject
that are unrelated to given branchdeploymentProjectId
- identifies deployment projectbranchKey
- key of the branch@NotNull com.google.common.collect.ImmutableList<VariableSubstitutionContext> getVariableContextForVersion(@NotNull long deploymentVersionId)
String getVersionNamePreview(ResultsSummary resultsSummary, String versionName)
resultsSummary
- the version would get created fromversionName
- the potential name of the versionvoid resetVersionsAge(@NotNull DeploymentVersion deploymentVersion)
@NotNull Map<Long,DeploymentVersionStatus> getLatestVersionStatuses(@NotNull List<Long> deploymentVersionIds)
deploymentVersionIds
- Copyright © 2021 Atlassian Software Systems Pty Ltd. All rights reserved.