RevisionHistoryAdapter (revision-history)
@ckeditor/ckeditor5-revision-history/src/revisionhistory
The revision history adapter.
The revision history adapter is an object that communicates asynchronously with the data source to fetch or save the revisions data. It is used internally by the revision history feature whenever revision data is required, a revision is created, or updated.
The adapter is optional. See the Revision history feature integration guide to learn more.
To set the adapter, overwrite the RevisionHistory#adapter
property.
Filtering
Methods
-
getRevision( data = { data.revisionId, data.channelId } ) → Promise
module:revision-history/revisionhistory~RevisionHistoryAdapter#getRevision
Called when the full revision data is required.
It should return a promise that resolves with the whole revision data.
Parameters
data : Object
-
Properties
data.revisionId : String
The ID of the revision for which the data should be loaded.
data.channelId : String
The ID of the document for which the revision was created.
Returns
Promise
-
updateRevisions( data, data[].revisionId, [ data[].name ], [ data[].creatorId ], [ data[].authorsIds ], [ data[].diffData ], [ data[].createdAt ], [ data[].fromVersion ], [ data[].toVersion ], [ data[].attributes ], channelId ) → Promise
module:revision-history/revisionhistory~RevisionHistoryAdapter#updateRevisions
Called when revision(s) data is added or updated.
Multiple revisions can be added and updated at the same moment. The method is passed an array with the updated data. Each item in the array is a data object that describes a single revision. Each data object contains revision id. If the revision id does not exist in your data source (database), then a new revision should be created. Otherwise, the existing revision should be updated with passed data.
The method should return a promise that is resolved when the update is completed.
The
data
parameter only contains those properties of a revision that have changed.Although the
data
parameter containscreatedAt
property, the revision creation date should be set by the backend of your application to ensure that all revisions will be saved with correct dates regardless of users' local system time. It is recommended to overwritecreatedAt
value whenever it is passed in thedata
parameter.The promise may resolve with an array of objects. Each object represents an updated revision, for which
createdAt
property was set (or changed) on the backend. Each object should haveid
(string) andcreatedAt
(Date
object) properties. The returned data will be used to update revisions data in the editor with dates set on the backend.Although the
data
parameter containscreatorId
property, you should verify thecreatorId
value when saving a revision in the database. However, do not overwrite the value if it was set tonull
!It is recommended to stringify
data.diffData
anddata.attributes
values to JSON and save them as strings in your database, and then to parse the strings when loading revisions.Parameters
data : Array.<Object>
Array with revisions data to add or update.
data[].revisionId : String
The ID of the revision to update.
[ data[].name ] : String | null
The name of the revision.
[ data[].creatorId ] : String | null
ID of the user who created the revision.
[ data[].authorsIds ] : Array.<String>
IDs of all users who contributed to this revision.
[ data[].diffData ] : Object
The revision data (content). This is an object with all root names as keys (except of the
$graveyard
root) and strings as values.[ data[].createdAt ] : Date
The date when the revision was created.
[ data[].fromVersion ] : Number
Document version from which the revision starts.
[ data[].toVersion ] : Number
Document version at which the revision ends.
[ data[].attributes ] : Object
Custom revision attributes.
channelId : String
The ID of the document for which the revisions were created.
Returns
Promise
Every day, we work hard to keep our documentation complete. Have you spotted an outdated information? Is something missing? Please report it via our issue tracker.