Package com.atlassian.bamboo.plan
Interface PlanManager
-
- All Known Implementing Classes:
PlanManagerImpl
@PublicApi public interface PlanManager
Manager for all Plan types within BambooUse this manager if you need to address Builds, Plans, etc.
- Since:
- 2.7
-
-
Method Summary
All Methods Instance Methods Abstract Methods Deprecated Methods Modifier and Type Method Description boolean
assertPlanPermission(@NotNull PlanIdentifier plan)
Used to validate user permission for plan.void
createPlan(Plan plan)
Same as savePlan, but create permissions used instead of edit permissions.void
deletePlan(@NotNull Plan plan)
Removes the plan object from the database.@NotNull Set<ImmutableChain>
filterFavouritedPlans(@NotNull Collection<? extends ImmutableChain> plans, @NotNull com.atlassian.user.User user)
Return a set ofPlan
s that are a subset of the givenTopLevelPlan
s collection that are favourited by theUser
.@NotNull List<Chain>
getAllChainsAndJobsUnrestricted()
WARNING this is probably a bad idea from a performance perspective, only do this if you're going to traverse through all theChainStage
andJob
of allChain
s returned.<T extends Plan>
@NotNull List<PlanKey>getAllPlanKeys(Class<T> planType)
Deprecated.since 6.2 with no replacement@NotNull List<TopLevelPlan>
getAllPlans()
Deprecated.since 5.0 please useCachedPlanManager
<T extends Plan>
@NotNull List<T>getAllPlans(Class<T> planType)
<T extends Plan>
@NotNull List<T>getAllPlans(Class<T> planType, int firstResult, int maxResults)
<T extends Plan>
@NotNull List<T>getAllPlansByProject(Project project, Class<T> planType)
<T extends Plan>
@NotNull Collection<T>getAllPlansMarkedForDeletion(Class<T> planType)
Deprecated.since 9.0 usePlanDao.getAllPlansMarkedForDeletion(Class)
directly.List<TopLevelPlan>
getAllPlansUnrestricted()
Returns allTopLevelPlan
's ignoring permissionsSet<ImmutableChain>
getFavouritePlans(@NotNull com.atlassian.user.User user)
@NotNull Set<Long>
getFavouritePlansIds(@NotNull com.atlassian.user.User user)
Return a collection of Favourite plan ids.@Nullable Plan
getPlanById(long id)
Returns aPlan
by its id<T extends Plan>
TgetPlanById(long id, Class<T> planType)
@Nullable Plan
getPlanByKey(@NotNull PlanKey planKey)
<T extends Plan>
TgetPlanByKey(@NotNull PlanKey planKey, Class<T> planType)
@Nullable Plan
getPlanByKey(@NotNull String planKey)
Deprecated.since 4.2<T extends Plan>
TgetPlanByKey(@NotNull String planKey, Class<T> planType)
Deprecated.since 4.2<T extends Plan>
TgetPlanByKeyIfOfType(@NotNull PlanKey planKey, @NotNull Class<T> planType)
<T extends Plan>
TgetPlanByOid(BambooEntityOid oid, Class<T> planType)
<T extends Plan>
TgetPlanByPartialKeyAndName(@NotNull PlanKey partialPlanKey, @NotNull String planName, Class<T> planType)
Deprecated.since 4.2@Nullable Class<? extends Plan>
getPlanClass(@NotNull PlanKey planKey)
int
getPlanCount()
int
getPlanCount(@NotNull ProjectIdentifier projectIdentifier)
How many plans currently exist in aproject
.<T extends Plan>
intgetPlanCount(Class<T> planType)
How many plans filtered byClass
currently exist@Nullable PlanIdentifier
getPlanIdentifierForPermissionCheckingByKey(@NotNull String planKey)
Returns aPlan
skeleton skeleton providing ONLY id and key, that matches the given key This method should be used only for permission checking using Acegi<T extends Plan>
@NotNull List<PlanIdentifier>getPlanIdentifiersForProject(@NotNull ProjectIdentifier project, @NotNull Class<T> planType, boolean includeMarkedForDeletion)
Retrieve a list of plans for a given project.@NotNull List<TopLevelPlan>
getPlansByProject(Project project)
Returns allTopLevelPlan
's filtered byProject
Result of this method is filtered by Acegi.<T extends Plan>
@NotNull List<T>getPlansByProject(Project project, Class<T> planType)
<T extends Plan>
@NotNull Map<Project,Collection<T>>getProjectPlanMap(Class<T> planType, boolean includeEmptyProjects)
boolean
isChainNameConflicting(@NotNull String projectKey, long planIdToIgnore, @NotNull String planName)
Verifies whether aChain
name is unique with the given projectboolean
isPlanCreationAllowed()
Check whether or not a plan can be created or not (based on licensing etc)boolean
isPlanKeyConflicting(@NotNull PlanKey planKey)
Verifies whether aPlan
key is unique within whole Bamboo installationboolean
isPlanKeyConflicting(@NotNull PlanKey planKey, long planIdToIgnore)
Verifies whether aPlan
key is unique within whole Bamboo installationvoid
markPlansForDeletion(PlanKey planKey)
Efficiently marks a plan to be deletedvoid
removeStages(@NotNull PlanKey key, @NotNull Collection<Long> stageIds)
Remove the tages from the plan specified.void
savePlan(@NotNull Plan plan)
Saves thePlan
void
savePlanWithSchedulesStopped(@NotNull Plan plan)
Saves thePlan
while polling jobs are stopped.void
setPlanSuspendedState(PlanKey planKey, boolean isSuspended)
void
syncDeletionStatusOfChainBranches()
Deprecated.since 9.0 usePlanDao.syncDeletionStatusOfChainBranches()
()} directlyvoid
syncDeletionStatusOfJobs()
Deprecated.since 9.0 usePlanDao.syncDeletionStatusOfJobs()
directlyvoid
syncDeletionStatusOfPlans()
Deprecated.since 9.0 usePlanDao.syncDeletionStatusOfPlans()
()} directlyvoid
triggerConfigUpdatedEventsForPlansInProject(@NotNull Project project)
Triggers updated events for every plan in a project regardless of permissions.
-
-
-
Method Detail
-
getPlanIdentifierForPermissionCheckingByKey
@Nullable @Nullable PlanIdentifier getPlanIdentifierForPermissionCheckingByKey(@NotNull @NotNull String planKey)
Returns aPlan
skeleton skeleton providing ONLY id and key, that matches the given key This method should be used only for permission checking using AcegiIf
Job
key is provided as a parameter, parent Chain will be returned anyway, as Acegi assertions are defined only forTopLevelPlan
s- Parameters:
planKey
- of the plan to find- Returns:
- plan by the id if found, otherwise null
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type (should never happen)
-
getPlanById
@Nullable @Nullable Plan getPlanById(long id) throws IncorrectPlanTypeException
Returns aPlan
by its id- Parameters:
id
- of the plan- Returns:
- plan with the given id, null if it doesn't exist
- Throws:
IncorrectPlanTypeException
- if plan cannot be found
-
getPlanById
@Nullable <T extends Plan> T getPlanById(long id, Class<T> planType) throws IncorrectPlanTypeException
- Parameters:
id
- of the planplanType
- - the type of the plan to retrieve- Returns:
- plan with the given id, if found AND is of the correct type.
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type
-
getPlanByOid
@Nullable <T extends Plan> T getPlanByOid(BambooEntityOid oid, Class<T> planType) throws IncorrectPlanTypeException
- Parameters:
oid
- of the planplanType
- - the type of the plan to retrieve- Returns:
- plan with the given oid, if found AND is of the correct type.
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type
-
getPlanByKey
@Nullable @Nullable Plan getPlanByKey(@NotNull @NotNull PlanKey planKey) throws IncorrectPlanTypeException
- Parameters:
planKey
- to search for- Returns:
- plan
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type (should never happen)
-
getPlanByKey
@Nullable <T extends Plan> T getPlanByKey(@NotNull @NotNull PlanKey planKey, Class<T> planType) throws IncorrectPlanTypeException
- Parameters:
planKey
- to search forplanType
- - the type of the plan to retrieve- Returns:
- plan with the given key, if found AND is of the correct type.
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type
-
getPlanByKeyIfOfType
@Nullable <T extends Plan> T getPlanByKeyIfOfType(@NotNull @NotNull PlanKey planKey, @NotNull @NotNull Class<T> planType)
Returns aPlan
by its planKey and if it's of the typeClass
. Does not throwIncorrectPlanTypeException
. Should only be used when the type of the plan can not be known.- Parameters:
planKey
- to search forplanType
- the type of the plan to retrieve- Returns:
- null if the plan doesn't exist, or it's not of the found type
-
getAllPlans
@NotNull @Deprecated @NotNull List<TopLevelPlan> getAllPlans()
Deprecated.since 5.0 please useCachedPlanManager
Returns allTopLevelPlan
's- Returns:
- plans
-
getAllPlansUnrestricted
List<TopLevelPlan> getAllPlansUnrestricted()
Returns allTopLevelPlan
's ignoring permissions- Returns:
-
getAllPlans
@NotNull <T extends Plan> @NotNull List<T> getAllPlans(Class<T> planType)
- Parameters:
planType
- - the type of the plan to retrieve- Returns:
- plans sorted by
DescriptionProvider.getName()
-
getAllPlanKeys
@NotNull @Deprecated <T extends Plan> @NotNull List<PlanKey> getAllPlanKeys(Class<T> planType)
Deprecated.since 6.2 with no replacement- Parameters:
planType
- - the type of the plan to retrieve- Returns:
- plan keys
-
getAllPlans
@NotNull <T extends Plan> @NotNull List<T> getAllPlans(Class<T> planType, int firstResult, int maxResults)
- Parameters:
planType
- - the type of the plan to retrievefirstResult
- firstResult for a paginated resultsmaxResults
- maximum number of results to return- Returns:
- plans sorted by
DescriptionProvider.getName()
-
getAllChainsAndJobsUnrestricted
@NotNull @NotNull List<Chain> getAllChainsAndJobsUnrestricted()
WARNING this is probably a bad idea from a performance perspective, only do this if you're going to traverse through all theChainStage
andJob
of allChain
s returned.- Returns:
-
getPlansByProject
@NotNull @NotNull List<TopLevelPlan> getPlansByProject(Project project)
Returns allTopLevelPlan
's filtered byProject
Result of this method is filtered by Acegi.- Parameters:
project
- - that the plans will belong to- Returns:
TopLevelPlan
plans contained within the given project
-
getPlansByProject
@NotNull <T extends Plan> @NotNull List<T> getPlansByProject(Project project, Class<T> planType)
- Parameters:
project
- - that the plans will belong toplanType
- - the type of the plan to retrieve- Returns:
- plans contained within the given project and of the given type
-
getAllPlansByProject
@NotNull <T extends Plan> @NotNull List<T> getAllPlansByProject(Project project, Class<T> planType)
- Parameters:
project
- - that the plans will belong toplanType
- - the type of the plan to retrieve- Returns:
- plans contained within the given project and of the given type
-
getProjectPlanMap
@NotNull <T extends Plan> @NotNull Map<Project,Collection<T>> getProjectPlanMap(Class<T> planType, boolean includeEmptyProjects)
-
getPlanIdentifiersForProject
@NotNull <T extends Plan> @NotNull List<PlanIdentifier> getPlanIdentifiersForProject(@NotNull @NotNull ProjectIdentifier project, @NotNull @NotNull Class<T> planType, boolean includeMarkedForDeletion)
Retrieve a list of plans for a given project. Only minimal data about the plans is returned.- Parameters:
project
- to get plans forplanType
- to filter plans byincludeMarkedForDeletion
- set to true if you want to return plans marked for deletion- Returns:
- PlanIdentifiers meeting the above criteria.
-
getFavouritePlans
Set<ImmutableChain> getFavouritePlans(@NotNull @NotNull com.atlassian.user.User user)
-
getFavouritePlansIds
@NotNull @NotNull Set<Long> getFavouritePlansIds(@NotNull @NotNull com.atlassian.user.User user)
Return a collection of Favourite plan ids.- Parameters:
user
-- Returns:
- favouritePlansIds
-
filterFavouritedPlans
@NotNull @NotNull Set<ImmutableChain> filterFavouritedPlans(@NotNull @NotNull Collection<? extends ImmutableChain> plans, @NotNull @NotNull com.atlassian.user.User user)
Return a set ofPlan
s that are a subset of the givenTopLevelPlan
s collection that are favourited by theUser
. Plans are not filtered by read permission.- Parameters:
plans
- to filteruser
- to return the favourites of- Returns:
- a set of
Chain
s that are a subset of the givenTopLevelPlan
s collection that are favourited by theUser
-
getAllPlansMarkedForDeletion
@Internal @Deprecated @NotNull <T extends Plan> @NotNull Collection<T> getAllPlansMarkedForDeletion(Class<T> planType)
Deprecated.since 9.0 usePlanDao.getAllPlansMarkedForDeletion(Class)
directly.Returns a list ofPlan
s that areImmutableDeletable.isMarkedForDeletion()
for the given type- Returns:
- plansMarkedForDeletion
-
getPlanCount
int getPlanCount()
- Returns:
- How many
Buildable
's exists
-
getPlanCount
<T extends Plan> int getPlanCount(Class<T> planType)
How many plans filtered byClass
currently exist- Parameters:
planType
- - the type of the plan to retrieve- Returns:
- how many plans exist in the datbase
-
getPlanCount
int getPlanCount(@NotNull @NotNull ProjectIdentifier projectIdentifier)
How many plans currently exist in aproject
.- Parameters:
projectIdentifier
- identifier of the project- Returns:
- number of plans in the project, excluding ones marked for deletion
-
isChainNameConflicting
boolean isChainNameConflicting(@NotNull @NotNull String projectKey, long planIdToIgnore, @NotNull @NotNull String planName)
Verifies whether aChain
name is unique with the given project- Parameters:
projectKey
- of the project to look for the plan inplanIdToIgnore
- the id of the plan that has to be ignored during lookup (when you're saving a Plan, you should supply the plan id here)planName
- - name of the plan inside the project: this is just the plan component of the name (i.e does not include the project component)- Returns:
- true if the name is in conflict
- Since:
- 4.0
-
isPlanKeyConflicting
boolean isPlanKeyConflicting(@NotNull @NotNull PlanKey planKey)
Verifies whether aPlan
key is unique within whole Bamboo installation- Parameters:
planKey
- key of the plan to be searched for in the database- Returns:
- true if plan key is conflicting
- Since:
- 4.3
-
isPlanKeyConflicting
boolean isPlanKeyConflicting(@NotNull @NotNull PlanKey planKey, long planIdToIgnore)
Verifies whether aPlan
key is unique within whole Bamboo installation- Parameters:
planKey
-planIdToIgnore
- id of plan which we want to set key for, if the key is used by that plan, it's not really conflicting- Returns:
- true if plan key is conflicting
- Since:
- 5.15
-
getPlanByPartialKeyAndName
@Nullable @Deprecated <T extends Plan> T getPlanByPartialKeyAndName(@NotNull @NotNull PlanKey partialPlanKey, @NotNull @NotNull String planName, Class<T> planType) throws IncorrectPlanTypeException
Deprecated.since 4.2Used for Job validation. Should update to be a specialised method- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type
-
getPlanClass
@Nullable @Nullable Class<? extends Plan> getPlanClass(@NotNull @NotNull PlanKey planKey)
-
assertPlanPermission
boolean assertPlanPermission(@NotNull @NotNull PlanIdentifier plan)
Used to validate user permission for plan.- Parameters:
plan
- to check the permissions of- Returns:
- true if the current user has read(?) permissions on the plan
-
isPlanCreationAllowed
boolean isPlanCreationAllowed()
Check whether or not a plan can be created or not (based on licensing etc)- Returns:
- true if a plan can be created otherwise false;
-
savePlanWithSchedulesStopped
void savePlanWithSchedulesStopped(@NotNull @NotNull Plan plan)
Saves thePlan
while polling jobs are stopped.- Parameters:
plan
-- Since:
- 5.0
-
setPlanSuspendedState
void setPlanSuspendedState(PlanKey planKey, boolean isSuspended)
-
triggerConfigUpdatedEventsForPlansInProject
void triggerConfigUpdatedEventsForPlansInProject(@NotNull @NotNull Project project)
Triggers updated events for every plan in a project regardless of permissions.- Parameters:
project
- to trigger event for.
-
createPlan
void createPlan(Plan plan)
Same as savePlan, but create permissions used instead of edit permissions.
-
deletePlan
void deletePlan(@NotNull @NotNull Plan plan)
Removes the plan object from the database. Does not do any other clean up work at all Please use theDeletionService
rather than using this method directly- Parameters:
plan
- to delete.
-
markPlansForDeletion
void markPlansForDeletion(PlanKey planKey)
Efficiently marks a plan to be deleted- Parameters:
planKey
-
-
syncDeletionStatusOfPlans
@Internal @Deprecated void syncDeletionStatusOfPlans()
Deprecated.since 9.0 usePlanDao.syncDeletionStatusOfPlans()
()} directly
-
syncDeletionStatusOfChainBranches
@Internal @Deprecated void syncDeletionStatusOfChainBranches()
Deprecated.since 9.0 usePlanDao.syncDeletionStatusOfChainBranches()
()} directlyPerforms a cleanup task to markChainBranch
objects that have a masterPlan
that is marked to be deleted, but is not marked as deleted.
-
syncDeletionStatusOfJobs
@Internal @Deprecated void syncDeletionStatusOfJobs()
Deprecated.since 9.0 usePlanDao.syncDeletionStatusOfJobs()
directlyPerforms a cleanup task to markJob
objects that have aPlan
orChainStage
that is marked to be deleted, but it itself was not marked as deleted.
-
removeStages
void removeStages(@NotNull @NotNull PlanKey key, @NotNull @NotNull Collection<Long> stageIds)
Remove the tages from the plan specified. key must be for aChain
- Parameters:
key
-stageIds
-
-
getPlanByKey
@Nullable @Deprecated @Nullable Plan getPlanByKey(@NotNull @NotNull String planKey) throws IncorrectPlanTypeException
Deprecated.since 4.2Returns aPlan
by its planKey- Parameters:
planKey
- of the plan to find- Returns:
- plan by the id if found, otherwise null
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type (should never happen)
-
getPlanByKey
@Nullable @Deprecated <T extends Plan> T getPlanByKey(@NotNull @NotNull String planKey, Class<T> planType) throws IncorrectPlanTypeException
Deprecated.since 4.2- Parameters:
planKey
- to search forplanType
- - the type of the plan to retrieve- Returns:
- plan with the given plan key, if found AND is of the correct type.
- Throws:
IncorrectPlanTypeException
- if plan cannot be found with the correct type
-
-