public interface Versioned
Object versioning in Confluence works in a slightly unconventional way. The identity of the 'current' object (known in the interface as the 'original' or 'latest' version) always remains the same. The object's version history consists of cloned snapshots of that object, taken before each change to its state.
Or, to give a code example:
Versioned oldVersion = (Versioned) currentObject.clone(); oldVersion.convertToHistoricalVersion(); oldVersion.setOriginalVersion(currentObject); // make changes to currentObject currentVersion.setVersion(currentVersion.getVersion() + 1); // save both objects
For Confluence persistent objects, some of the above may be handled for you by the default DAO.
Modifier and Type | Method and Description |
---|---|
void |
applyChildVersioningPolicy(@Nullable Versioned versionToPromote,
ObjectDao dao)
Deprecated.
since 6.10.0. Use
applyChildVersioningPolicy(Versioned, ObjectDaoInternal) instead. |
void |
applyChildVersioningPolicy(@Nullable Versioned versionToPromote,
ObjectDaoInternal<?> dao)
If
getVersionChildPolicy(com.atlassian.confluence.api.model.content.ContentType) specifies so, moves content from versionToPromote to this Versioned instance or
makes no change. |
void |
convertToHistoricalVersion()
Remove all data from the object that does not need to be saved by historical versions.
|
Versioned |
getLatestVersion()
Get the latest, current version of this versioned object.
|
int |
getVersion()
Return the version number of this version of the object.
|
VersionChildOwnerPolicy |
getVersionChildPolicy(ContentType contentType)
Returns the right
VersionChildOwnerPolicy depending on the passed contentType. |
boolean |
isLatestVersion() |
boolean |
isNew()
Is this the first version of this object?
|
void |
setOriginalVersion(Versioned originalVersion)
Deprecated.
since 7.0.0
|
void |
setVersion(int version)
Set the version number of this version of the object.
|
int getVersion()
void setVersion(int version)
version
- the new version number for this version of the object.void convertToHistoricalVersion()
When using Hibernate to persist versioned objects, take special care to null any field that might contain a Hibernate-persisted collection, as Hibernate does not allow two different persistent objects to refer to the same persisted collection at the same time.
@Deprecated void applyChildVersioningPolicy(@Nullable Versioned versionToPromote, ObjectDao dao)
applyChildVersioningPolicy(Versioned, ObjectDaoInternal)
instead.getVersionChildPolicy(com.atlassian.confluence.api.model.content.ContentType)
specifies so, moves content from versionToPromote to this Versioned instance or
makes no change.versionToPromote
- the new version of the current instance that we're getting the children fromdao
- dao used to delete dangling contained contentvoid applyChildVersioningPolicy(@Nullable Versioned versionToPromote, ObjectDaoInternal<?> dao)
getVersionChildPolicy(com.atlassian.confluence.api.model.content.ContentType)
specifies so, moves content from versionToPromote to this Versioned instance or
makes no change.versionToPromote
- the new version of the current instance that we're getting the children fromdao
- dao used to delete dangling contained contentboolean isNew()
Versioned getLatestVersion()
Note that drafts are a special version of a ContentEntityObject
so for drafts this method should return the ContentEntityObject
the drafts points to if it exists and the draft itself otherwise.
ContentEntityObject.DRAFT
@Deprecated void setOriginalVersion(Versioned originalVersion)
originalVersion
- the current version of this object.boolean isLatestVersion()
VersionChildOwnerPolicy getVersionChildPolicy(ContentType contentType)
VersionChildOwnerPolicy
depending on the passed contentType.
By default, VersionChildOwnerPolicy.currentVersion
is returned
Right now, this is only enforced for children with content type Attachment or Comment
Copyright © 2003–2021 Atlassian. All rights reserved.