Package org.opencms.db
Class CmsPublishList
java.lang.Object
org.opencms.db.CmsPublishList
- All Implemented Interfaces:
- Externalizable,- Serializable
A container for all new/changed/deteled Cms resources that are published together.
Only classes inside the org.opencms.db package can add or remove elements to or from this list. This allows the OpenCms API to pass the list around between classes, but with restricted access to create this list.
 To create a publish list, one of the public constructors must be used in order to set the basic operation mode
 (project publish or direct publish).
 After this, use CmsDriverManager.fillPublishList(CmsDbContext, CmsPublishList)
- Since:
- 6.0.0
- See Also:
- 
Constructor SummaryConstructorsConstructorDescriptionEmpty constructor.CmsPublishList(boolean all, List<CmsResource> directPublishResources, boolean directPublishSiblings) Constructs a publish list for a list of direct publish resources.CmsPublishList(List<CmsResource> directPublishResources, boolean publishSiblings) Constructs a publish list for a list of direct publish resources.CmsPublishList(List<CmsResource> directPublishResources, boolean publishSiblings, boolean publishSubResources) Constructs a publish list for a list of direct publish resources.CmsPublishList(CmsProject project) Constructs a publish list for a given project.CmsPublishList(CmsResource directPublishResource, boolean publishSiblings) Constructs a publish list for a single direct publish resource.
- 
Method SummaryModifier and TypeMethodDescriptionprotected voidadd(CmsResource resource, boolean check) Adds a new/changed Cms folder resource to the publish list.protected voidaddAll(Collection<CmsResource> resources, boolean check) Appends all the given resources to this publish list.protected CmsResourcecheckContainsSubResources(CmsObject cms, List<CmsResource> folders) Checks whether the publish list contains all sub-resources of a list of folders.protected booleanChecks if the publish list contains a resource.protected booleancontainsSubResources(CmsObject cms, CmsResource folder) Checks if the publish list contains all sub-resources of a given folder.Returns a list of all resources in the publish list, including folders and files.Returns a list of folder resources with the deleted state.Returns the list of resources that should be published for a "direct" publish operation.Returns an unmodifiable list of the files in this publish list.Returns an unmodifiable list of the new/changed folders in this publish list.protected List<CmsResource> getMissingSubResources(CmsObject cms, List<CmsResource> folders) Gets the sub-resources of a list of folders which are missing from the publish list.protected List<CmsResource> getMovedFolders(CmsObject cms) Internal method to get the moved folders from the publish list.Returns the id of the project that should be published, or-1if this publish list is initialized for a "direct publish" operation.Returns the publish history Id for this publish list.protected List<CmsResource> getTopFolders(List<CmsResource> folders) Gives the "roots" of a list of folders, i.e.Gets the list of moved folders which are not subfolders of other moved folders in the publish list.protected voidInitializes the publish list, ensuring all internal lists are in the right order.booleanChecks if this is a publish list is used for a "direct publish" operation.booleanReturnstrueif all siblings of the project resources are to be published.booleanReturnstrueif sub-resources in folders should be published (for direct publish only).booleanReturns true if this is a user publish list.voidprotected booleanremove(CmsResource resource) Removes a Cms resource from the publish list.voidRevives the publish list by populating the internal resource lists withCmsResourcevoidsetUserPublishList(boolean isUserPublishList) Sets the 'user publish list' flag on this publish list.intsize()Returns the number of all resources to be published.toString()void
- 
Constructor Details- 
CmsPublishListpublic CmsPublishList()Empty constructor.
- 
CmsPublishListpublic CmsPublishList(boolean all, List<CmsResource> directPublishResources, boolean directPublishSiblings) Constructs a publish list for a list of direct publish resources.- Parameters:
- all- no redundant resource are filtered out
- directPublishResources- a list of- CmsResource
- directPublishSiblings- indicates if all siblings of the selected resources should be published
 
- 
CmsPublishListConstructs a publish list for a given project.- Parameters:
- project- the project to publish, this should always be the id of the current project
 
- 
CmsPublishListConstructs a publish list for a single direct publish resource.- Parameters:
- directPublishResource- a VFS resource to be published directly
- publishSiblings- indicates if all siblings of the selected resources should be published
 
- 
CmsPublishListConstructs a publish list for a list of direct publish resources.- Parameters:
- directPublishResources- a list of- CmsResource
- publishSiblings- indicates if all siblings of the selected resources should be published
 
- 
CmsPublishListpublic CmsPublishList(List<CmsResource> directPublishResources, boolean publishSiblings, boolean publishSubResources) Constructs a publish list for a list of direct publish resources.- Parameters:
- directPublishResources- a list of- CmsResource
- publishSiblings- indicates if all siblings of the selected resources should be published
- publishSubResources- indicates if sub-resources in folders should be published (for direct publish only)
 
 
- 
- 
Method Details- 
getAllResourcesReturns a list of all resources in the publish list, including folders and files.- Returns:
- a list of CmsResourceobjects
 
- 
getDeletedFolderListReturns a list of folder resources with the deleted state.- Returns:
- a list of folder resources with the deleted state
 
- 
getDirectPublishResourcesReturns the list of resources that should be published for a "direct" publish operation.Will return nullif this publish list was not initialized for a "direct publish" but for a project publish.- Returns:
- the list of resources that should be published for a "direct" publish operation, or null
 
- 
getFileListReturns an unmodifiable list of the files in this publish list.- Returns:
- the list with the files in this publish list
 
- 
getFolderListReturns an unmodifiable list of the new/changed folders in this publish list.- Returns:
- the list with the new/changed folders in this publish list
 
- 
getProjectIdReturns the id of the project that should be published, or-1if this publish list is initialized for a "direct publish" operation.- Returns:
- the id of the project that should be published, or -1
 
- 
getPublishHistoryIdReturns the publish history Id for this publish list.- Returns:
- the publish history Id
 
- 
getTopMovedFoldersGets the list of moved folders which are not subfolders of other moved folders in the publish list.- Parameters:
- cms- the current cms context
- Returns:
- the moved folders which are not subfolders of other moved folders in the publish list
- Throws:
- CmsException- if something goes wrong
 
- 
isDirectPublishChecks if this is a publish list is used for a "direct publish" operation.- Returns:
- true if this is a publish list is used for a "direct publish" operation
 
- 
isPublishSiblingsReturnstrueif all siblings of the project resources are to be published.- Returns:
- trueif all siblings of the project resources are to be publisheds
 
- 
isPublishSubResourcesReturnstrueif sub-resources in folders should be published (for direct publish only).- Returns:
- trueif sub-resources in folders should be published (for direct publish only)
 
- 
isUserPublishListReturns true if this is a user publish list.- Returns:
- true if this is a user publish list
 
- 
readExternal- Specified by:
- readExternalin interface- Externalizable
- Throws:
- IOException
- See Also:
 
- 
reviveRevives the publish list by populating the internal resource lists withCmsResource- Parameters:
- cms- a cms object used to read the resource instances
 
- 
setUserPublishListSets the 'user publish list' flag on this publish list.- Parameters:
- isUserPublishList- if true, the list is marked as a user publish list
 
- 
sizeReturns the number of all resources to be published.- Returns:
- the number of all resources to be published
 
- 
toString
- 
writeExternal- Specified by:
- writeExternalin interface- Externalizable
- Throws:
- IOException
- See Also:
 
- 
addAdds a new/changed Cms folder resource to the publish list.- Parameters:
- resource- a new/changed Cms folder resource
- check- if set an exception is thrown if the specified resource is unchanged, if not set the resource is ignored
- Throws:
- IllegalArgumentException- if the specified resource is unchanged
 
- 
addAllprotected void addAll(Collection<CmsResource> resources, boolean check) throws IllegalArgumentException Appends all the given resources to this publish list.- Parameters:
- resources- resources to be added to this publish list
- check- if set an exception is thrown if the a resource is unchanged, if not set the resource is ignored
- Throws:
- IllegalArgumentException- if one of the resources is unchanged
 
- 
checkContainsSubResourcesprotected CmsResource checkContainsSubResources(CmsObject cms, List<CmsResource> folders) throws CmsException Checks whether the publish list contains all sub-resources of a list of folders.- Parameters:
- cms- the current CMS context
- folders- the folders which should be checked
- Returns:
- a folder from the list if one of its sub-resources is not contained in the publish list, otherwise null
- Throws:
- CmsException- if something goes wrong
 
- 
containsResourceChecks if the publish list contains a resource.- Parameters:
- res- the resource
- Returns:
- true if the publish list contains a resource
 
- 
containsSubResourcesChecks if the publish list contains all sub-resources of a given folder.- Parameters:
- cms- the current CMS context
- folder- the folder for which the check should be performed
- Returns:
- true if the publish list contains all sub-resources of a given folder
- Throws:
- CmsException- if something goes wrong
 
- 
getMissingSubResourcesprotected List<CmsResource> getMissingSubResources(CmsObject cms, List<CmsResource> folders) throws CmsException Gets the sub-resources of a list of folders which are missing from the publish list.- Parameters:
- cms- the current CMS context
- folders- the folders which should be checked
- Returns:
- a list of missing sub resources
- Throws:
- CmsException- if something goes wrong
 
- 
getMovedFoldersInternal method to get the moved folders from the publish list.- Parameters:
- cms- the current CMS context
- Returns:
- the list of moved folders from the publish list
- Throws:
- CmsException- if something goes wrong
 
- 
getTopFoldersGives the "roots" of a list of folders, i.e. the list of folders which are not descendants of any other folders in the original list- Parameters:
- folders- the original list of folders
- Returns:
- the root folders of the list
 
- 
initializeInitializes the publish list, ensuring all internal lists are in the right order.
- 
removeRemoves a Cms resource from the publish list.- Parameters:
- resource- a Cms resource
- Returns:
- true if this publish list contains the specified resource
- See Also:
 
 
-