@webiny/api-headless-cms 0.0.0-unstable.2af142b57e → 0.0.0-unstable.3bc8100a7f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/constants.d.ts +44 -0
- package/constants.js +70 -0
- package/constants.js.map +1 -0
- package/context.d.ts +1 -1
- package/context.js +122 -52
- package/context.js.map +1 -1
- package/crud/AccessControl/AccessControl.d.ts +98 -0
- package/crud/AccessControl/AccessControl.js +542 -0
- package/crud/AccessControl/AccessControl.js.map +1 -0
- package/crud/AccessControl/README.md +47 -0
- package/crud/AccessControl/groups-own.png +0 -0
- package/crud/AccessControl/models-own.png +0 -0
- package/crud/contentEntry/abstractions/IDeleteEntry.d.ts +4 -0
- package/crud/contentEntry/abstractions/IDeleteEntry.js +7 -0
- package/crud/contentEntry/abstractions/IDeleteEntry.js.map +1 -0
- package/crud/contentEntry/abstractions/IDeleteEntryOperation.d.ts +4 -0
- package/crud/contentEntry/abstractions/IDeleteEntryOperation.js +7 -0
- package/crud/contentEntry/abstractions/IDeleteEntryOperation.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetEntriesByIds.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetEntriesByIds.js +7 -0
- package/crud/contentEntry/abstractions/IGetEntriesByIds.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetEntry.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetEntry.js +7 -0
- package/crud/contentEntry/abstractions/IGetEntry.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetLatestEntriesByIds.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetLatestEntriesByIds.js +7 -0
- package/crud/contentEntry/abstractions/IGetLatestEntriesByIds.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetLatestRevisionByEntryId.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetLatestRevisionByEntryId.js +7 -0
- package/crud/contentEntry/abstractions/IGetLatestRevisionByEntryId.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetPreviousRevisionByEntryId.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetPreviousRevisionByEntryId.js +7 -0
- package/crud/contentEntry/abstractions/IGetPreviousRevisionByEntryId.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetPublishedEntriesByIds.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetPublishedEntriesByIds.js +7 -0
- package/crud/contentEntry/abstractions/IGetPublishedEntriesByIds.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetPublishedRevisionByEntryId.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetPublishedRevisionByEntryId.js +7 -0
- package/crud/contentEntry/abstractions/IGetPublishedRevisionByEntryId.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetRevisionById.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetRevisionById.js +7 -0
- package/crud/contentEntry/abstractions/IGetRevisionById.js.map +1 -0
- package/crud/contentEntry/abstractions/IGetRevisionsByEntryId.d.ts +4 -0
- package/crud/contentEntry/abstractions/IGetRevisionsByEntryId.js +7 -0
- package/crud/contentEntry/abstractions/IGetRevisionsByEntryId.js.map +1 -0
- package/crud/contentEntry/abstractions/IListEntries.d.ts +4 -0
- package/crud/contentEntry/abstractions/IListEntries.js +7 -0
- package/crud/contentEntry/abstractions/IListEntries.js.map +1 -0
- package/crud/contentEntry/abstractions/IListEntriesOperation.d.ts +4 -0
- package/crud/contentEntry/abstractions/IListEntriesOperation.js +7 -0
- package/crud/contentEntry/abstractions/IListEntriesOperation.js.map +1 -0
- package/crud/contentEntry/abstractions/IMoveEntryToBinOperation.d.ts +4 -0
- package/crud/contentEntry/abstractions/IMoveEntryToBinOperation.js +7 -0
- package/crud/contentEntry/abstractions/IMoveEntryToBinOperation.js.map +1 -0
- package/crud/contentEntry/abstractions/IRestoreEntryFromBin.d.ts +4 -0
- package/crud/contentEntry/abstractions/IRestoreEntryFromBin.js +7 -0
- package/crud/contentEntry/abstractions/IRestoreEntryFromBin.js.map +1 -0
- package/crud/contentEntry/abstractions/IRestoreEntryFromBinOperation.d.ts +4 -0
- package/crud/contentEntry/abstractions/IRestoreEntryFromBinOperation.js +7 -0
- package/crud/contentEntry/abstractions/IRestoreEntryFromBinOperation.js.map +1 -0
- package/crud/contentEntry/abstractions/index.d.ts +16 -0
- package/crud/contentEntry/abstractions/index.js +183 -0
- package/crud/contentEntry/abstractions/index.js.map +1 -0
- package/crud/contentEntry/afterDelete.d.ts +6 -2
- package/crud/contentEntry/afterDelete.js +18 -2
- package/crud/contentEntry/afterDelete.js.map +1 -1
- package/crud/contentEntry/beforeCreate.d.ts +2 -2
- package/crud/contentEntry/beforeCreate.js +3 -1
- package/crud/contentEntry/beforeCreate.js.map +1 -1
- package/crud/contentEntry/beforeUpdate.d.ts +2 -2
- package/crud/contentEntry/beforeUpdate.js +3 -1
- package/crud/contentEntry/beforeUpdate.js.map +1 -1
- package/crud/contentEntry/entryDataFactories/createEntryData.d.ts +20 -0
- package/crud/contentEntry/entryDataFactories/createEntryData.js +254 -0
- package/crud/contentEntry/entryDataFactories/createEntryData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/createEntryRevisionFromData.d.ts +23 -0
- package/crud/contentEntry/entryDataFactories/createEntryRevisionFromData.js +157 -0
- package/crud/contentEntry/entryDataFactories/createEntryRevisionFromData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/createPublishEntryData.d.ts +13 -0
- package/crud/contentEntry/entryDataFactories/createPublishEntryData.js +63 -0
- package/crud/contentEntry/entryDataFactories/createPublishEntryData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/createRepublishEntryData.d.ts +12 -0
- package/crud/contentEntry/entryDataFactories/createRepublishEntryData.js +59 -0
- package/crud/contentEntry/entryDataFactories/createRepublishEntryData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/createUnpublishEntryData.d.ts +12 -0
- package/crud/contentEntry/entryDataFactories/createUnpublishEntryData.js +40 -0
- package/crud/contentEntry/entryDataFactories/createUnpublishEntryData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/createUpdateEntryData.d.ts +20 -0
- package/crud/contentEntry/entryDataFactories/createUpdateEntryData.js +130 -0
- package/crud/contentEntry/entryDataFactories/createUpdateEntryData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/index.d.ts +8 -0
- package/crud/contentEntry/entryDataFactories/index.js +95 -0
- package/crud/contentEntry/entryDataFactories/index.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/mapAndCleanUpdatedInputData.d.ts +5 -0
- package/crud/contentEntry/entryDataFactories/mapAndCleanUpdatedInputData.js +36 -0
- package/crud/contentEntry/entryDataFactories/mapAndCleanUpdatedInputData.js.map +1 -0
- package/crud/contentEntry/entryDataFactories/statuses.d.ts +4 -0
- package/crud/contentEntry/entryDataFactories/statuses.js +12 -0
- package/crud/contentEntry/entryDataFactories/statuses.js.map +1 -0
- package/crud/contentEntry/entryDataValidation.d.ts +5 -3
- package/crud/contentEntry/entryDataValidation.js +223 -45
- package/crud/contentEntry/entryDataValidation.js.map +1 -1
- package/crud/contentEntry/markLockedFields.d.ts +1 -1
- package/crud/contentEntry/markLockedFields.js +20 -10
- package/crud/contentEntry/markLockedFields.js.map +1 -1
- package/crud/contentEntry/referenceFieldsMapping.d.ts +7 -1
- package/crud/contentEntry/referenceFieldsMapping.js +143 -91
- package/crud/contentEntry/referenceFieldsMapping.js.map +1 -1
- package/crud/contentEntry/searchableFields.d.ts +2 -2
- package/crud/contentEntry/searchableFields.js +5 -4
- package/crud/contentEntry/searchableFields.js.map +1 -1
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntry.d.ts +10 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntry.js +58 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntry.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperation.d.ts +7 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperation.js +17 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperation.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperationWithEvents.d.ts +9 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperationWithEvents.js +45 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntryOperationWithEvents.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntrySecure.d.ts +9 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntrySecure.js +22 -0
- package/crud/contentEntry/useCases/DeleteEntry/DeleteEntrySecure.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBin.d.ts +10 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBin.js +33 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBin.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperation.d.ts +7 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperation.js +17 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperation.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperationWithEvents.d.ts +9 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperationWithEvents.js +45 -0
- package/crud/contentEntry/useCases/DeleteEntry/MoveEntryToBinOperationWithEvents.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/TransformEntryDelete.d.ts +6 -0
- package/crud/contentEntry/useCases/DeleteEntry/TransformEntryDelete.js +21 -0
- package/crud/contentEntry/useCases/DeleteEntry/TransformEntryDelete.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/TransformEntryMoveToBin.d.ts +9 -0
- package/crud/contentEntry/useCases/DeleteEntry/TransformEntryMoveToBin.js +54 -0
- package/crud/contentEntry/useCases/DeleteEntry/TransformEntryMoveToBin.js.map +1 -0
- package/crud/contentEntry/useCases/DeleteEntry/index.d.ts +28 -0
- package/crud/contentEntry/useCases/DeleteEntry/index.js +42 -0
- package/crud/contentEntry/useCases/DeleteEntry/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.d.ts +7 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.js +17 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.js.map +1 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsNotDeleted.js +18 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsSecure.d.ts +9 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsSecure.js +28 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIdsSecure.js.map +1 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/index.d.ts +11 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/index.js +20 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.d.ts +7 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.js +17 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsNotDeleted.js +18 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsSecure.d.ts +9 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsSecure.js +28 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIdsSecure.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/index.d.ts +11 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/index.js +20 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.d.ts +7 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.js +17 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdDeleted.js +21 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdNotDeleted.js +21 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryIdNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/index.d.ts +13 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/index.js +22 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.d.ts +7 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.js +17 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.js.map +1 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryIdNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryIdNotDeleted.js +21 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryIdNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/index.d.ts +9 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/index.js +18 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.d.ts +7 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.js +17 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsNotDeleted.js +18 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsSecure.d.ts +9 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsSecure.js +28 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIdsSecure.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/index.d.ts +11 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/index.js +20 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.d.ts +7 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.js +17 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryIdNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryIdNotDeleted.js +21 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryIdNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/index.d.ts +9 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/index.js +18 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.d.ts +7 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.js +17 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.js.map +1 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionByIdNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionByIdNotDeleted.js +21 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionByIdNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetRevisionById/index.d.ts +9 -0
- package/crud/contentEntry/useCases/GetRevisionById/index.js +18 -0
- package/crud/contentEntry/useCases/GetRevisionById/index.js.map +1 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.d.ts +7 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.js +17 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.js.map +1 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryIdNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryIdNotDeleted.js +18 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryIdNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/index.d.ts +11 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/index.js +18 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/index.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/GetEntry.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/GetEntry.js +29 -0
- package/crud/contentEntry/useCases/ListEntries/GetEntry.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/GetEntrySecure.d.ts +11 -0
- package/crud/contentEntry/useCases/ListEntries/GetEntrySecure.js +38 -0
- package/crud/contentEntry/useCases/ListEntries/GetEntrySecure.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntries.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntries.js +62 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntries.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.js +17 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationDeleted.js +24 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationLatest.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationLatest.js +25 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationLatest.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationNotDeleted.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationNotDeleted.js +24 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationNotDeleted.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationPublished.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationPublished.js +24 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationPublished.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithEvents.d.ts +9 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithEvents.js +22 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithEvents.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSearchableFields.d.ts +8 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSearchableFields.js +27 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSearchableFields.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSort.d.ts +8 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSort.js +26 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithSort.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithStatusCheck.d.ts +7 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithStatusCheck.js +36 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperationWithStatusCheck.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesSecure.d.ts +11 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesSecure.js +41 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesSecure.js.map +1 -0
- package/crud/contentEntry/useCases/ListEntries/index.d.ts +24 -0
- package/crud/contentEntry/useCases/ListEntries/index.js +61 -0
- package/crud/contentEntry/useCases/ListEntries/index.js.map +1 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBin.d.ts +10 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBin.js +37 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBin.js.map +1 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.d.ts +7 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.js +17 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.js.map +1 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperationWithEvents.d.ts +9 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperationWithEvents.js +42 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperationWithEvents.js.map +1 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinSecure.d.ts +9 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinSecure.js +22 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinSecure.js.map +1 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/TransformEntryRestoreFromBin.d.ts +9 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/TransformEntryRestoreFromBin.js +53 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/TransformEntryRestoreFromBin.js.map +1 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/index.d.ts +23 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/index.js +24 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/index.js.map +1 -0
- package/crud/contentEntry/useCases/index.d.ts +11 -0
- package/crud/contentEntry/useCases/index.js +128 -0
- package/crud/contentEntry/useCases/index.js.map +1 -0
- package/crud/contentEntry.crud.d.ts +9 -7
- package/crud/contentEntry.crud.js +1045 -998
- package/crud/contentEntry.crud.js.map +1 -1
- package/crud/contentModel/beforeCreate.d.ts +2 -2
- package/crud/contentModel/beforeCreate.js +50 -85
- package/crud/contentModel/beforeCreate.js.map +1 -1
- package/crud/contentModel/beforeDelete.d.ts +3 -5
- package/crud/contentModel/beforeDelete.js +52 -20
- package/crud/contentModel/beforeDelete.js.map +1 -1
- package/crud/contentModel/beforeUpdate.d.ts +2 -2
- package/crud/contentModel/beforeUpdate.js +31 -6
- package/crud/contentModel/beforeUpdate.js.map +1 -1
- package/crud/contentModel/compatibility/modelApiName.d.ts +3 -0
- package/crud/contentModel/compatibility/modelApiName.js +26 -0
- package/crud/contentModel/compatibility/modelApiName.js.map +1 -0
- package/crud/contentModel/contentModelManagerFactory.d.ts +2 -2
- package/crud/contentModel/contentModelManagerFactory.js +3 -1
- package/crud/contentModel/contentModelManagerFactory.js.map +1 -1
- package/crud/contentModel/createFieldStorageId.d.ts +1 -1
- package/crud/contentModel/createFieldStorageId.js +3 -1
- package/crud/contentModel/createFieldStorageId.js.map +1 -1
- package/crud/contentModel/defaultFields.d.ts +5 -0
- package/crud/contentModel/defaultFields.js +60 -0
- package/crud/contentModel/defaultFields.js.map +1 -0
- package/crud/contentModel/ensureTypeTag.d.ts +5 -0
- package/crud/contentModel/ensureTypeTag.js +21 -0
- package/crud/contentModel/ensureTypeTag.js.map +1 -0
- package/crud/contentModel/fields/descriptionField.d.ts +6 -0
- package/crud/contentModel/fields/descriptionField.js +30 -0
- package/crud/contentModel/fields/descriptionField.js.map +1 -0
- package/crud/contentModel/fields/getApplicableFieldById.d.ts +2 -0
- package/crud/contentModel/fields/getApplicableFieldById.js +15 -0
- package/crud/contentModel/fields/getApplicableFieldById.js.map +1 -0
- package/crud/contentModel/fields/imageField.d.ts +2 -0
- package/crud/contentModel/fields/imageField.js +25 -0
- package/crud/contentModel/fields/imageField.js.map +1 -0
- package/crud/contentModel/fields/titleField.d.ts +6 -0
- package/crud/contentModel/fields/titleField.js +31 -0
- package/crud/contentModel/fields/titleField.js.map +1 -0
- package/crud/contentModel/listModelsFromDatabase.d.ts +10 -0
- package/crud/contentModel/listModelsFromDatabase.js +38 -0
- package/crud/contentModel/listModelsFromDatabase.js.map +1 -0
- package/crud/contentModel/validate/endingAllowed.d.ts +6 -0
- package/crud/contentModel/validate/endingAllowed.js +28 -0
- package/crud/contentModel/validate/endingAllowed.js.map +1 -0
- package/crud/contentModel/validate/isModelEndingAllowed.d.ts +6 -0
- package/crud/contentModel/validate/isModelEndingAllowed.js +25 -0
- package/crud/contentModel/validate/isModelEndingAllowed.js.map +1 -0
- package/crud/contentModel/validate/modelId.d.ts +11 -0
- package/crud/contentModel/validate/modelId.js +38 -0
- package/crud/contentModel/validate/modelId.js.map +1 -0
- package/crud/contentModel/validate/pluralApiName.d.ts +7 -0
- package/crud/contentModel/validate/pluralApiName.js +26 -0
- package/crud/contentModel/validate/pluralApiName.js.map +1 -0
- package/crud/contentModel/validate/singularApiName.d.ts +7 -0
- package/crud/contentModel/validate/singularApiName.js +26 -0
- package/crud/contentModel/validate/singularApiName.js.map +1 -0
- package/crud/contentModel/validateModel.d.ts +2 -1
- package/crud/contentModel/validateModel.js +3 -1
- package/crud/contentModel/validateModel.js.map +1 -1
- package/crud/contentModel/validateModelFields.d.ts +2 -1
- package/crud/contentModel/validateModelFields.js +27 -64
- package/crud/contentModel/validateModelFields.js.map +1 -1
- package/crud/contentModel/validateStorageId.d.ts +1 -0
- package/crud/contentModel/validateStorageId.js +19 -0
- package/crud/contentModel/validateStorageId.js.map +1 -0
- package/crud/contentModel/validation.d.ts +611 -195
- package/crud/contentModel/validation.js +130 -22
- package/crud/contentModel/validation.js.map +1 -1
- package/crud/contentModel.crud.d.ts +6 -4
- package/crud/contentModel.crud.js +480 -415
- package/crud/contentModel.crud.js.map +1 -1
- package/crud/contentModelGroup/beforeCreate.d.ts +3 -3
- package/crud/contentModelGroup/beforeCreate.js +15 -1
- package/crud/contentModelGroup/beforeCreate.js.map +1 -1
- package/crud/contentModelGroup/beforeDelete.d.ts +3 -3
- package/crud/contentModelGroup/beforeDelete.js +3 -1
- package/crud/contentModelGroup/beforeDelete.js.map +1 -1
- package/crud/contentModelGroup/beforeUpdate.d.ts +3 -3
- package/crud/contentModelGroup/beforeUpdate.js +3 -1
- package/crud/contentModelGroup/beforeUpdate.js.map +1 -1
- package/crud/contentModelGroup/listGroupsFromDatabase.d.ts +8 -0
- package/crud/contentModelGroup/listGroupsFromDatabase.js +22 -0
- package/crud/contentModelGroup/listGroupsFromDatabase.js.map +1 -0
- package/crud/contentModelGroup/validation.d.ts +10 -7
- package/crud/contentModelGroup/validation.js +5 -2
- package/crud/contentModelGroup/validation.js.map +1 -1
- package/crud/contentModelGroup.crud.d.ts +6 -4
- package/crud/contentModelGroup.crud.js +261 -228
- package/crud/contentModelGroup.crud.js.map +1 -1
- package/crud/system.crud.d.ts +4 -4
- package/crud/system.crud.js +18 -71
- package/crud/system.crud.js.map +1 -1
- package/export/crud/exporting.d.ts +3 -0
- package/export/crud/exporting.js +49 -0
- package/export/crud/exporting.js.map +1 -0
- package/export/crud/importing.d.ts +3 -0
- package/export/crud/importing.js +79 -0
- package/export/crud/importing.js.map +1 -0
- package/export/crud/imports/importData.d.ts +14 -0
- package/export/crud/imports/importData.js +52 -0
- package/export/crud/imports/importData.js.map +1 -0
- package/export/crud/imports/importGroups.d.ts +8 -0
- package/export/crud/imports/importGroups.js +104 -0
- package/export/crud/imports/importGroups.js.map +1 -0
- package/export/crud/imports/importModels.d.ts +8 -0
- package/export/crud/imports/importModels.js +136 -0
- package/export/crud/imports/importModels.js.map +1 -0
- package/export/crud/imports/validateGroups.d.ts +8 -0
- package/export/crud/imports/validateGroups.js +112 -0
- package/export/crud/imports/validateGroups.js.map +1 -0
- package/export/crud/imports/validateInput.d.ts +19 -0
- package/export/crud/imports/validateInput.js +55 -0
- package/export/crud/imports/validateInput.js.map +1 -0
- package/export/crud/imports/validateModels.d.ts +12 -0
- package/export/crud/imports/validateModels.js +203 -0
- package/export/crud/imports/validateModels.js.map +1 -0
- package/export/crud/index.d.ts +4 -0
- package/export/crud/index.js +15 -0
- package/export/crud/index.js.map +1 -0
- package/export/crud/sanitize.d.ts +4 -0
- package/export/crud/sanitize.js +36 -0
- package/export/crud/sanitize.js.map +1 -0
- package/export/graphql/index.d.ts +3 -0
- package/export/graphql/index.js +188 -0
- package/export/graphql/index.js.map +1 -0
- package/export/index.d.ts +2 -0
- package/export/index.js +29 -0
- package/export/index.js.map +1 -0
- package/export/types.d.ts +113 -0
- package/export/types.js +21 -0
- package/export/types.js.map +1 -0
- package/fieldConverters/CmsModelDefaultFieldConverterPlugin.d.ts +5 -3
- package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js +4 -7
- package/fieldConverters/CmsModelDefaultFieldConverterPlugin.js.map +1 -1
- package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.d.ts +3 -2
- package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js +28 -73
- package/fieldConverters/CmsModelDynamicZoneFieldConverterPlugin.js.map +1 -1
- package/fieldConverters/CmsModelObjectFieldConverterPlugin.d.ts +3 -2
- package/fieldConverters/CmsModelObjectFieldConverterPlugin.js +49 -40
- package/fieldConverters/CmsModelObjectFieldConverterPlugin.js.map +1 -1
- package/fieldConverters/index.d.ts +3 -0
- package/fieldConverters/index.js +7 -1
- package/fieldConverters/index.js.map +1 -1
- package/graphql/buildSchemaPlugins.d.ts +3 -3
- package/graphql/buildSchemaPlugins.js +7 -1
- package/graphql/buildSchemaPlugins.js.map +1 -1
- package/graphql/checkEndpointAccess.d.ts +2 -0
- package/graphql/checkEndpointAccess.js +20 -0
- package/graphql/checkEndpointAccess.js.map +1 -0
- package/graphql/createExecutableSchema.d.ts +2 -3
- package/graphql/createExecutableSchema.js +17 -8
- package/graphql/createExecutableSchema.js.map +1 -1
- package/graphql/createRequestBody.d.ts +2 -0
- package/graphql/createRequestBody.js +16 -0
- package/graphql/createRequestBody.js.map +1 -0
- package/graphql/formatErrorPayload.d.ts +1 -0
- package/graphql/formatErrorPayload.js +27 -0
- package/graphql/formatErrorPayload.js.map +1 -0
- package/graphql/generateSchema.d.ts +2 -2
- package/graphql/generateSchema.js +9 -2
- package/graphql/generateSchema.js.map +1 -1
- package/graphql/getSchema/generateCacheId.d.ts +10 -0
- package/graphql/getSchema/generateCacheId.js +17 -0
- package/graphql/getSchema/generateCacheId.js.map +1 -0
- package/graphql/getSchema/generateCacheKey.d.ts +10 -0
- package/graphql/getSchema/generateCacheKey.js +34 -0
- package/graphql/getSchema/generateCacheKey.js.map +1 -0
- package/graphql/getSchema.d.ts +16 -0
- package/graphql/getSchema.js +81 -0
- package/graphql/getSchema.js.map +1 -0
- package/graphql/graphQLHandlerFactory.d.ts +2 -2
- package/graphql/graphQLHandlerFactory.js +9 -146
- package/graphql/graphQLHandlerFactory.js.map +1 -1
- package/graphql/handleRequest.d.ts +11 -0
- package/graphql/handleRequest.js +86 -0
- package/graphql/handleRequest.js.map +1 -0
- package/graphql/index.d.ts +4 -3
- package/graphql/index.js +4 -2
- package/graphql/index.js.map +1 -1
- package/graphql/scalars/RevisionId.d.ts +2 -0
- package/graphql/scalars/RevisionId.js +26 -0
- package/graphql/scalars/RevisionId.js.map +1 -0
- package/graphql/scalars/RevisionIdScalarPlugin.d.ts +2 -0
- package/graphql/scalars/RevisionIdScalarPlugin.js +18 -0
- package/graphql/scalars/RevisionIdScalarPlugin.js.map +1 -0
- package/graphql/schema/baseContentSchema.d.ts +3 -3
- package/graphql/schema/baseContentSchema.js +10 -21
- package/graphql/schema/baseContentSchema.js.map +1 -1
- package/graphql/schema/baseSchema.d.ts +2 -3
- package/graphql/schema/baseSchema.js +103 -3
- package/graphql/schema/baseSchema.js.map +1 -1
- package/graphql/schema/contentEntries.d.ts +3 -3
- package/graphql/schema/contentEntries.js +135 -61
- package/graphql/schema/contentEntries.js.map +1 -1
- package/graphql/schema/contentModelGroups.d.ts +3 -3
- package/graphql/schema/contentModelGroups.js +13 -10
- package/graphql/schema/contentModelGroups.js.map +1 -1
- package/graphql/schema/contentModels.d.ts +4 -5
- package/graphql/schema/contentModels.js +54 -19
- package/graphql/schema/contentModels.js.map +1 -1
- package/graphql/schema/createFieldResolvers.d.ts +2 -2
- package/graphql/schema/createFieldResolvers.js +18 -24
- package/graphql/schema/createFieldResolvers.js.map +1 -1
- package/graphql/schema/createFieldTypePluginRecords.d.ts +3 -0
- package/graphql/schema/createFieldTypePluginRecords.js +15 -0
- package/graphql/schema/createFieldTypePluginRecords.js.map +1 -0
- package/graphql/schema/createManageResolvers.d.ts +1 -2
- package/graphql/schema/createManageResolvers.js +63 -55
- package/graphql/schema/createManageResolvers.js.map +1 -1
- package/graphql/schema/createManageSDL.d.ts +3 -2
- package/graphql/schema/createManageSDL.js +125 -69
- package/graphql/schema/createManageSDL.js.map +1 -1
- package/graphql/schema/createPreviewResolvers.d.ts +1 -2
- package/graphql/schema/createPreviewResolvers.js +14 -20
- package/graphql/schema/createPreviewResolvers.js.map +1 -1
- package/graphql/schema/createReadResolvers.d.ts +1 -2
- package/graphql/schema/createReadResolvers.js +15 -21
- package/graphql/schema/createReadResolvers.js.map +1 -1
- package/graphql/schema/createReadSDL.d.ts +3 -2
- package/graphql/schema/createReadSDL.js +50 -38
- package/graphql/schema/createReadSDL.js.map +1 -1
- package/graphql/schema/createSingularResolvers.d.ts +12 -0
- package/graphql/schema/createSingularResolvers.js +56 -0
- package/graphql/schema/createSingularResolvers.js.map +1 -0
- package/graphql/schema/createSingularSDL.d.ts +12 -0
- package/graphql/schema/createSingularSDL.js +95 -0
- package/graphql/schema/createSingularSDL.js.map +1 -0
- package/graphql/schema/resolvers/manage/normalizeGraphQlInput.d.ts +7 -0
- package/graphql/schema/resolvers/manage/normalizeGraphQlInput.js +59 -0
- package/graphql/schema/resolvers/manage/normalizeGraphQlInput.js.map +1 -0
- package/graphql/schema/resolvers/manage/resolveCreate.d.ts +3 -2
- package/graphql/schema/resolvers/manage/resolveCreate.js +4 -2
- package/graphql/schema/resolvers/manage/resolveCreate.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveCreateFrom.d.ts +3 -2
- package/graphql/schema/resolvers/manage/resolveCreateFrom.js +4 -2
- package/graphql/schema/resolvers/manage/resolveCreateFrom.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveDelete.d.ts +3 -2
- package/graphql/schema/resolvers/manage/resolveDelete.js +17 -4
- package/graphql/schema/resolvers/manage/resolveDelete.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveDeleteMultiple.d.ts +7 -0
- package/graphql/schema/resolvers/manage/resolveDeleteMultiple.js +22 -0
- package/graphql/schema/resolvers/manage/resolveDeleteMultiple.js.map +1 -0
- package/graphql/schema/resolvers/manage/resolveGet.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolveGet.js +12 -5
- package/graphql/schema/resolvers/manage/resolveGet.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveGetByIds.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolveGetByIds.js +3 -1
- package/graphql/schema/resolvers/manage/resolveGetByIds.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveGetRevisions.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolveGetRevisions.js +3 -1
- package/graphql/schema/resolvers/manage/resolveGetRevisions.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveGetUniqueFieldValues.d.ts +4 -0
- package/graphql/schema/resolvers/manage/resolveGetUniqueFieldValues.js +20 -0
- package/graphql/schema/resolvers/manage/resolveGetUniqueFieldValues.js.map +1 -0
- package/graphql/schema/resolvers/manage/resolveList.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolveList.js +3 -1
- package/graphql/schema/resolvers/manage/resolveList.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveListDeleted.d.ts +4 -0
- package/graphql/schema/resolvers/manage/resolveListDeleted.js +20 -0
- package/graphql/schema/resolvers/manage/resolveListDeleted.js.map +1 -0
- package/graphql/schema/resolvers/manage/resolveMove.d.ts +8 -0
- package/graphql/schema/resolvers/manage/resolveMove.js +27 -0
- package/graphql/schema/resolvers/manage/resolveMove.js.map +1 -0
- package/graphql/schema/resolvers/manage/resolvePublish.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolvePublish.js +3 -1
- package/graphql/schema/resolvers/manage/resolvePublish.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveRepublish.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolveRepublish.js +3 -1
- package/graphql/schema/resolvers/manage/resolveRepublish.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveRestoreFromBin.d.ts +7 -0
- package/graphql/schema/resolvers/manage/resolveRestoreFromBin.js +20 -0
- package/graphql/schema/resolvers/manage/resolveRestoreFromBin.js.map +1 -0
- package/graphql/schema/resolvers/manage/resolveUnpublish.d.ts +2 -2
- package/graphql/schema/resolvers/manage/resolveUnpublish.js +3 -1
- package/graphql/schema/resolvers/manage/resolveUnpublish.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveUpdate.d.ts +3 -2
- package/graphql/schema/resolvers/manage/resolveUpdate.js +4 -2
- package/graphql/schema/resolvers/manage/resolveUpdate.js.map +1 -1
- package/graphql/schema/resolvers/manage/resolveValidate.d.ts +8 -0
- package/graphql/schema/resolvers/manage/resolveValidate.js +20 -0
- package/graphql/schema/resolvers/manage/resolveValidate.js.map +1 -0
- package/graphql/schema/resolvers/preview/resolveGet.d.ts +2 -2
- package/graphql/schema/resolvers/preview/resolveGet.js +6 -5
- package/graphql/schema/resolvers/preview/resolveGet.js.map +1 -1
- package/graphql/schema/resolvers/preview/resolveList.d.ts +2 -2
- package/graphql/schema/resolvers/preview/resolveList.js +3 -1
- package/graphql/schema/resolvers/preview/resolveList.js.map +1 -1
- package/graphql/schema/resolvers/read/resolveGet.d.ts +2 -2
- package/graphql/schema/resolvers/read/resolveGet.js +6 -5
- package/graphql/schema/resolvers/read/resolveGet.js.map +1 -1
- package/graphql/schema/resolvers/read/resolveList.d.ts +2 -2
- package/graphql/schema/resolvers/read/resolveList.js +3 -1
- package/graphql/schema/resolvers/read/resolveList.js.map +1 -1
- package/graphql/schema/resolvers/singular/resolveGet.d.ts +7 -0
- package/graphql/schema/resolvers/singular/resolveGet.js +21 -0
- package/graphql/schema/resolvers/singular/resolveGet.js.map +1 -0
- package/graphql/schema/resolvers/singular/resolveUpdate.d.ts +8 -0
- package/graphql/schema/resolvers/singular/resolveUpdate.js +21 -0
- package/graphql/schema/resolvers/singular/resolveUpdate.js.map +1 -0
- package/graphql/schema/schemaPlugins.d.ts +3 -3
- package/graphql/schema/schemaPlugins.js +39 -25
- package/graphql/schema/schemaPlugins.js.map +1 -1
- package/graphql/system.d.ts +3 -6
- package/graphql/system.js +6 -29
- package/graphql/system.js.map +1 -1
- package/graphqlFields/boolean.d.ts +1 -1
- package/graphqlFields/boolean.js +3 -1
- package/graphqlFields/boolean.js.map +1 -1
- package/graphqlFields/datetime.d.ts +1 -1
- package/graphqlFields/datetime.js +5 -5
- package/graphqlFields/datetime.js.map +1 -1
- package/graphqlFields/dynamicZone/dynamicZoneField.d.ts +1 -1
- package/graphqlFields/dynamicZone/dynamicZoneField.js +142 -30
- package/graphqlFields/dynamicZone/dynamicZoneField.js.map +1 -1
- package/graphqlFields/dynamicZone/index.d.ts +0 -1
- package/graphqlFields/dynamicZone/index.js +2 -7
- package/graphqlFields/dynamicZone/index.js.map +1 -1
- package/graphqlFields/file.d.ts +1 -1
- package/graphqlFields/file.js +3 -1
- package/graphqlFields/file.js.map +1 -1
- package/graphqlFields/helpers.d.ts +1 -2
- package/graphqlFields/helpers.js +6 -18
- package/graphqlFields/helpers.js.map +1 -1
- package/graphqlFields/index.d.ts +1 -1
- package/graphqlFields/index.js +6 -2
- package/graphqlFields/index.js.map +1 -1
- package/graphqlFields/json.d.ts +2 -0
- package/graphqlFields/json.js +49 -0
- package/graphqlFields/json.js.map +1 -0
- package/graphqlFields/longText.d.ts +1 -1
- package/graphqlFields/longText.js +14 -3
- package/graphqlFields/longText.js.map +1 -1
- package/graphqlFields/number.d.ts +1 -1
- package/graphqlFields/number.js +4 -1
- package/graphqlFields/number.js.map +1 -1
- package/graphqlFields/object.d.ts +2 -2
- package/graphqlFields/object.js +47 -34
- package/graphqlFields/object.js.map +1 -1
- package/graphqlFields/ref.d.ts +1 -1
- package/graphqlFields/ref.js +69 -29
- package/graphqlFields/ref.js.map +1 -1
- package/graphqlFields/richText/RichTextPluginsProcessor.d.ts +6 -0
- package/graphqlFields/richText/RichTextPluginsProcessor.js +34 -0
- package/graphqlFields/richText/RichTextPluginsProcessor.js.map +1 -0
- package/graphqlFields/richText/richTextResolver.d.ts +7 -0
- package/graphqlFields/richText/richTextResolver.js +24 -0
- package/graphqlFields/richText/richTextResolver.js.map +1 -0
- package/graphqlFields/richText.d.ts +1 -1
- package/graphqlFields/richText.js +11 -3
- package/graphqlFields/richText.js.map +1 -1
- package/graphqlFields/searchableJson.d.ts +2 -0
- package/graphqlFields/searchableJson.js +55 -0
- package/graphqlFields/searchableJson.js.map +1 -0
- package/graphqlFields/text.d.ts +1 -1
- package/graphqlFields/text.js +5 -1
- package/graphqlFields/text.js.map +1 -1
- package/htmlRenderer/LexicalRenderer.d.ts +5 -0
- package/htmlRenderer/LexicalRenderer.js +28 -0
- package/htmlRenderer/LexicalRenderer.js.map +1 -0
- package/htmlRenderer/createLexicalHTMLRenderer.d.ts +2 -0
- package/htmlRenderer/createLexicalHTMLRenderer.js +31 -0
- package/htmlRenderer/createLexicalHTMLRenderer.js.map +1 -0
- package/index.d.ts +15 -6
- package/index.js +106 -8
- package/index.js.map +1 -1
- package/modelManager/DefaultCmsModelManager.d.ts +11 -10
- package/modelManager/DefaultCmsModelManager.js +19 -18
- package/modelManager/DefaultCmsModelManager.js.map +1 -1
- package/modelManager/SingletonModelManager.d.ts +12 -0
- package/modelManager/SingletonModelManager.js +48 -0
- package/modelManager/SingletonModelManager.js.map +1 -0
- package/modelManager/index.d.ts +2 -1
- package/modelManager/index.js +19 -2
- package/modelManager/index.js.map +1 -1
- package/package.json +40 -45
- package/parameters/context.js +4 -2
- package/parameters/context.js.map +1 -1
- package/parameters/header.js +7 -6
- package/parameters/header.js.map +1 -1
- package/parameters/index.js +3 -1
- package/parameters/index.js.map +1 -1
- package/parameters/manual.d.ts +2 -1
- package/parameters/manual.js +9 -4
- package/parameters/manual.js.map +1 -1
- package/parameters/path.js +4 -3
- package/parameters/path.js.map +1 -1
- package/plugins/CmsGraphQLSchemaPlugin/CmsGraphQLSchemaPlugin.d.ts +9 -0
- package/plugins/CmsGraphQLSchemaPlugin/CmsGraphQLSchemaPlugin.js +17 -0
- package/plugins/CmsGraphQLSchemaPlugin/CmsGraphQLSchemaPlugin.js.map +1 -0
- package/plugins/CmsGraphQLSchemaPlugin/index.d.ts +1 -0
- package/plugins/CmsGraphQLSchemaPlugin/index.js +18 -0
- package/plugins/CmsGraphQLSchemaPlugin/index.js.map +1 -0
- package/plugins/CmsGraphQLSchemaSorterPlugin.d.ts +1 -1
- package/plugins/CmsGraphQLSchemaSorterPlugin.js +4 -5
- package/plugins/CmsGraphQLSchemaSorterPlugin.js.map +1 -1
- package/plugins/CmsGroupPlugin.d.ts +15 -4
- package/plugins/CmsGroupPlugin.js +25 -7
- package/plugins/CmsGroupPlugin.js.map +1 -1
- package/plugins/CmsModelFieldConverterPlugin.d.ts +5 -2
- package/plugins/CmsModelFieldConverterPlugin.js +9 -4
- package/plugins/CmsModelFieldConverterPlugin.js.map +1 -1
- package/plugins/CmsModelPlugin.d.ts +47 -7
- package/plugins/CmsModelPlugin.js +169 -32
- package/plugins/CmsModelPlugin.js.map +1 -1
- package/plugins/CmsParametersPlugin.d.ts +3 -3
- package/plugins/CmsParametersPlugin.js +7 -4
- package/plugins/CmsParametersPlugin.js.map +1 -1
- package/plugins/CmsRichTextRendererPlugin.d.ts +24 -0
- package/plugins/CmsRichTextRendererPlugin.js +28 -0
- package/plugins/CmsRichTextRendererPlugin.js.map +1 -0
- package/plugins/StorageOperationsCmsModelPlugin.d.ts +23 -0
- package/plugins/StorageOperationsCmsModelPlugin.js +41 -0
- package/plugins/StorageOperationsCmsModelPlugin.js.map +1 -0
- package/plugins/StorageTransformPlugin.d.ts +7 -3
- package/plugins/StorageTransformPlugin.js +12 -5
- package/plugins/StorageTransformPlugin.js.map +1 -1
- package/plugins/index.d.ts +2 -0
- package/plugins/index.js +25 -1
- package/plugins/index.js.map +1 -1
- package/storage/date.d.ts +3 -0
- package/storage/date.js +119 -0
- package/storage/date.js.map +1 -0
- package/storage/default.js +3 -1
- package/storage/default.js.map +1 -1
- package/storage/dynamicZone.d.ts +2 -0
- package/storage/dynamicZone.js +157 -0
- package/storage/dynamicZone.js.map +1 -0
- package/storage/index.d.ts +1 -0
- package/storage/index.js +21 -0
- package/storage/index.js.map +1 -0
- package/storage/json.d.ts +2 -0
- package/storage/json.js +56 -0
- package/storage/json.js.map +1 -0
- package/storage/object.js +24 -20
- package/storage/object.js.map +1 -1
- package/types/context.d.ts +146 -0
- package/types/context.js +7 -0
- package/types/context.js.map +1 -0
- package/types/fields/dynamicZoneField.d.ts +23 -0
- package/types/fields/dynamicZoneField.js +7 -0
- package/types/fields/dynamicZoneField.js.map +1 -0
- package/types/fields/objectField.d.ts +13 -0
- package/types/fields/objectField.js +7 -0
- package/types/fields/objectField.js.map +1 -0
- package/types/identity.d.ts +19 -0
- package/types/identity.js +7 -0
- package/types/identity.js.map +1 -0
- package/types/index.d.ts +10 -0
- package/types/index.js +117 -0
- package/types/index.js.map +1 -0
- package/types/model.d.ts +199 -0
- package/types/model.js +7 -0
- package/types/model.js.map +1 -0
- package/types/modelAst.d.ts +39 -0
- package/types/modelAst.js +7 -0
- package/types/modelAst.js.map +1 -0
- package/types/modelField.d.ts +330 -0
- package/types/modelField.js +7 -0
- package/types/modelField.js.map +1 -0
- package/types/modelGroup.d.ts +77 -0
- package/types/modelGroup.js +7 -0
- package/types/modelGroup.js.map +1 -0
- package/types/plugins.d.ts +365 -0
- package/types/plugins.js +7 -0
- package/types/plugins.js.map +1 -0
- package/types/types.d.ts +1897 -0
- package/{types.js → types/types.js} +33 -134
- package/types/types.js.map +1 -0
- package/utils/RichTextRenderer.d.ts +10 -0
- package/utils/RichTextRenderer.js +33 -0
- package/utils/RichTextRenderer.js.map +1 -0
- package/utils/caching/Cache.d.ts +5 -0
- package/utils/caching/Cache.js +48 -0
- package/utils/caching/Cache.js.map +1 -0
- package/utils/caching/CacheKey.d.ts +3 -0
- package/utils/caching/CacheKey.js +28 -0
- package/utils/caching/CacheKey.js.map +1 -0
- package/utils/caching/index.d.ts +2 -0
- package/utils/caching/index.js +29 -0
- package/utils/caching/index.js.map +1 -0
- package/utils/caching/types.d.ts +13 -0
- package/utils/caching/types.js +14 -0
- package/utils/caching/types.js.map +1 -0
- package/utils/contentEntryTraverser/ContentEntryTraverser.d.ts +13 -0
- package/utils/contentEntryTraverser/ContentEntryTraverser.js +97 -0
- package/utils/contentEntryTraverser/ContentEntryTraverser.js.map +1 -0
- package/utils/contentModelAst/CmsModelFieldToAstConverterFromPlugins.d.ts +6 -0
- package/utils/contentModelAst/CmsModelFieldToAstConverterFromPlugins.js +23 -0
- package/utils/contentModelAst/CmsModelFieldToAstConverterFromPlugins.js.map +1 -0
- package/utils/contentModelAst/CmsModelFieldToAstFromPlugin.d.ts +7 -0
- package/utils/contentModelAst/CmsModelFieldToAstFromPlugin.js +22 -0
- package/utils/contentModelAst/CmsModelFieldToAstFromPlugin.js.map +1 -0
- package/utils/contentModelAst/CmsModelToAstConverter.d.ts +11 -0
- package/utils/contentModelAst/CmsModelToAstConverter.js +28 -0
- package/utils/contentModelAst/CmsModelToAstConverter.js.map +1 -0
- package/utils/contentModelAst/index.d.ts +3 -0
- package/utils/contentModelAst/index.js +40 -0
- package/utils/contentModelAst/index.js.map +1 -0
- package/utils/converters/Converter.d.ts +3 -3
- package/utils/converters/Converter.js +4 -5
- package/utils/converters/Converter.js.map +1 -1
- package/utils/converters/ConverterCollection.d.ts +2 -2
- package/utils/converters/ConverterCollection.js +13 -7
- package/utils/converters/ConverterCollection.js.map +1 -1
- package/utils/converters/valueKeyStorageConverter.d.ts +4 -8
- package/utils/converters/valueKeyStorageConverter.js +34 -21
- package/utils/converters/valueKeyStorageConverter.js.map +1 -1
- package/utils/createModelField.d.ts +7 -0
- package/utils/createModelField.js +51 -0
- package/utils/createModelField.js.map +1 -0
- package/utils/createTypeFromFields.d.ts +2 -1
- package/utils/createTypeFromFields.js +14 -7
- package/utils/createTypeFromFields.js.map +1 -1
- package/utils/createTypeName.d.ts +0 -2
- package/utils/createTypeName.js +3 -9
- package/utils/createTypeName.js.map +1 -1
- package/utils/date.d.ts +10 -0
- package/utils/date.js +36 -0
- package/utils/date.js.map +1 -0
- package/utils/entryStorage.d.ts +9 -4
- package/utils/entryStorage.js +8 -5
- package/utils/entryStorage.js.map +1 -1
- package/utils/filterAsync.js +9 -8
- package/utils/filterAsync.js.map +1 -1
- package/utils/getBaseFieldType.d.ts +2 -4
- package/utils/getBaseFieldType.js +3 -1
- package/utils/getBaseFieldType.js.map +1 -1
- package/utils/getEntryDescription.d.ts +2 -0
- package/utils/getEntryDescription.js +19 -0
- package/utils/getEntryDescription.js.map +1 -0
- package/utils/getEntryImage.d.ts +2 -0
- package/utils/getEntryImage.js +19 -0
- package/utils/getEntryImage.js.map +1 -0
- package/utils/getEntryTitle.d.ts +2 -2
- package/utils/getEntryTitle.js +3 -1
- package/utils/getEntryTitle.js.map +1 -1
- package/utils/getSchemaFromFieldPlugins.d.ts +14 -3
- package/utils/getSchemaFromFieldPlugins.js +25 -6
- package/utils/getSchemaFromFieldPlugins.js.map +1 -1
- package/utils/identity.d.ts +2 -0
- package/utils/identity.js +20 -0
- package/utils/identity.js.map +1 -0
- package/utils/incrementEntryIdVersion.d.ts +5 -0
- package/utils/incrementEntryIdVersion.js +31 -0
- package/utils/incrementEntryIdVersion.js.map +1 -0
- package/utils/index.d.ts +2 -0
- package/utils/index.js +29 -0
- package/utils/index.js.map +1 -0
- package/utils/isHeadlessCmsReady.d.ts +2 -0
- package/utils/isHeadlessCmsReady.js +23 -0
- package/utils/isHeadlessCmsReady.js.map +1 -0
- package/utils/modelFieldTraverser/ModelFieldTraverser.d.ts +16 -0
- package/utils/modelFieldTraverser/ModelFieldTraverser.js +41 -0
- package/utils/modelFieldTraverser/ModelFieldTraverser.js.map +1 -0
- package/utils/modelFieldTraverser/index.d.ts +1 -0
- package/utils/modelFieldTraverser/index.js +18 -0
- package/utils/modelFieldTraverser/index.js.map +1 -0
- package/utils/renderFields.d.ts +5 -3
- package/utils/renderFields.js +15 -3
- package/utils/renderFields.js.map +1 -1
- package/utils/renderGetFilterFields.d.ts +2 -2
- package/utils/renderGetFilterFields.js +9 -21
- package/utils/renderGetFilterFields.js.map +1 -1
- package/utils/renderInputFields.d.ts +5 -3
- package/utils/renderInputFields.js +20 -6
- package/utils/renderInputFields.js.map +1 -1
- package/utils/renderListFilterFields.d.ts +3 -1
- package/utils/renderListFilterFields.js +25 -22
- package/utils/renderListFilterFields.js.map +1 -1
- package/utils/renderSortEnum.d.ts +4 -3
- package/utils/renderSortEnum.js +10 -3
- package/utils/renderSortEnum.js.map +1 -1
- package/utils/toSlug.js +3 -1
- package/utils/toSlug.js.map +1 -1
- package/validators/dateGte.d.ts +1 -1
- package/validators/dateGte.js +3 -1
- package/validators/dateGte.js.map +1 -1
- package/validators/dateLte.d.ts +1 -1
- package/validators/dateLte.js +3 -1
- package/validators/dateLte.js.map +1 -1
- package/validators/gte.d.ts +1 -1
- package/validators/gte.js +4 -3
- package/validators/gte.js.map +1 -1
- package/validators/in.d.ts +1 -1
- package/validators/in.js +4 -3
- package/validators/in.js.map +1 -1
- package/validators/index.js +4 -3
- package/validators/index.js.map +1 -1
- package/validators/lte.d.ts +1 -1
- package/validators/lte.js +4 -3
- package/validators/lte.js.map +1 -1
- package/validators/maxLength.d.ts +1 -1
- package/validators/maxLength.js +4 -3
- package/validators/maxLength.js.map +1 -1
- package/validators/minLength.d.ts +1 -1
- package/validators/minLength.js +4 -3
- package/validators/minLength.js.map +1 -1
- package/validators/pattern.d.ts +1 -1
- package/validators/pattern.js +5 -3
- package/validators/pattern.js.map +1 -1
- package/validators/patternPlugins/email.d.ts +1 -1
- package/validators/patternPlugins/email.js +4 -2
- package/validators/patternPlugins/email.js.map +1 -1
- package/validators/patternPlugins/index.d.ts +1 -1
- package/validators/patternPlugins/index.js +3 -1
- package/validators/patternPlugins/index.js.map +1 -1
- package/validators/patternPlugins/lowerCase.d.ts +1 -1
- package/validators/patternPlugins/lowerCase.js +3 -1
- package/validators/patternPlugins/lowerCase.js.map +1 -1
- package/validators/patternPlugins/lowerCaseSpace.d.ts +1 -1
- package/validators/patternPlugins/lowerCaseSpace.js +3 -1
- package/validators/patternPlugins/lowerCaseSpace.js.map +1 -1
- package/validators/patternPlugins/upperCase.d.ts +1 -1
- package/validators/patternPlugins/upperCase.js +3 -1
- package/validators/patternPlugins/upperCase.js.map +1 -1
- package/validators/patternPlugins/upperCaseSpace.d.ts +1 -1
- package/validators/patternPlugins/upperCaseSpace.js +3 -1
- package/validators/patternPlugins/upperCaseSpace.js.map +1 -1
- package/validators/patternPlugins/url.d.ts +1 -1
- package/validators/patternPlugins/url.js +3 -1
- package/validators/patternPlugins/url.js.map +1 -1
- package/validators/required.d.ts +1 -1
- package/validators/required.js +3 -1
- package/validators/required.js.map +1 -1
- package/validators/timeGte.d.ts +1 -1
- package/validators/timeGte.js +4 -3
- package/validators/timeGte.js.map +1 -1
- package/validators/timeLte.d.ts +1 -1
- package/validators/timeLte.js +4 -3
- package/validators/timeLte.js.map +1 -1
- package/validators/unique.d.ts +1 -1
- package/validators/unique.js +4 -2
- package/validators/unique.js.map +1 -1
- package/crud/contentModel/afterCreate.d.ts +0 -8
- package/crud/contentModel/afterCreate.js +0 -16
- package/crud/contentModel/afterCreate.js.map +0 -1
- package/crud/contentModel/afterCreateFrom.d.ts +0 -8
- package/crud/contentModel/afterCreateFrom.js +0 -16
- package/crud/contentModel/afterCreateFrom.js.map +0 -1
- package/crud/contentModel/afterDelete.d.ts +0 -8
- package/crud/contentModel/afterDelete.js +0 -16
- package/crud/contentModel/afterDelete.js.map +0 -1
- package/crud/contentModel/afterUpdate.d.ts +0 -8
- package/crud/contentModel/afterUpdate.js +0 -16
- package/crud/contentModel/afterUpdate.js.map +0 -1
- package/crud/contentModel/systemFields.d.ts +0 -1
- package/crud/contentModel/systemFields.js +0 -8
- package/crud/contentModel/systemFields.js.map +0 -1
- package/crud/contentModel/validateLayout.d.ts +0 -2
- package/crud/contentModel/validateLayout.js +0 -28
- package/crud/contentModel/validateLayout.js.map +0 -1
- package/crud/settings.crud.d.ts +0 -10
- package/crud/settings.crud.js +0 -71
- package/crud/settings.crud.js.map +0 -1
- package/graphql/schema/resolvers/commonFieldResolvers.d.ts +0 -6
- package/graphql/schema/resolvers/commonFieldResolvers.js +0 -12
- package/graphql/schema/resolvers/commonFieldResolvers.js.map +0 -1
- package/graphqlFields/dynamicZone/dynamicZoneStorage.d.ts +0 -3
- package/graphqlFields/dynamicZone/dynamicZoneStorage.js +0 -63
- package/graphqlFields/dynamicZone/dynamicZoneStorage.js.map +0 -1
- package/plugins/CmsGraphQLSchemaPlugin.d.ts +0 -5
- package/plugins/CmsGraphQLSchemaPlugin.js +0 -12
- package/plugins/CmsGraphQLSchemaPlugin.js.map +0 -1
- package/types.d.ts +0 -2641
- package/types.js.map +0 -1
- package/upgrades/5.33.0/index.d.ts +0 -3
- package/upgrades/5.33.0/index.js +0 -159
- package/upgrades/5.33.0/index.js.map +0 -1
- package/upgrades/index.d.ts +0 -1
- package/upgrades/index.js +0 -9
- package/upgrades/index.js.map +0 -1
- package/utils/access.d.ts +0 -8
- package/utils/access.js +0 -76
- package/utils/access.js.map +0 -1
- package/utils/ownership.d.ts +0 -8
- package/utils/ownership.js +0 -33
- package/utils/ownership.js.map +0 -1
- package/utils/permissions.d.ts +0 -7
- package/utils/permissions.js +0 -91
- package/utils/permissions.js.map +0 -1
- package/utils/pluralizedTypeName.d.ts +0 -1
- package/utils/pluralizedTypeName.js +0 -20
- package/utils/pluralizedTypeName.js.map +0 -1
- package/validators/dynamicZone.d.ts +0 -2
- package/validators/dynamicZone.js +0 -20
- package/validators/dynamicZone.js.map +0 -1
|
@@ -4,194 +4,31 @@ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefau
|
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
|
-
exports.createContentEntryCrud =
|
|
8
|
-
var
|
|
9
|
-
var
|
|
7
|
+
exports.createContentEntryCrud = void 0;
|
|
8
|
+
var _utils = require("@webiny/utils");
|
|
9
|
+
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
10
10
|
var _handlerGraphql = require("@webiny/handler-graphql");
|
|
11
11
|
var _entryDataValidation = require("./contentEntry/entryDataValidation");
|
|
12
|
-
var _error = _interopRequireDefault(require("@webiny/error"));
|
|
13
12
|
var _pubsub = require("@webiny/pubsub");
|
|
14
13
|
var _beforeCreate = require("./contentEntry/beforeCreate");
|
|
15
14
|
var _beforeUpdate = require("./contentEntry/beforeUpdate");
|
|
16
|
-
var _utils = require("@webiny/utils");
|
|
17
15
|
var _afterDelete = require("./contentEntry/afterDelete");
|
|
18
|
-
var _referenceFieldsMapping = require("./contentEntry/referenceFieldsMapping");
|
|
19
|
-
var _merge = _interopRequireDefault(require("lodash/merge"));
|
|
20
|
-
var _permissions = require("../utils/permissions");
|
|
21
|
-
var _access = require("../utils/access");
|
|
22
|
-
var _ownership = require("../utils/ownership");
|
|
23
16
|
var _entryStorage = require("../utils/entryStorage");
|
|
24
|
-
var _valueKeyStorageConverter = require("../utils/converters/valueKeyStorageConverter");
|
|
25
17
|
var _searchableFields = require("./contentEntry/searchableFields");
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
const STATUS_DRAFT = "draft";
|
|
32
|
-
exports.STATUS_DRAFT = STATUS_DRAFT;
|
|
33
|
-
const STATUS_PUBLISHED = "published";
|
|
34
|
-
exports.STATUS_PUBLISHED = STATUS_PUBLISHED;
|
|
35
|
-
const STATUS_UNPUBLISHED = "unpublished";
|
|
36
|
-
exports.STATUS_UNPUBLISHED = STATUS_UNPUBLISHED;
|
|
37
|
-
/**
|
|
38
|
-
* Used for some fields to convert their values.
|
|
39
|
-
*/
|
|
40
|
-
const convertDefaultValue = (field, value) => {
|
|
41
|
-
switch (field.type) {
|
|
42
|
-
case "boolean":
|
|
43
|
-
return Boolean(value);
|
|
44
|
-
case "number":
|
|
45
|
-
return Number(value);
|
|
46
|
-
default:
|
|
47
|
-
return value;
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
const getDefaultValue = field => {
|
|
51
|
-
const {
|
|
52
|
-
settings,
|
|
53
|
-
multipleValues
|
|
54
|
-
} = field;
|
|
55
|
-
if (settings && settings.defaultValue !== undefined) {
|
|
56
|
-
return convertDefaultValue(field, settings.defaultValue);
|
|
57
|
-
}
|
|
58
|
-
const {
|
|
59
|
-
predefinedValues
|
|
60
|
-
} = field;
|
|
61
|
-
if (!predefinedValues || !predefinedValues.enabled || Array.isArray(predefinedValues.values) === false) {
|
|
62
|
-
return undefined;
|
|
63
|
-
}
|
|
64
|
-
if (!multipleValues) {
|
|
65
|
-
const selectedValue = predefinedValues.values.find(value => {
|
|
66
|
-
return !!value.selected;
|
|
67
|
-
});
|
|
68
|
-
if (selectedValue) {
|
|
69
|
-
return convertDefaultValue(field, selectedValue.value);
|
|
70
|
-
}
|
|
71
|
-
return undefined;
|
|
72
|
-
}
|
|
73
|
-
return predefinedValues.values.filter(({
|
|
74
|
-
selected
|
|
75
|
-
}) => !!selected).map(({
|
|
76
|
-
value
|
|
77
|
-
}) => {
|
|
78
|
-
return convertDefaultValue(field, value);
|
|
79
|
-
});
|
|
80
|
-
};
|
|
81
|
-
/**
|
|
82
|
-
* Cleans and adds default values to create input data.
|
|
83
|
-
*/
|
|
84
|
-
const mapAndCleanCreateInputData = (model, input) => {
|
|
85
|
-
return model.fields.reduce((acc, field) => {
|
|
86
|
-
/**
|
|
87
|
-
* This should never happen, but let's make it sure.
|
|
88
|
-
* The fix would be for the user to add the fieldId on the field definition.
|
|
89
|
-
*/
|
|
90
|
-
if (!field.fieldId) {
|
|
91
|
-
throw new _error.default("Field does not have an fieldId.", "MISSING_FIELD_ID", {
|
|
92
|
-
field
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
const value = input[field.fieldId];
|
|
96
|
-
/**
|
|
97
|
-
* We set the default value on create input if value is not defined.
|
|
98
|
-
*/
|
|
99
|
-
acc[field.fieldId] = value === undefined ? getDefaultValue(field) : value;
|
|
100
|
-
return acc;
|
|
101
|
-
}, {});
|
|
102
|
-
};
|
|
103
|
-
/**
|
|
104
|
-
* Cleans the update input entry data.
|
|
105
|
-
*/
|
|
106
|
-
const mapAndCleanUpdatedInputData = (model, input) => {
|
|
107
|
-
return model.fields.reduce((acc, field) => {
|
|
108
|
-
/**
|
|
109
|
-
* This should never happen, but let's make it sure.
|
|
110
|
-
* The fix would be for the user to add the fieldId on the field definition.
|
|
111
|
-
*/
|
|
112
|
-
if (!field.fieldId) {
|
|
113
|
-
throw new _error.default("Field does not have an fieldId.", "MISSING_FIELD_ID", {
|
|
114
|
-
field
|
|
115
|
-
});
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* We cannot set default value here because user might want to update only certain field values.
|
|
119
|
-
*/
|
|
120
|
-
const value = input[field.fieldId];
|
|
121
|
-
if (value === undefined) {
|
|
122
|
-
return acc;
|
|
123
|
-
}
|
|
124
|
-
acc[field.fieldId] = value;
|
|
125
|
-
return acc;
|
|
126
|
-
}, {});
|
|
127
|
-
};
|
|
128
|
-
/**
|
|
129
|
-
* This method takes original entry meta and new input.
|
|
130
|
-
* When new meta is merged onto the existing one, everything that has undefined or null value is removed.
|
|
131
|
-
*/
|
|
132
|
-
const createEntryMeta = (input, original) => {
|
|
133
|
-
const meta = (0, _merge.default)(original || {}, input || {});
|
|
134
|
-
for (const key in meta) {
|
|
135
|
-
if (meta[key] !== undefined || meta[key] !== null) {
|
|
136
|
-
continue;
|
|
137
|
-
}
|
|
138
|
-
delete meta[key];
|
|
139
|
-
}
|
|
140
|
-
return meta;
|
|
141
|
-
};
|
|
142
|
-
const createEntryId = input => {
|
|
143
|
-
let entryId = (0, _mdbid.default)();
|
|
144
|
-
if (input.id) {
|
|
145
|
-
if (input.id.match(/^([a-zA-Z0-9])([a-zA-Z0-9\-]+)([a-zA-Z0-9])$/) === null) {
|
|
146
|
-
throw new _error.default("The provided ID is not valid. It must be a string which can A-Z, a-z, 0-9, - and it cannot start or end with a -.", "INVALID_ID", {
|
|
147
|
-
id: input.id
|
|
148
|
-
});
|
|
149
|
-
}
|
|
150
|
-
entryId = input.id;
|
|
151
|
-
}
|
|
152
|
-
const version = 1;
|
|
153
|
-
return {
|
|
154
|
-
entryId: entryId,
|
|
155
|
-
version,
|
|
156
|
-
id: (0, _utils.createIdentifier)({
|
|
157
|
-
id: entryId,
|
|
158
|
-
version
|
|
159
|
-
})
|
|
160
|
-
};
|
|
161
|
-
};
|
|
162
|
-
const increaseEntryIdVersion = id => {
|
|
163
|
-
const {
|
|
164
|
-
id: entryId,
|
|
165
|
-
version
|
|
166
|
-
} = (0, _utils.parseIdentifier)(id);
|
|
167
|
-
if (!version) {
|
|
168
|
-
throw new _error.default("Cannot increase version on the ID without the version part.", "WRONG_ID", {
|
|
169
|
-
id
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
return {
|
|
173
|
-
entryId,
|
|
174
|
-
version: version + 1,
|
|
175
|
-
id: (0, _utils.createIdentifier)({
|
|
176
|
-
id: entryId,
|
|
177
|
-
version: version + 1
|
|
178
|
-
})
|
|
179
|
-
};
|
|
180
|
-
};
|
|
181
|
-
const allowedEntryStatus = ["draft", "published", "unpublished"];
|
|
182
|
-
const transformEntryStatus = status => {
|
|
183
|
-
return allowedEntryStatus.includes(status) ? status : "draft";
|
|
184
|
-
};
|
|
18
|
+
var _filterAsync = require("../utils/filterAsync");
|
|
19
|
+
var _constants = require("../constants");
|
|
20
|
+
var _entryDataFactories = require("./contentEntry/entryDataFactories");
|
|
21
|
+
var _useCases = require("./contentEntry/useCases");
|
|
22
|
+
var _ContentEntryTraverser = require("../utils/contentEntryTraverser/ContentEntryTraverser");
|
|
185
23
|
const createContentEntryCrud = params => {
|
|
186
24
|
const {
|
|
187
25
|
storageOperations,
|
|
26
|
+
accessControl,
|
|
188
27
|
context,
|
|
189
|
-
getIdentity,
|
|
190
|
-
getTenant
|
|
28
|
+
getIdentity: getSecurityIdentity,
|
|
29
|
+
getTenant,
|
|
30
|
+
getLocale
|
|
191
31
|
} = params;
|
|
192
|
-
const {
|
|
193
|
-
plugins
|
|
194
|
-
} = context;
|
|
195
32
|
|
|
196
33
|
/**
|
|
197
34
|
* Create
|
|
@@ -214,6 +51,13 @@ const createContentEntryCrud = params => {
|
|
|
214
51
|
const onEntryAfterUpdate = (0, _pubsub.createTopic)("cms.onEntryAfterUpdate");
|
|
215
52
|
const onEntryUpdateError = (0, _pubsub.createTopic)("cms.onEntryUpdateError");
|
|
216
53
|
|
|
54
|
+
/**
|
|
55
|
+
* Move
|
|
56
|
+
*/
|
|
57
|
+
const onEntryBeforeMove = (0, _pubsub.createTopic)("cms.onEntryBeforeMove");
|
|
58
|
+
const onEntryAfterMove = (0, _pubsub.createTopic)("cms.onEntryAfterMove");
|
|
59
|
+
const onEntryMoveError = (0, _pubsub.createTopic)("cms.onEntryMoveError");
|
|
60
|
+
|
|
217
61
|
/**
|
|
218
62
|
* Publish
|
|
219
63
|
*/
|
|
@@ -242,15 +86,34 @@ const createContentEntryCrud = params => {
|
|
|
242
86
|
const onEntryAfterDelete = (0, _pubsub.createTopic)("cms.onEntryAfterDelete");
|
|
243
87
|
const onEntryDeleteError = (0, _pubsub.createTopic)("cms.onEntryDeleteError");
|
|
244
88
|
|
|
245
|
-
|
|
89
|
+
/**
|
|
90
|
+
* Restore from bin
|
|
91
|
+
*/
|
|
92
|
+
const onEntryBeforeRestoreFromBin = (0, _pubsub.createTopic)("cms.onEntryBeforeRestoreFromBin");
|
|
93
|
+
const onEntryAfterRestoreFromBin = (0, _pubsub.createTopic)("cms.onEntryAfterRestoreFromBin");
|
|
94
|
+
const onEntryRestoreFromBinError = (0, _pubsub.createTopic)("cms.onEntryRestoreFromBinError");
|
|
95
|
+
|
|
96
|
+
/**
|
|
97
|
+
* Delete revision
|
|
98
|
+
*/
|
|
246
99
|
const onEntryRevisionBeforeDelete = (0, _pubsub.createTopic)("cms.onEntryRevisionBeforeDelete");
|
|
247
100
|
const onEntryRevisionAfterDelete = (0, _pubsub.createTopic)("cms.onEntryRevisionAfterDelete");
|
|
248
101
|
const onEntryRevisionDeleteError = (0, _pubsub.createTopic)("cms.onEntryRevisionDeleteError");
|
|
102
|
+
/**
|
|
103
|
+
* Delete multiple entries
|
|
104
|
+
*/
|
|
105
|
+
const onEntryBeforeDeleteMultiple = (0, _pubsub.createTopic)("cms.onEntryBeforeDeleteMultiple");
|
|
106
|
+
const onEntryAfterDeleteMultiple = (0, _pubsub.createTopic)("cms.onEntryAfterDeleteMultiple");
|
|
107
|
+
const onEntryDeleteMultipleError = (0, _pubsub.createTopic)("cms.onEntryDeleteMultipleError");
|
|
249
108
|
|
|
250
|
-
|
|
109
|
+
/**
|
|
110
|
+
* Get entry
|
|
111
|
+
*/
|
|
251
112
|
const onEntryBeforeGet = (0, _pubsub.createTopic)("cms.onEntryBeforeGet");
|
|
252
113
|
|
|
253
|
-
|
|
114
|
+
/**
|
|
115
|
+
* List entries
|
|
116
|
+
*/
|
|
254
117
|
const onEntryBeforeList = (0, _pubsub.createTopic)("cms.onEntryBeforeList");
|
|
255
118
|
|
|
256
119
|
/**
|
|
@@ -268,927 +131,1111 @@ const createContentEntryCrud = params => {
|
|
|
268
131
|
context,
|
|
269
132
|
onEntryAfterDelete
|
|
270
133
|
});
|
|
271
|
-
const checkEntryPermissions = check => {
|
|
272
|
-
return (0, _permissions.checkPermissions)(context, "cms.contentEntry", check);
|
|
273
|
-
};
|
|
274
134
|
|
|
275
135
|
/**
|
|
276
|
-
*
|
|
136
|
+
* List entries
|
|
137
|
+
*/
|
|
138
|
+
const {
|
|
139
|
+
listEntriesUseCase,
|
|
140
|
+
listLatestUseCase,
|
|
141
|
+
listDeletedUseCase,
|
|
142
|
+
listPublishedUseCase,
|
|
143
|
+
getEntryUseCase
|
|
144
|
+
} = (0, _useCases.listEntriesUseCases)({
|
|
145
|
+
operation: storageOperations.entries["list"],
|
|
146
|
+
accessControl,
|
|
147
|
+
topics: {
|
|
148
|
+
onEntryBeforeList
|
|
149
|
+
},
|
|
150
|
+
context,
|
|
151
|
+
getIdentity: getSecurityIdentity
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
/**
|
|
155
|
+
* Get entries by ids
|
|
156
|
+
*/
|
|
157
|
+
const {
|
|
158
|
+
getEntriesByIdsUseCase
|
|
159
|
+
} = (0, _useCases.getEntriesByIdsUseCases)({
|
|
160
|
+
operation: storageOperations.entries.getByIds,
|
|
161
|
+
accessControl
|
|
162
|
+
});
|
|
163
|
+
|
|
164
|
+
/**
|
|
165
|
+
* Get latest entries by ids
|
|
166
|
+
*/
|
|
167
|
+
const {
|
|
168
|
+
getLatestEntriesByIdsUseCase
|
|
169
|
+
} = (0, _useCases.getLatestEntriesByIdsUseCases)({
|
|
170
|
+
operation: storageOperations.entries.getLatestByIds,
|
|
171
|
+
accessControl
|
|
172
|
+
});
|
|
173
|
+
|
|
174
|
+
/**
|
|
175
|
+
* Get published entries by ids
|
|
176
|
+
*/
|
|
177
|
+
const {
|
|
178
|
+
getPublishedEntriesByIdsUseCase
|
|
179
|
+
} = (0, _useCases.getPublishedEntriesByIdsUseCases)({
|
|
180
|
+
operation: storageOperations.entries.getPublishedByIds,
|
|
181
|
+
accessControl
|
|
182
|
+
});
|
|
183
|
+
|
|
184
|
+
/**
|
|
185
|
+
* Get revisions by entryId
|
|
186
|
+
*/
|
|
187
|
+
const {
|
|
188
|
+
getRevisionsByEntryIdUseCase
|
|
189
|
+
} = (0, _useCases.getRevisionsByEntryIdUseCases)({
|
|
190
|
+
operation: storageOperations.entries.getRevisions,
|
|
191
|
+
accessControl
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
/**
|
|
195
|
+
* Get revision by id
|
|
196
|
+
*/
|
|
197
|
+
const {
|
|
198
|
+
getRevisionByIdUseCase
|
|
199
|
+
} = (0, _useCases.getRevisionByIdUseCases)({
|
|
200
|
+
operation: storageOperations.entries.getRevisionById
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
/**
|
|
204
|
+
* Get latest revision by entryId
|
|
205
|
+
*/
|
|
206
|
+
const {
|
|
207
|
+
getLatestRevisionByEntryIdUseCase,
|
|
208
|
+
getLatestRevisionByEntryIdWithDeletedUseCase,
|
|
209
|
+
getLatestRevisionByEntryIdDeletedUseCase
|
|
210
|
+
} = (0, _useCases.getLatestRevisionByEntryIdUseCases)({
|
|
211
|
+
operation: storageOperations.entries.getLatestRevisionByEntryId
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
* Get previous revision by entryId
|
|
216
|
+
*/
|
|
217
|
+
const {
|
|
218
|
+
getPreviousRevisionByEntryIdUseCase
|
|
219
|
+
} = (0, _useCases.getPreviousRevisionByEntryIdUseCases)({
|
|
220
|
+
operation: storageOperations.entries.getPreviousRevision
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* Get published revision by entryId
|
|
225
|
+
*/
|
|
226
|
+
const {
|
|
227
|
+
getPublishedRevisionByEntryIdUseCase
|
|
228
|
+
} = (0, _useCases.getPublishedRevisionByEntryIdUseCases)({
|
|
229
|
+
operation: storageOperations.entries.getPublishedRevisionByEntryId
|
|
230
|
+
});
|
|
231
|
+
|
|
232
|
+
/**
|
|
233
|
+
* Delete entry
|
|
234
|
+
*/
|
|
235
|
+
const {
|
|
236
|
+
deleteEntryUseCase,
|
|
237
|
+
moveEntryToBinUseCase,
|
|
238
|
+
deleteEntryOperation
|
|
239
|
+
} = (0, _useCases.deleteEntryUseCases)({
|
|
240
|
+
deleteOperation: storageOperations.entries.delete,
|
|
241
|
+
moveToBinOperation: storageOperations.entries.moveToBin,
|
|
242
|
+
getEntry: getLatestRevisionByEntryIdUseCase,
|
|
243
|
+
getEntryWithDeleted: getLatestRevisionByEntryIdWithDeletedUseCase,
|
|
244
|
+
getIdentity: getSecurityIdentity,
|
|
245
|
+
topics: {
|
|
246
|
+
onEntryBeforeDelete,
|
|
247
|
+
onEntryAfterDelete,
|
|
248
|
+
onEntryDeleteError
|
|
249
|
+
},
|
|
250
|
+
accessControl,
|
|
251
|
+
context
|
|
252
|
+
});
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* Restore entry from bin
|
|
277
256
|
*/
|
|
278
|
-
const
|
|
257
|
+
const {
|
|
258
|
+
restoreEntryFromBinUseCase
|
|
259
|
+
} = (0, _useCases.restoreEntryFromBinUseCases)({
|
|
260
|
+
restoreOperation: storageOperations.entries.restoreFromBin,
|
|
261
|
+
getEntry: getLatestRevisionByEntryIdDeletedUseCase,
|
|
262
|
+
getIdentity: getSecurityIdentity,
|
|
263
|
+
topics: {
|
|
264
|
+
onEntryBeforeRestoreFromBin,
|
|
265
|
+
onEntryAfterRestoreFromBin,
|
|
266
|
+
onEntryRestoreFromBinError
|
|
267
|
+
},
|
|
268
|
+
accessControl,
|
|
269
|
+
context
|
|
270
|
+
});
|
|
271
|
+
const getEntryById = async (model, id) => {
|
|
272
|
+
const where = {
|
|
273
|
+
id
|
|
274
|
+
};
|
|
275
|
+
await onEntryBeforeGet.publish({
|
|
276
|
+
where,
|
|
277
|
+
model
|
|
278
|
+
});
|
|
279
|
+
const [entry] = await getEntriesByIdsUseCase.execute(model, {
|
|
280
|
+
ids: [id]
|
|
281
|
+
});
|
|
282
|
+
if (!entry) {
|
|
283
|
+
throw new _handlerGraphql.NotFoundError(`Entry by ID "${id}" not found.`);
|
|
284
|
+
}
|
|
285
|
+
// TODO figure out without casting
|
|
286
|
+
return entry;
|
|
287
|
+
};
|
|
288
|
+
const createEntry = async (model, rawInput, options) => {
|
|
289
|
+
await accessControl.ensureCanAccessEntry({
|
|
290
|
+
model,
|
|
291
|
+
rwd: "w"
|
|
292
|
+
});
|
|
279
293
|
const {
|
|
294
|
+
entry,
|
|
295
|
+
input
|
|
296
|
+
} = await (0, _entryDataFactories.createEntryData)({
|
|
297
|
+
context,
|
|
280
298
|
model,
|
|
281
|
-
|
|
282
|
-
|
|
299
|
+
options,
|
|
300
|
+
rawInput,
|
|
301
|
+
getLocale,
|
|
302
|
+
getTenant,
|
|
303
|
+
getIdentity: getSecurityIdentity,
|
|
304
|
+
accessControl
|
|
305
|
+
});
|
|
306
|
+
await accessControl.ensureCanAccessEntry({
|
|
307
|
+
model,
|
|
308
|
+
entry,
|
|
309
|
+
rwd: "w"
|
|
310
|
+
});
|
|
311
|
+
let storageEntry = null;
|
|
283
312
|
try {
|
|
284
|
-
await
|
|
313
|
+
await onEntryBeforeCreate.publish({
|
|
285
314
|
entry,
|
|
315
|
+
input,
|
|
286
316
|
model
|
|
287
317
|
});
|
|
288
|
-
await
|
|
289
|
-
|
|
318
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
319
|
+
const result = await storageOperations.entries.create(model, {
|
|
320
|
+
entry,
|
|
321
|
+
storageEntry
|
|
290
322
|
});
|
|
291
|
-
await
|
|
323
|
+
await onEntryAfterCreate.publish({
|
|
292
324
|
entry,
|
|
293
|
-
|
|
325
|
+
storageEntry: result,
|
|
326
|
+
model,
|
|
327
|
+
input
|
|
294
328
|
});
|
|
329
|
+
return entry;
|
|
295
330
|
} catch (ex) {
|
|
296
|
-
await
|
|
331
|
+
await onEntryCreateError.publish({
|
|
332
|
+
error: ex,
|
|
297
333
|
entry,
|
|
298
334
|
model,
|
|
299
|
-
|
|
335
|
+
input
|
|
300
336
|
});
|
|
301
|
-
throw new _error.default(ex.message || "Could not
|
|
302
|
-
|
|
337
|
+
throw new _error.default(ex.message || "Could not create content entry.", ex.code || "CREATE_ENTRY_ERROR", ex.data || {
|
|
338
|
+
error: ex,
|
|
339
|
+
input,
|
|
340
|
+
entry,
|
|
341
|
+
storageEntry
|
|
303
342
|
});
|
|
304
343
|
}
|
|
305
344
|
};
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
const permission = await checkEntryPermissions({
|
|
311
|
-
rwd: "r"
|
|
312
|
-
});
|
|
313
|
-
await (0, _access.checkModelAccess)(context, initialModel);
|
|
314
|
-
const model = (0, _valueKeyStorageConverter.attachCmsModelFieldConverters)({
|
|
315
|
-
model: initialModel,
|
|
316
|
-
plugins
|
|
317
|
-
});
|
|
318
|
-
const entries = await storageOperations.entries.getByIds(model, {
|
|
319
|
-
ids
|
|
345
|
+
const createEntryRevisionFrom = async (model, sourceId, rawInput, options) => {
|
|
346
|
+
await accessControl.ensureCanAccessEntry({
|
|
347
|
+
model,
|
|
348
|
+
rwd: "w"
|
|
320
349
|
});
|
|
321
|
-
|
|
322
|
-
};
|
|
323
|
-
return {
|
|
324
|
-
/**
|
|
325
|
-
* Deprecated - will be removed in 5.35.0
|
|
326
|
-
*/
|
|
327
|
-
onBeforeEntryCreate: onEntryBeforeCreate,
|
|
328
|
-
onAfterEntryCreate: onEntryAfterCreate,
|
|
329
|
-
onBeforeEntryCreateRevision: onEntryBeforeCreateRevision,
|
|
330
|
-
onAfterEntryCreateRevision: onEntryRevisionAfterCreate,
|
|
331
|
-
onBeforeEntryUpdate: onEntryBeforeUpdate,
|
|
332
|
-
onAfterEntryUpdate: onEntryAfterUpdate,
|
|
333
|
-
onBeforeEntryDelete: onEntryBeforeDelete,
|
|
334
|
-
onAfterEntryDelete: onEntryAfterDelete,
|
|
335
|
-
onBeforeEntryDeleteRevision: onEntryRevisionBeforeDelete,
|
|
336
|
-
onAfterEntryDeleteRevision: onEntryRevisionAfterDelete,
|
|
337
|
-
onBeforeEntryPublish: onEntryBeforePublish,
|
|
338
|
-
onAfterEntryPublish: onEntryAfterPublish,
|
|
339
|
-
onBeforeEntryUnpublish: onEntryBeforeUnpublish,
|
|
340
|
-
onAfterEntryUnpublish: onEntryAfterUnpublish,
|
|
341
|
-
onBeforeEntryGet: onEntryBeforeGet,
|
|
342
|
-
onBeforeEntryList: onEntryBeforeList,
|
|
343
|
-
/**
|
|
344
|
-
* Released in 5.34.0
|
|
345
|
-
*
|
|
346
|
-
* Create
|
|
347
|
-
*/
|
|
348
|
-
onEntryBeforeCreate,
|
|
349
|
-
onEntryAfterCreate,
|
|
350
|
-
onEntryCreateError,
|
|
351
|
-
/**
|
|
352
|
-
* Create revision
|
|
353
|
-
*/
|
|
354
|
-
onEntryRevisionBeforeCreate: onEntryBeforeCreateRevision,
|
|
355
|
-
onEntryRevisionAfterCreate,
|
|
356
|
-
onEntryRevisionCreateError: onEntryCreateRevisionError,
|
|
357
|
-
/**
|
|
358
|
-
* Update
|
|
359
|
-
*/
|
|
360
|
-
onEntryBeforeUpdate,
|
|
361
|
-
onEntryAfterUpdate,
|
|
362
|
-
onEntryUpdateError,
|
|
363
|
-
/**
|
|
364
|
-
* Delete whole entry
|
|
365
|
-
*/
|
|
366
|
-
onEntryBeforeDelete,
|
|
367
|
-
onEntryAfterDelete,
|
|
368
|
-
onEntryDeleteError,
|
|
369
|
-
/**
|
|
370
|
-
* Delete entry revision
|
|
371
|
-
*/
|
|
372
|
-
onEntryRevisionBeforeDelete,
|
|
373
|
-
onEntryRevisionAfterDelete,
|
|
374
|
-
onEntryRevisionDeleteError,
|
|
375
|
-
/**
|
|
376
|
-
* Publish
|
|
377
|
-
*/
|
|
378
|
-
onEntryBeforePublish,
|
|
379
|
-
onEntryAfterPublish,
|
|
380
|
-
onEntryPublishError,
|
|
381
|
-
/**
|
|
382
|
-
* Republish
|
|
383
|
-
*/
|
|
384
|
-
onEntryBeforeRepublish,
|
|
385
|
-
onEntryAfterRepublish,
|
|
386
|
-
onEntryRepublishError,
|
|
387
|
-
/**
|
|
388
|
-
* Unpublish
|
|
389
|
-
*/
|
|
390
|
-
onEntryBeforeUnpublish,
|
|
391
|
-
onEntryAfterUnpublish,
|
|
392
|
-
onEntryUnpublishError,
|
|
393
|
-
onEntryBeforeGet,
|
|
394
|
-
onEntryBeforeList,
|
|
350
|
+
|
|
395
351
|
/**
|
|
396
|
-
*
|
|
352
|
+
* Entries are identified by a common parent ID + Revision number.
|
|
397
353
|
*/
|
|
398
|
-
|
|
354
|
+
const {
|
|
355
|
+
id: uniqueId
|
|
356
|
+
} = (0, _utils.parseIdentifier)(sourceId);
|
|
357
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
358
|
+
id: sourceId
|
|
359
|
+
});
|
|
360
|
+
const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
|
|
361
|
+
id: uniqueId
|
|
362
|
+
});
|
|
363
|
+
if (!originalStorageEntry) {
|
|
364
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${sourceId}" of model "${model.modelId}" was not found.`);
|
|
365
|
+
}
|
|
366
|
+
if (!latestStorageEntry) {
|
|
367
|
+
throw new _handlerGraphql.NotFoundError(`Latest entry "${uniqueId}" of model "${model.modelId}" was not found.`);
|
|
368
|
+
}
|
|
369
|
+
|
|
399
370
|
/**
|
|
400
|
-
*
|
|
371
|
+
* We need to convert data from DB to its original form before using it further.
|
|
401
372
|
*/
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
373
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
374
|
+
const {
|
|
375
|
+
entry,
|
|
376
|
+
input
|
|
377
|
+
} = await (0, _entryDataFactories.createEntryRevisionFromData)({
|
|
378
|
+
sourceId,
|
|
379
|
+
model,
|
|
380
|
+
rawInput,
|
|
381
|
+
options,
|
|
382
|
+
context,
|
|
383
|
+
getIdentity: getSecurityIdentity,
|
|
384
|
+
getTenant,
|
|
385
|
+
getLocale,
|
|
386
|
+
originalEntry,
|
|
387
|
+
latestStorageEntry,
|
|
388
|
+
accessControl
|
|
389
|
+
});
|
|
390
|
+
await accessControl.ensureCanAccessEntry({
|
|
391
|
+
model,
|
|
392
|
+
entry,
|
|
393
|
+
rwd: "w"
|
|
394
|
+
});
|
|
395
|
+
let storageEntry = null;
|
|
396
|
+
try {
|
|
397
|
+
await onEntryBeforeCreateRevision.publish({
|
|
398
|
+
input,
|
|
399
|
+
entry,
|
|
400
|
+
original: originalEntry,
|
|
412
401
|
model
|
|
413
402
|
});
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
return entry;
|
|
419
|
-
},
|
|
420
|
-
/**
|
|
421
|
-
* Get published revisions by entry IDs.
|
|
422
|
-
*/
|
|
423
|
-
async getPublishedEntriesByIds(initialModel, ids) {
|
|
424
|
-
const permission = await checkEntryPermissions({
|
|
425
|
-
rwd: "r"
|
|
403
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
404
|
+
const result = await storageOperations.entries.createRevisionFrom(model, {
|
|
405
|
+
entry,
|
|
406
|
+
storageEntry
|
|
426
407
|
});
|
|
427
|
-
await
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
408
|
+
await onEntryRevisionAfterCreate.publish({
|
|
409
|
+
input,
|
|
410
|
+
entry,
|
|
411
|
+
model,
|
|
412
|
+
original: originalEntry,
|
|
413
|
+
storageEntry: result
|
|
431
414
|
});
|
|
432
|
-
|
|
433
|
-
|
|
415
|
+
return entry;
|
|
416
|
+
} catch (ex) {
|
|
417
|
+
await onEntryCreateRevisionError.publish({
|
|
418
|
+
entry,
|
|
419
|
+
original: originalEntry,
|
|
420
|
+
model,
|
|
421
|
+
input,
|
|
422
|
+
error: ex
|
|
434
423
|
});
|
|
435
|
-
|
|
436
|
-
|
|
424
|
+
throw new _error.default(ex.message || "Could not create entry from existing one.", ex.code || "CREATE_FROM_REVISION_ERROR", {
|
|
425
|
+
error: ex,
|
|
426
|
+
entry,
|
|
427
|
+
storageEntry,
|
|
428
|
+
originalEntry,
|
|
429
|
+
originalStorageEntry
|
|
430
|
+
});
|
|
431
|
+
}
|
|
432
|
+
};
|
|
433
|
+
const updateEntry = async (model, id, rawInput, metaInput, options) => {
|
|
434
|
+
await accessControl.ensureCanAccessEntry({
|
|
435
|
+
model,
|
|
436
|
+
rwd: "w"
|
|
437
|
+
});
|
|
438
|
+
|
|
437
439
|
/**
|
|
438
|
-
*
|
|
440
|
+
* The entry we are going to update.
|
|
439
441
|
*/
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
442
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
443
|
+
id
|
|
444
|
+
});
|
|
445
|
+
if (!originalStorageEntry) {
|
|
446
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
447
|
+
}
|
|
448
|
+
if (originalStorageEntry.locked) {
|
|
449
|
+
throw new _error.default(`Cannot update entry because it's locked.`, "CONTENT_ENTRY_UPDATE_ERROR");
|
|
450
|
+
}
|
|
451
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
452
|
+
const {
|
|
453
|
+
entry,
|
|
454
|
+
input
|
|
455
|
+
} = await (0, _entryDataFactories.createUpdateEntryData)({
|
|
456
|
+
model,
|
|
457
|
+
rawInput,
|
|
458
|
+
options,
|
|
459
|
+
context,
|
|
460
|
+
getIdentity: getSecurityIdentity,
|
|
461
|
+
getTenant,
|
|
462
|
+
getLocale,
|
|
463
|
+
originalEntry,
|
|
464
|
+
metaInput
|
|
465
|
+
});
|
|
466
|
+
await accessControl.ensureCanAccessEntry({
|
|
467
|
+
model,
|
|
468
|
+
entry,
|
|
469
|
+
rwd: "w"
|
|
470
|
+
});
|
|
471
|
+
let storageEntry = null;
|
|
472
|
+
try {
|
|
473
|
+
await onEntryBeforeUpdate.publish({
|
|
474
|
+
entry,
|
|
475
|
+
model,
|
|
476
|
+
input,
|
|
477
|
+
original: originalEntry
|
|
443
478
|
});
|
|
444
|
-
await (0,
|
|
445
|
-
const
|
|
446
|
-
|
|
447
|
-
|
|
479
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
480
|
+
const result = await storageOperations.entries.update(model, {
|
|
481
|
+
entry,
|
|
482
|
+
storageEntry
|
|
448
483
|
});
|
|
449
|
-
|
|
450
|
-
|
|
484
|
+
await onEntryAfterUpdate.publish({
|
|
485
|
+
entry,
|
|
486
|
+
storageEntry: result,
|
|
487
|
+
model,
|
|
488
|
+
input,
|
|
489
|
+
original: originalEntry
|
|
451
490
|
});
|
|
452
|
-
return
|
|
453
|
-
}
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
model
|
|
457
|
-
|
|
491
|
+
return entry;
|
|
492
|
+
} catch (ex) {
|
|
493
|
+
await onEntryUpdateError.publish({
|
|
494
|
+
entry,
|
|
495
|
+
model,
|
|
496
|
+
input,
|
|
497
|
+
error: ex
|
|
458
498
|
});
|
|
459
|
-
|
|
460
|
-
|
|
499
|
+
throw new _error.default(ex.message || "Could not update existing entry.", ex.code || "UPDATE_ERROR", {
|
|
500
|
+
error: ex,
|
|
501
|
+
entry,
|
|
502
|
+
storageEntry,
|
|
503
|
+
originalEntry,
|
|
504
|
+
input
|
|
461
505
|
});
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
506
|
+
}
|
|
507
|
+
};
|
|
508
|
+
const validateEntry = async (model, id, inputData) => {
|
|
509
|
+
await accessControl.ensureCanAccessEntry({
|
|
510
|
+
model,
|
|
511
|
+
rwd: "w"
|
|
512
|
+
});
|
|
513
|
+
const input = (0, _entryDataFactories.mapAndCleanUpdatedInputData)(model, inputData || {});
|
|
514
|
+
let originalEntry;
|
|
515
|
+
if (id) {
|
|
516
|
+
/**
|
|
517
|
+
* The entry we are going to update.
|
|
518
|
+
*/
|
|
519
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
520
|
+
id
|
|
521
|
+
});
|
|
522
|
+
if (!originalStorageEntry) {
|
|
523
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
524
|
+
}
|
|
525
|
+
originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
526
|
+
}
|
|
527
|
+
await accessControl.ensureCanAccessEntry({
|
|
528
|
+
model,
|
|
529
|
+
entry: originalEntry,
|
|
530
|
+
rwd: "w"
|
|
531
|
+
});
|
|
532
|
+
const result = await (0, _entryDataValidation.validateModelEntryData)({
|
|
533
|
+
context,
|
|
534
|
+
model,
|
|
535
|
+
data: input,
|
|
536
|
+
entry: originalEntry
|
|
537
|
+
});
|
|
538
|
+
return result.length > 0 ? result : [];
|
|
539
|
+
};
|
|
540
|
+
const moveEntry = async (model, id, folderId) => {
|
|
541
|
+
await accessControl.ensureCanAccessEntry({
|
|
542
|
+
model,
|
|
543
|
+
rwd: "w"
|
|
544
|
+
});
|
|
545
|
+
|
|
546
|
+
/**
|
|
547
|
+
* The entry we are going to move to another folder.
|
|
467
548
|
*/
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
549
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
550
|
+
id
|
|
551
|
+
});
|
|
552
|
+
if (!originalStorageEntry) {
|
|
553
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
554
|
+
}
|
|
555
|
+
const entry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
556
|
+
await accessControl.ensureCanAccessEntry({
|
|
557
|
+
model,
|
|
558
|
+
entry,
|
|
559
|
+
rwd: "w"
|
|
560
|
+
});
|
|
561
|
+
|
|
562
|
+
/**
|
|
563
|
+
* No need to continue if the entry is already in the requested folder.
|
|
564
|
+
*/
|
|
565
|
+
if (entry.location?.folderId === folderId) {
|
|
566
|
+
return entry;
|
|
567
|
+
}
|
|
568
|
+
try {
|
|
569
|
+
await onEntryBeforeMove.publish({
|
|
570
|
+
entry,
|
|
571
|
+
model,
|
|
572
|
+
folderId
|
|
471
573
|
});
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
574
|
+
await storageOperations.entries.move(model, id, folderId);
|
|
575
|
+
await onEntryAfterMove.publish({
|
|
576
|
+
entry,
|
|
577
|
+
model,
|
|
578
|
+
folderId
|
|
475
579
|
});
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
580
|
+
return entry;
|
|
581
|
+
} catch (ex) {
|
|
582
|
+
await onEntryMoveError.publish({
|
|
583
|
+
entry,
|
|
584
|
+
model,
|
|
585
|
+
folderId,
|
|
586
|
+
error: ex
|
|
483
587
|
});
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
limit: 1
|
|
588
|
+
throw _error.default.from(ex, {
|
|
589
|
+
message: `Could not move entry "${id}" of model "${model.modelId}".`,
|
|
590
|
+
code: "MOVE_ENTRY_ERROR"
|
|
488
591
|
});
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
592
|
+
}
|
|
593
|
+
};
|
|
594
|
+
const republishEntry = async (model, id) => {
|
|
595
|
+
await accessControl.ensureCanAccessEntry({
|
|
596
|
+
model,
|
|
597
|
+
rwd: "w",
|
|
598
|
+
pw: "p"
|
|
599
|
+
});
|
|
600
|
+
|
|
494
601
|
/**
|
|
495
|
-
*
|
|
496
|
-
|
|
497
|
-
|
|
602
|
+
* Fetch the entry from the storage.
|
|
603
|
+
*/
|
|
604
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
605
|
+
id
|
|
606
|
+
});
|
|
607
|
+
if (!originalStorageEntry) {
|
|
608
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" was not found!`);
|
|
609
|
+
}
|
|
610
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
611
|
+
await accessControl.ensureCanAccessEntry({
|
|
612
|
+
model,
|
|
613
|
+
entry: originalEntry,
|
|
614
|
+
rwd: "w",
|
|
615
|
+
pw: "p"
|
|
616
|
+
});
|
|
617
|
+
const {
|
|
618
|
+
entry
|
|
619
|
+
} = await (0, _entryDataFactories.createRepublishEntryData)({
|
|
620
|
+
context,
|
|
621
|
+
model,
|
|
622
|
+
originalEntry,
|
|
623
|
+
getIdentity: getSecurityIdentity
|
|
624
|
+
});
|
|
625
|
+
const storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
626
|
+
/**
|
|
627
|
+
* First we need to update existing entry.
|
|
498
628
|
*/
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
629
|
+
try {
|
|
630
|
+
await storageOperations.entries.update(model, {
|
|
631
|
+
entry,
|
|
632
|
+
storageEntry
|
|
502
633
|
});
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
plugins
|
|
634
|
+
} catch (ex) {
|
|
635
|
+
throw new _error.default("Could not update existing entry with new data while re-publishing.", "REPUBLISH_UPDATE_ERROR", {
|
|
636
|
+
entry
|
|
507
637
|
});
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
const where = (0, _objectSpread2.default)({}, initialWhere);
|
|
517
|
-
/**
|
|
518
|
-
* Possibly only get records which are owned by current user.
|
|
519
|
-
* Or if searching for the owner set that value - in the case that user can see other entries than their own.
|
|
520
|
-
*/
|
|
521
|
-
const ownedBy = permission.own ? getIdentity().id : where.ownedBy;
|
|
522
|
-
if (ownedBy !== undefined) {
|
|
523
|
-
where.ownedBy = ownedBy;
|
|
524
|
-
}
|
|
525
|
-
/**
|
|
526
|
-
* Where must contain either latest or published keys.
|
|
527
|
-
* We cannot list entries without one of those
|
|
528
|
-
*/
|
|
529
|
-
if (where.latest && where.published) {
|
|
530
|
-
throw new _error.default("Cannot list entries that are both published and latest.", "LIST_ENTRIES_ERROR", {
|
|
531
|
-
where
|
|
532
|
-
});
|
|
533
|
-
} else if (!where.latest && !where.published) {
|
|
534
|
-
throw new _error.default("Cannot list entries if we do not have latest or published defined.", "LIST_ENTRIES_ERROR", {
|
|
535
|
-
where
|
|
536
|
-
});
|
|
537
|
-
}
|
|
538
|
-
const fields = (0, _searchableFields.getSearchableFields)({
|
|
539
|
-
fields: model.fields,
|
|
540
|
-
plugins: context.plugins,
|
|
541
|
-
input: params.fields || []
|
|
542
|
-
});
|
|
543
|
-
try {
|
|
544
|
-
await onEntryBeforeList.publish({
|
|
545
|
-
where,
|
|
546
|
-
model
|
|
547
|
-
});
|
|
548
|
-
const {
|
|
549
|
-
hasMoreItems,
|
|
550
|
-
totalCount,
|
|
551
|
-
cursor,
|
|
552
|
-
items
|
|
553
|
-
} = await storageOperations.entries.list(model, (0, _objectSpread2.default)((0, _objectSpread2.default)({}, params), {}, {
|
|
554
|
-
limit,
|
|
555
|
-
where,
|
|
556
|
-
fields
|
|
557
|
-
}));
|
|
558
|
-
const meta = {
|
|
559
|
-
hasMoreItems,
|
|
560
|
-
totalCount,
|
|
561
|
-
/**
|
|
562
|
-
* Cursor should be null if there are no more items to load.
|
|
563
|
-
* Just make sure of that, disregarding what is returned from the storageOperations.entries.list method.
|
|
564
|
-
*/
|
|
565
|
-
cursor: hasMoreItems ? cursor : null
|
|
566
|
-
};
|
|
567
|
-
return [items, meta];
|
|
568
|
-
} catch (ex) {
|
|
569
|
-
throw new _error.default("Error while fetching entries from storage.", "LIST_ENTRIES_ERROR", {
|
|
570
|
-
params,
|
|
571
|
-
error: {
|
|
572
|
-
message: ex.message,
|
|
573
|
-
code: ex.code,
|
|
574
|
-
data: ex.data
|
|
575
|
-
},
|
|
576
|
-
model,
|
|
577
|
-
fields
|
|
578
|
-
});
|
|
579
|
-
}
|
|
580
|
-
},
|
|
581
|
-
async listLatestEntries(model, params) {
|
|
582
|
-
const where = (params === null || params === void 0 ? void 0 : params.where) || {};
|
|
583
|
-
return this.listEntries(model, (0, _objectSpread2.default)((0, _objectSpread2.default)({
|
|
584
|
-
sort: ["createdOn_DESC"]
|
|
585
|
-
}, params || {}), {}, {
|
|
586
|
-
where: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, where), {}, {
|
|
587
|
-
latest: true
|
|
588
|
-
})
|
|
589
|
-
}));
|
|
590
|
-
},
|
|
591
|
-
async listPublishedEntries(model, params) {
|
|
592
|
-
const where = (params === null || params === void 0 ? void 0 : params.where) || {};
|
|
593
|
-
return this.listEntries(model, (0, _objectSpread2.default)((0, _objectSpread2.default)({
|
|
594
|
-
sort: ["createdOn_DESC"]
|
|
595
|
-
}, params || {}), {}, {
|
|
596
|
-
where: (0, _objectSpread2.default)((0, _objectSpread2.default)({}, where), {}, {
|
|
597
|
-
published: true
|
|
598
|
-
})
|
|
599
|
-
}));
|
|
600
|
-
},
|
|
601
|
-
async createEntry(initialModel, inputData) {
|
|
602
|
-
await checkEntryPermissions({
|
|
603
|
-
rwd: "w"
|
|
638
|
+
}
|
|
639
|
+
/**
|
|
640
|
+
* Then we move onto publishing it again.
|
|
641
|
+
*/
|
|
642
|
+
try {
|
|
643
|
+
await onEntryBeforeRepublish.publish({
|
|
644
|
+
entry,
|
|
645
|
+
model
|
|
604
646
|
});
|
|
605
|
-
await
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
plugins
|
|
647
|
+
const result = await storageOperations.entries.publish(model, {
|
|
648
|
+
entry,
|
|
649
|
+
storageEntry
|
|
609
650
|
});
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
* Make sure we only work with fields that are defined in the model.
|
|
613
|
-
*/
|
|
614
|
-
const initialInput = mapAndCleanCreateInputData(model, inputData);
|
|
615
|
-
await (0, _entryDataValidation.validateModelEntryData)({
|
|
616
|
-
context,
|
|
651
|
+
await onEntryAfterRepublish.publish({
|
|
652
|
+
entry,
|
|
617
653
|
model,
|
|
618
|
-
|
|
654
|
+
storageEntry: result
|
|
619
655
|
});
|
|
620
|
-
|
|
621
|
-
|
|
656
|
+
return entry;
|
|
657
|
+
} catch (ex) {
|
|
658
|
+
await onEntryRepublishError.publish({
|
|
659
|
+
entry,
|
|
622
660
|
model,
|
|
623
|
-
|
|
624
|
-
validateEntries: true
|
|
625
|
-
});
|
|
626
|
-
const identity = context.security.getIdentity();
|
|
627
|
-
const locale = this.getLocale();
|
|
628
|
-
const owner = {
|
|
629
|
-
id: identity.id,
|
|
630
|
-
displayName: identity.displayName,
|
|
631
|
-
type: identity.type
|
|
632
|
-
};
|
|
633
|
-
/**
|
|
634
|
-
* There is a possibility that user sends an ID in the input, so we will use that one.
|
|
635
|
-
* There is no check if the ID is unique or not, that is up to the user.
|
|
636
|
-
*/
|
|
637
|
-
const {
|
|
638
|
-
id,
|
|
639
|
-
entryId,
|
|
640
|
-
version
|
|
641
|
-
} = createEntryId(inputData);
|
|
642
|
-
const entry = {
|
|
643
|
-
webinyVersion: context.WEBINY_VERSION,
|
|
644
|
-
tenant: getTenant().id,
|
|
645
|
-
entryId,
|
|
646
|
-
id,
|
|
647
|
-
modelId: model.modelId,
|
|
648
|
-
locale: locale.code,
|
|
649
|
-
createdOn: new Date().toISOString(),
|
|
650
|
-
savedOn: new Date().toISOString(),
|
|
651
|
-
createdBy: owner,
|
|
652
|
-
ownedBy: owner,
|
|
653
|
-
version,
|
|
654
|
-
locked: false,
|
|
655
|
-
status: STATUS_DRAFT,
|
|
656
|
-
values: input
|
|
657
|
-
};
|
|
658
|
-
let storageEntry = null;
|
|
659
|
-
try {
|
|
660
|
-
await onEntryBeforeCreate.publish({
|
|
661
|
-
entry,
|
|
662
|
-
input,
|
|
663
|
-
model
|
|
664
|
-
});
|
|
665
|
-
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
666
|
-
const result = await storageOperations.entries.create(model, {
|
|
667
|
-
entry,
|
|
668
|
-
storageEntry
|
|
669
|
-
});
|
|
670
|
-
await onEntryAfterCreate.publish({
|
|
671
|
-
entry,
|
|
672
|
-
storageEntry: result,
|
|
673
|
-
model,
|
|
674
|
-
input
|
|
675
|
-
});
|
|
676
|
-
return result;
|
|
677
|
-
} catch (ex) {
|
|
678
|
-
await onEntryCreateError.publish({
|
|
679
|
-
error: ex,
|
|
680
|
-
entry,
|
|
681
|
-
model,
|
|
682
|
-
input
|
|
683
|
-
});
|
|
684
|
-
throw new _error.default(ex.message || "Could not create content entry.", ex.code || "CREATE_ENTRY_ERROR", ex.data || {
|
|
685
|
-
error: ex,
|
|
686
|
-
input,
|
|
687
|
-
entry,
|
|
688
|
-
storageEntry
|
|
689
|
-
});
|
|
690
|
-
}
|
|
691
|
-
},
|
|
692
|
-
async createEntryRevisionFrom(initialModel, sourceId, inputData) {
|
|
693
|
-
const permission = await checkEntryPermissions({
|
|
694
|
-
rwd: "w"
|
|
661
|
+
error: ex
|
|
695
662
|
});
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
model: initialModel,
|
|
699
|
-
plugins
|
|
663
|
+
throw new _error.default("Could not publish existing entry while re-publishing.", "REPUBLISH_PUBLISH_ERROR", {
|
|
664
|
+
entry
|
|
700
665
|
});
|
|
666
|
+
}
|
|
667
|
+
};
|
|
668
|
+
const deleteEntryRevision = async (model, revisionId) => {
|
|
669
|
+
await accessControl.ensureCanAccessEntry({
|
|
670
|
+
model,
|
|
671
|
+
rwd: "d"
|
|
672
|
+
});
|
|
673
|
+
const {
|
|
674
|
+
id: entryId,
|
|
675
|
+
version
|
|
676
|
+
} = (0, _utils.parseIdentifier)(revisionId);
|
|
677
|
+
const storageEntryToDelete = await getRevisionByIdUseCase.execute(model, {
|
|
678
|
+
id: revisionId
|
|
679
|
+
});
|
|
680
|
+
const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
|
|
681
|
+
id: entryId
|
|
682
|
+
});
|
|
683
|
+
const storagePreviousEntry = await getPreviousRevisionByEntryIdUseCase.execute(model, {
|
|
684
|
+
entryId,
|
|
685
|
+
version: version
|
|
686
|
+
});
|
|
687
|
+
if (!storageEntryToDelete) {
|
|
688
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${revisionId}" was not found!`);
|
|
689
|
+
}
|
|
690
|
+
const latestEntryRevisionId = latestStorageEntry ? latestStorageEntry.id : null;
|
|
691
|
+
const entryToDelete = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntryToDelete);
|
|
692
|
+
await accessControl.ensureCanAccessEntry({
|
|
693
|
+
model,
|
|
694
|
+
entry: entryToDelete,
|
|
695
|
+
rwd: "d"
|
|
696
|
+
});
|
|
701
697
|
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
698
|
+
/**
|
|
699
|
+
* If targeted record is the latest entry record and there is no previous one, we need
|
|
700
|
+
* to run full delete with hooks. In this case, `deleteRevision` hooks are not fired.
|
|
701
|
+
*/
|
|
702
|
+
if (entryToDelete.id === latestEntryRevisionId && !storagePreviousEntry) {
|
|
703
|
+
return await deleteEntryOperation.execute(model, {
|
|
704
|
+
entry: entryToDelete
|
|
705
|
+
});
|
|
706
|
+
}
|
|
707
|
+
/**
|
|
708
|
+
* If targeted record is the latest entry revision, set the previous one as the new latest.
|
|
709
|
+
*/
|
|
710
|
+
let entryToSetAsLatest = null;
|
|
711
|
+
let storageEntryToSetAsLatest = null;
|
|
712
|
+
let updatedEntryToSetAsLatest = null;
|
|
713
|
+
let storageUpdatedEntryToSetAsLatest = null;
|
|
714
|
+
if (entryToDelete.id === latestEntryRevisionId && storagePreviousEntry) {
|
|
715
|
+
entryToSetAsLatest = await (0, _entryStorage.entryFromStorageTransform)(context, model, storagePreviousEntry);
|
|
716
|
+
storageEntryToSetAsLatest = storagePreviousEntry;
|
|
706
717
|
|
|
707
718
|
/**
|
|
708
|
-
*
|
|
719
|
+
* Since we're setting a different revision as the latest, we need to update entry-level meta
|
|
720
|
+
* fields. The values are taken from the latest revision we're about to delete. The update of the
|
|
721
|
+
* new latest revision is performed within storage operations.
|
|
709
722
|
*/
|
|
710
|
-
const
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
723
|
+
const pickedEntryLevelMetaFields = (0, _constants.pickEntryMetaFields)(entryToDelete, _constants.isEntryLevelEntryMetaField);
|
|
724
|
+
updatedEntryToSetAsLatest = {
|
|
725
|
+
...entryToSetAsLatest,
|
|
726
|
+
...pickedEntryLevelMetaFields
|
|
727
|
+
};
|
|
728
|
+
storageUpdatedEntryToSetAsLatest = {
|
|
729
|
+
...storageEntryToSetAsLatest,
|
|
730
|
+
...pickedEntryLevelMetaFields
|
|
731
|
+
};
|
|
732
|
+
}
|
|
733
|
+
try {
|
|
734
|
+
await onEntryRevisionBeforeDelete.publish({
|
|
735
|
+
entry: entryToDelete,
|
|
736
|
+
model
|
|
715
737
|
});
|
|
716
|
-
|
|
717
|
-
|
|
738
|
+
await storageOperations.entries.deleteRevision(model, {
|
|
739
|
+
entry: entryToDelete,
|
|
740
|
+
storageEntry: storageEntryToDelete,
|
|
741
|
+
latestEntry: updatedEntryToSetAsLatest,
|
|
742
|
+
latestStorageEntry: storageUpdatedEntryToSetAsLatest
|
|
718
743
|
});
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
/**
|
|
724
|
-
* We need to convert data from DB to its original form before using it further.
|
|
725
|
-
*/
|
|
726
|
-
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
727
|
-
const initialValues = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry.values), input);
|
|
728
|
-
await (0, _entryDataValidation.validateModelEntryData)({
|
|
729
|
-
context,
|
|
730
|
-
model,
|
|
731
|
-
data: initialValues,
|
|
732
|
-
entry: originalEntry
|
|
744
|
+
await onEntryRevisionAfterDelete.publish({
|
|
745
|
+
entry: entryToDelete,
|
|
746
|
+
model
|
|
733
747
|
});
|
|
734
|
-
|
|
735
|
-
|
|
748
|
+
} catch (ex) {
|
|
749
|
+
await onEntryRevisionDeleteError.publish({
|
|
750
|
+
entry: entryToDelete,
|
|
736
751
|
model,
|
|
737
|
-
|
|
738
|
-
|
|
752
|
+
error: ex
|
|
753
|
+
});
|
|
754
|
+
throw new _error.default(ex.message, ex.code || "DELETE_REVISION_ERROR", {
|
|
755
|
+
error: ex,
|
|
756
|
+
entry: entryToDelete,
|
|
757
|
+
storageEntry: storageEntryToDelete,
|
|
758
|
+
latestEntry: updatedEntryToSetAsLatest,
|
|
759
|
+
latestStorageEntry: storageUpdatedEntryToSetAsLatest
|
|
739
760
|
});
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
761
|
+
}
|
|
762
|
+
};
|
|
763
|
+
const deleteMultipleEntries = async (model, params) => {
|
|
764
|
+
const {
|
|
765
|
+
entries: input
|
|
766
|
+
} = params;
|
|
767
|
+
const maxDeletableEntries = 50;
|
|
768
|
+
const entryIdList = new Set();
|
|
769
|
+
for (const id of input) {
|
|
743
770
|
const {
|
|
744
|
-
id
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
753
|
-
|
|
754
|
-
|
|
755
|
-
|
|
756
|
-
|
|
757
|
-
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
|
|
766
|
-
|
|
767
|
-
|
|
768
|
-
|
|
769
|
-
|
|
770
|
-
|
|
771
|
-
|
|
772
|
-
|
|
773
|
-
|
|
774
|
-
});
|
|
775
|
-
await onEntryRevisionAfterCreate.publish({
|
|
776
|
-
input,
|
|
777
|
-
entry,
|
|
778
|
-
model,
|
|
779
|
-
original: originalEntry,
|
|
780
|
-
storageEntry: result
|
|
781
|
-
});
|
|
782
|
-
return result;
|
|
783
|
-
} catch (ex) {
|
|
784
|
-
await onEntryCreateRevisionError.publish({
|
|
785
|
-
entry,
|
|
786
|
-
original: originalEntry,
|
|
787
|
-
model,
|
|
788
|
-
input,
|
|
789
|
-
error: ex
|
|
790
|
-
});
|
|
791
|
-
throw new _error.default(ex.message || "Could not create entry from existing one.", ex.code || "CREATE_FROM_REVISION_ERROR", {
|
|
792
|
-
error: ex,
|
|
793
|
-
entry,
|
|
794
|
-
storageEntry,
|
|
795
|
-
originalEntry,
|
|
796
|
-
originalStorageEntry
|
|
797
|
-
});
|
|
798
|
-
}
|
|
799
|
-
},
|
|
800
|
-
async updateEntry(initialModel, id, inputData, metaInput) {
|
|
801
|
-
const permission = await checkEntryPermissions({
|
|
802
|
-
rwd: "w"
|
|
771
|
+
id: entryId
|
|
772
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
773
|
+
entryIdList.add(entryId);
|
|
774
|
+
}
|
|
775
|
+
const ids = Array.from(entryIdList);
|
|
776
|
+
if (ids.length > maxDeletableEntries) {
|
|
777
|
+
throw new _error.default("Cannot delete more than 50 entries at once.", "DELETE_ENTRIES_MAX", {
|
|
778
|
+
entries: ids
|
|
779
|
+
});
|
|
780
|
+
}
|
|
781
|
+
await accessControl.ensureCanAccessEntry({
|
|
782
|
+
model,
|
|
783
|
+
rwd: "d"
|
|
784
|
+
});
|
|
785
|
+
const {
|
|
786
|
+
items: entries
|
|
787
|
+
} = await storageOperations.entries.list(model, {
|
|
788
|
+
where: {
|
|
789
|
+
latest: true,
|
|
790
|
+
entryId_in: ids
|
|
791
|
+
},
|
|
792
|
+
limit: maxDeletableEntries + 1
|
|
793
|
+
});
|
|
794
|
+
/**
|
|
795
|
+
* We do not want to allow deleting entries that user does not own or cannot access.
|
|
796
|
+
*/
|
|
797
|
+
const items = (await (0, _filterAsync.filterAsync)(entries, async entry => {
|
|
798
|
+
return accessControl.canAccessEntry({
|
|
799
|
+
model,
|
|
800
|
+
entry: entry
|
|
803
801
|
});
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
802
|
+
})).map(entry => entry.id);
|
|
803
|
+
try {
|
|
804
|
+
await onEntryBeforeDeleteMultiple.publish({
|
|
805
|
+
entries,
|
|
806
|
+
ids,
|
|
807
|
+
model
|
|
808
|
+
});
|
|
809
|
+
await storageOperations.entries.deleteMultipleEntries(model, {
|
|
810
|
+
entries: items
|
|
811
|
+
});
|
|
812
|
+
await onEntryAfterDeleteMultiple.publish({
|
|
813
|
+
entries,
|
|
814
|
+
ids,
|
|
815
|
+
model
|
|
816
|
+
});
|
|
817
|
+
return items.map(id => {
|
|
818
|
+
return {
|
|
819
|
+
id
|
|
820
|
+
};
|
|
808
821
|
});
|
|
822
|
+
} catch (ex) {
|
|
823
|
+
await onEntryDeleteMultipleError.publish({
|
|
824
|
+
entries,
|
|
825
|
+
ids,
|
|
826
|
+
model,
|
|
827
|
+
error: ex
|
|
828
|
+
});
|
|
829
|
+
throw new _error.default(ex.message, ex.code || "DELETE_ENTRIES_MULTIPLE_ERROR", {
|
|
830
|
+
error: ex,
|
|
831
|
+
entries
|
|
832
|
+
});
|
|
833
|
+
}
|
|
834
|
+
};
|
|
835
|
+
const deleteEntry = async (model, id, options = {}) => {
|
|
836
|
+
const {
|
|
837
|
+
permanently = true
|
|
838
|
+
} = options;
|
|
809
839
|
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
840
|
+
/**
|
|
841
|
+
* If the 'permanently' flag is set to false, the entry must be moved to the bin; otherwise, deleted.
|
|
842
|
+
*/
|
|
843
|
+
if (!permanently) {
|
|
844
|
+
return await moveEntryToBinUseCase.execute(model, id, options);
|
|
845
|
+
}
|
|
846
|
+
return await deleteEntryUseCase.execute(model, id, options);
|
|
847
|
+
};
|
|
848
|
+
const publishEntry = async (model, id) => {
|
|
849
|
+
await accessControl.ensureCanAccessEntry({
|
|
850
|
+
model,
|
|
851
|
+
pw: "p"
|
|
852
|
+
});
|
|
853
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
854
|
+
id
|
|
855
|
+
});
|
|
856
|
+
if (!originalStorageEntry) {
|
|
857
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
|
|
858
|
+
}
|
|
859
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
860
|
+
await accessControl.ensureCanAccessEntry({
|
|
861
|
+
model,
|
|
862
|
+
entry: originalEntry,
|
|
863
|
+
pw: "p"
|
|
864
|
+
});
|
|
814
865
|
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
866
|
+
// We need the latest entry to get the latest entry-level meta fields.
|
|
867
|
+
const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
|
|
868
|
+
id: originalEntry.entryId
|
|
869
|
+
});
|
|
870
|
+
if (!latestStorageEntry) {
|
|
871
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
|
|
872
|
+
}
|
|
873
|
+
const latestEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, latestStorageEntry);
|
|
874
|
+
const {
|
|
875
|
+
entry
|
|
876
|
+
} = await (0, _entryDataFactories.createPublishEntryData)({
|
|
877
|
+
context,
|
|
878
|
+
model,
|
|
879
|
+
originalEntry,
|
|
880
|
+
latestEntry,
|
|
881
|
+
getIdentity: getSecurityIdentity
|
|
882
|
+
});
|
|
883
|
+
let storageEntry = null;
|
|
884
|
+
try {
|
|
885
|
+
await onEntryBeforePublish.publish({
|
|
886
|
+
original: originalEntry,
|
|
887
|
+
entry,
|
|
888
|
+
model
|
|
820
889
|
});
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
890
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
891
|
+
const result = await storageOperations.entries.publish(model, {
|
|
892
|
+
entry,
|
|
893
|
+
storageEntry
|
|
894
|
+
});
|
|
895
|
+
await onEntryAfterPublish.publish({
|
|
896
|
+
original: originalEntry,
|
|
897
|
+
entry,
|
|
898
|
+
storageEntry: result,
|
|
899
|
+
model
|
|
900
|
+
});
|
|
901
|
+
return entry;
|
|
902
|
+
} catch (ex) {
|
|
903
|
+
await onEntryPublishError.publish({
|
|
904
|
+
original: originalEntry,
|
|
905
|
+
entry,
|
|
830
906
|
model,
|
|
831
|
-
|
|
832
|
-
|
|
907
|
+
error: ex
|
|
908
|
+
});
|
|
909
|
+
throw new _error.default(ex.message || "Could not publish entry.", ex.code || "PUBLISH_ERROR", {
|
|
910
|
+
error: ex,
|
|
911
|
+
entry,
|
|
912
|
+
storageEntry,
|
|
913
|
+
originalEntry,
|
|
914
|
+
originalStorageEntry
|
|
915
|
+
});
|
|
916
|
+
}
|
|
917
|
+
};
|
|
918
|
+
const unpublishEntry = async (model, id) => {
|
|
919
|
+
await accessControl.ensureCanAccessEntry({
|
|
920
|
+
model,
|
|
921
|
+
pw: "u"
|
|
922
|
+
});
|
|
923
|
+
const {
|
|
924
|
+
id: entryId
|
|
925
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
926
|
+
const originalStorageEntry = await getPublishedRevisionByEntryIdUseCase.execute(model, {
|
|
927
|
+
id: entryId
|
|
928
|
+
});
|
|
929
|
+
if (!originalStorageEntry) {
|
|
930
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
931
|
+
}
|
|
932
|
+
if (originalStorageEntry.id !== id) {
|
|
933
|
+
throw new _error.default(`Entry is not published.`, "UNPUBLISH_ERROR", {
|
|
934
|
+
entry: originalStorageEntry
|
|
935
|
+
});
|
|
936
|
+
}
|
|
937
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
938
|
+
await accessControl.ensureCanAccessEntry({
|
|
939
|
+
model,
|
|
940
|
+
entry: originalEntry,
|
|
941
|
+
pw: "u"
|
|
942
|
+
});
|
|
943
|
+
const {
|
|
944
|
+
entry
|
|
945
|
+
} = await (0, _entryDataFactories.createUnpublishEntryData)({
|
|
946
|
+
context,
|
|
947
|
+
model,
|
|
948
|
+
originalEntry,
|
|
949
|
+
getIdentity: getSecurityIdentity
|
|
950
|
+
});
|
|
951
|
+
let storageEntry = null;
|
|
952
|
+
try {
|
|
953
|
+
await onEntryBeforeUnpublish.publish({
|
|
954
|
+
entry,
|
|
955
|
+
model
|
|
956
|
+
});
|
|
957
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
958
|
+
const result = await storageOperations.entries.unpublish(model, {
|
|
959
|
+
entry,
|
|
960
|
+
storageEntry
|
|
833
961
|
});
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
962
|
+
await onEntryAfterUnpublish.publish({
|
|
963
|
+
entry,
|
|
964
|
+
storageEntry: result,
|
|
965
|
+
model
|
|
966
|
+
});
|
|
967
|
+
return entry;
|
|
968
|
+
} catch (ex) {
|
|
969
|
+
await onEntryUnpublishError.publish({
|
|
970
|
+
entry,
|
|
838
971
|
model,
|
|
839
|
-
|
|
840
|
-
validateEntries: false
|
|
972
|
+
error: ex
|
|
841
973
|
});
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
854
|
-
|
|
855
|
-
|
|
856
|
-
|
|
857
|
-
|
|
858
|
-
|
|
859
|
-
|
|
860
|
-
|
|
861
|
-
original: originalEntry
|
|
862
|
-
});
|
|
863
|
-
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
864
|
-
const result = await storageOperations.entries.update(model, {
|
|
865
|
-
entry,
|
|
866
|
-
storageEntry
|
|
867
|
-
});
|
|
868
|
-
await onEntryAfterUpdate.publish({
|
|
869
|
-
entry,
|
|
870
|
-
storageEntry: result,
|
|
871
|
-
model,
|
|
872
|
-
input,
|
|
873
|
-
original: originalEntry
|
|
874
|
-
});
|
|
875
|
-
return result;
|
|
876
|
-
} catch (ex) {
|
|
877
|
-
await onEntryUpdateError.publish({
|
|
878
|
-
entry,
|
|
879
|
-
model,
|
|
880
|
-
input,
|
|
881
|
-
error: ex
|
|
882
|
-
});
|
|
883
|
-
throw new _error.default(ex.message || "Could not update existing entry.", ex.code || "UPDATE_ERROR", {
|
|
884
|
-
error: ex,
|
|
885
|
-
entry,
|
|
886
|
-
storageEntry,
|
|
887
|
-
originalEntry,
|
|
888
|
-
input
|
|
889
|
-
});
|
|
890
|
-
}
|
|
891
|
-
},
|
|
974
|
+
throw new _error.default(ex.message || "Could not unpublish entry.", ex.code || "UNPUBLISH_ERROR", {
|
|
975
|
+
originalEntry,
|
|
976
|
+
originalStorageEntry,
|
|
977
|
+
entry,
|
|
978
|
+
storageEntry
|
|
979
|
+
});
|
|
980
|
+
}
|
|
981
|
+
};
|
|
982
|
+
const getUniqueFieldValues = async (model, params) => {
|
|
983
|
+
await accessControl.ensureCanAccessEntry({
|
|
984
|
+
model
|
|
985
|
+
});
|
|
986
|
+
const {
|
|
987
|
+
where: initialWhere,
|
|
988
|
+
fieldId
|
|
989
|
+
} = params;
|
|
990
|
+
const where = {
|
|
991
|
+
...initialWhere
|
|
992
|
+
};
|
|
892
993
|
/**
|
|
893
|
-
*
|
|
894
|
-
*
|
|
994
|
+
* Possibly only get records which are owned by current user.
|
|
995
|
+
* Or if searching for the owner set that value - in the case that user can see other entries than their own.
|
|
996
|
+
*/
|
|
997
|
+
if (await accessControl.canAccessOnlyOwnedEntries({
|
|
998
|
+
model
|
|
999
|
+
})) {
|
|
1000
|
+
where.createdBy = getSecurityIdentity().id;
|
|
1001
|
+
}
|
|
1002
|
+
|
|
1003
|
+
/**
|
|
1004
|
+
* Where must contain either latest or published keys.
|
|
1005
|
+
* We cannot list entries without one of those
|
|
895
1006
|
*/
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
1007
|
+
if (where.latest && where.published) {
|
|
1008
|
+
throw new _error.default("Cannot list entries that are both published and latest.", "LIST_ENTRIES_ERROR", {
|
|
1009
|
+
where
|
|
899
1010
|
});
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
plugins
|
|
1011
|
+
} else if (!where.latest && !where.published) {
|
|
1012
|
+
throw new _error.default("Cannot list entries if we do not have latest or published defined.", "LIST_ENTRIES_ERROR", {
|
|
1013
|
+
where
|
|
904
1014
|
});
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
1015
|
+
}
|
|
1016
|
+
/**
|
|
1017
|
+
* We need to verify that the field in question is searchable.
|
|
1018
|
+
*/
|
|
1019
|
+
const fields = (0, _searchableFields.getSearchableFields)({
|
|
1020
|
+
fields: model.fields,
|
|
1021
|
+
plugins: context.plugins,
|
|
1022
|
+
input: []
|
|
1023
|
+
});
|
|
1024
|
+
if (!fields.includes(fieldId)) {
|
|
1025
|
+
throw new _error.default("Cannot list unique entry field values if the field is not searchable.", "LIST_UNIQUE_ENTRY_VALUES_ERROR", {
|
|
1026
|
+
fieldId
|
|
910
1027
|
});
|
|
911
|
-
|
|
912
|
-
|
|
913
|
-
|
|
914
|
-
|
|
915
|
-
|
|
916
|
-
* We can only process published entries.
|
|
917
|
-
*/
|
|
918
|
-
if (originalEntry.status !== "published") {
|
|
919
|
-
throw new _error.default("Entry with given ID is not published!", "NOT_PUBLISHED_ERROR", {
|
|
920
|
-
id,
|
|
921
|
-
original: originalEntry
|
|
922
|
-
});
|
|
923
|
-
}
|
|
924
|
-
const values = await (0, _referenceFieldsMapping.referenceFieldsMapping)({
|
|
925
|
-
context,
|
|
926
|
-
model,
|
|
927
|
-
input: originalEntry.values,
|
|
928
|
-
validateEntries: false
|
|
1028
|
+
}
|
|
1029
|
+
try {
|
|
1030
|
+
return await storageOperations.entries.getUniqueFieldValues(model, {
|
|
1031
|
+
where,
|
|
1032
|
+
fieldId
|
|
929
1033
|
});
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
1034
|
+
} catch (ex) {
|
|
1035
|
+
throw new _error.default("Error while fetching unique entry values from storage.", "LIST_UNIQUE_ENTRY_VALUES_ERROR", {
|
|
1036
|
+
error: {
|
|
1037
|
+
message: ex.message,
|
|
1038
|
+
code: ex.code,
|
|
1039
|
+
data: ex.data
|
|
1040
|
+
},
|
|
1041
|
+
model,
|
|
1042
|
+
where,
|
|
1043
|
+
fieldId
|
|
934
1044
|
});
|
|
935
|
-
|
|
936
|
-
|
|
937
|
-
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
|
|
942
|
-
|
|
943
|
-
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
|
|
948
|
-
|
|
949
|
-
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
|
|
954
|
-
|
|
955
|
-
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
|
|
1045
|
+
}
|
|
1046
|
+
};
|
|
1047
|
+
const getEntryTraverser = async modelId => {
|
|
1048
|
+
const modelAstConverter = context.cms.getModelToAstConverter();
|
|
1049
|
+
const model = await context.cms.getModel(modelId);
|
|
1050
|
+
if (!model) {
|
|
1051
|
+
throw new Error(`Missing "${modelId}" model!`);
|
|
1052
|
+
}
|
|
1053
|
+
const modelAst = modelAstConverter.toAst(model);
|
|
1054
|
+
return new _ContentEntryTraverser.ContentEntryTraverser(modelAst);
|
|
1055
|
+
};
|
|
1056
|
+
return {
|
|
1057
|
+
getEntryTraverser,
|
|
1058
|
+
onEntryBeforeCreate,
|
|
1059
|
+
onEntryAfterCreate,
|
|
1060
|
+
onEntryCreateError,
|
|
1061
|
+
onEntryRevisionBeforeCreate: onEntryBeforeCreateRevision,
|
|
1062
|
+
onEntryRevisionAfterCreate,
|
|
1063
|
+
onEntryRevisionCreateError: onEntryCreateRevisionError,
|
|
1064
|
+
onEntryBeforeUpdate,
|
|
1065
|
+
onEntryAfterUpdate,
|
|
1066
|
+
onEntryUpdateError,
|
|
1067
|
+
onEntryBeforeMove,
|
|
1068
|
+
onEntryAfterMove,
|
|
1069
|
+
onEntryMoveError,
|
|
1070
|
+
onEntryBeforeDelete,
|
|
1071
|
+
onEntryAfterDelete,
|
|
1072
|
+
onEntryDeleteError,
|
|
1073
|
+
onEntryBeforeRestoreFromBin,
|
|
1074
|
+
onEntryAfterRestoreFromBin,
|
|
1075
|
+
onEntryRestoreFromBinError,
|
|
1076
|
+
onEntryRevisionBeforeDelete,
|
|
1077
|
+
onEntryRevisionAfterDelete,
|
|
1078
|
+
onEntryRevisionDeleteError,
|
|
1079
|
+
onEntryBeforePublish,
|
|
1080
|
+
onEntryAfterPublish,
|
|
1081
|
+
onEntryPublishError,
|
|
1082
|
+
onEntryBeforeRepublish,
|
|
1083
|
+
onEntryAfterRepublish,
|
|
1084
|
+
onEntryRepublishError,
|
|
1085
|
+
onEntryBeforeUnpublish,
|
|
1086
|
+
onEntryAfterUnpublish,
|
|
1087
|
+
onEntryUnpublishError,
|
|
1088
|
+
onEntryBeforeGet,
|
|
1089
|
+
onEntryBeforeList,
|
|
1090
|
+
/**
|
|
1091
|
+
* Get entries by exact revision IDs from the database.
|
|
1092
|
+
*/
|
|
1093
|
+
async getEntriesByIds(model, ids) {
|
|
1094
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntriesByIds", async () => {
|
|
1095
|
+
return getEntriesByIdsUseCase.execute(model, {
|
|
1096
|
+
ids
|
|
960
1097
|
});
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
1098
|
+
});
|
|
1099
|
+
},
|
|
1100
|
+
/**
|
|
1101
|
+
* Get a single entry by revision ID from the database.
|
|
1102
|
+
*/
|
|
1103
|
+
async getEntryById(model, id) {
|
|
1104
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntryById", async () => {
|
|
1105
|
+
return getEntryById(model, id);
|
|
1106
|
+
});
|
|
1107
|
+
},
|
|
1108
|
+
/**
|
|
1109
|
+
* Get published revisions by entry IDs.
|
|
1110
|
+
*/
|
|
1111
|
+
async getPublishedEntriesByIds(model, ids) {
|
|
1112
|
+
return context.benchmark.measure("headlessCms.crud.entries.getPublishedEntriesByIds", async () => {
|
|
1113
|
+
return getPublishedEntriesByIdsUseCase.execute(model, {
|
|
1114
|
+
ids
|
|
965
1115
|
});
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
1116
|
+
});
|
|
1117
|
+
},
|
|
1118
|
+
/**
|
|
1119
|
+
* Get the latest revisions by entry IDs.
|
|
1120
|
+
*/
|
|
1121
|
+
async getLatestEntriesByIds(model, ids) {
|
|
1122
|
+
return context.benchmark.measure("headlessCms.crud.entries.getLatestEntriesByIds", async () => {
|
|
1123
|
+
return await getLatestEntriesByIdsUseCase.execute(model, {
|
|
1124
|
+
ids
|
|
972
1125
|
});
|
|
973
|
-
|
|
974
|
-
|
|
1126
|
+
});
|
|
1127
|
+
},
|
|
1128
|
+
async getEntryRevisions(model, entryId) {
|
|
1129
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntryRevisions", async () => {
|
|
1130
|
+
return getRevisionsByEntryIdUseCase.execute(model, {
|
|
1131
|
+
id: entryId
|
|
975
1132
|
});
|
|
976
|
-
}
|
|
1133
|
+
});
|
|
977
1134
|
},
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
1135
|
+
/**
|
|
1136
|
+
* @internal
|
|
1137
|
+
*/
|
|
1138
|
+
async getEntry(model, params) {
|
|
1139
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntry", async () => {
|
|
1140
|
+
return await getEntryUseCase.execute(model, params);
|
|
981
1141
|
});
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
1142
|
+
},
|
|
1143
|
+
/**
|
|
1144
|
+
* @description Should not be used directly. Internal use only!
|
|
1145
|
+
*
|
|
1146
|
+
* @internal
|
|
1147
|
+
*/
|
|
1148
|
+
async listEntries(model, params) {
|
|
1149
|
+
return context.benchmark.measure("headlessCms.crud.entries.listEntries", async () => {
|
|
1150
|
+
return await listEntriesUseCase.execute(model, params);
|
|
986
1151
|
});
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
const storageEntryToDelete = await storageOperations.entries.getRevisionById(model, {
|
|
992
|
-
id: revisionId
|
|
1152
|
+
},
|
|
1153
|
+
async listLatestEntries(model, params) {
|
|
1154
|
+
return context.benchmark.measure("headlessCms.crud.entries.listLatestEntries", async () => {
|
|
1155
|
+
return await listLatestUseCase.execute(model, params);
|
|
993
1156
|
});
|
|
994
|
-
|
|
995
|
-
|
|
1157
|
+
},
|
|
1158
|
+
async listDeletedEntries(model, params) {
|
|
1159
|
+
return context.benchmark.measure("headlessCms.crud.entries.listDeletedEntries", async () => {
|
|
1160
|
+
return await listDeletedUseCase.execute(model, params);
|
|
996
1161
|
});
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1162
|
+
},
|
|
1163
|
+
async listPublishedEntries(model, params) {
|
|
1164
|
+
return context.benchmark.measure("headlessCms.crud.entries.listPublishedEntries", async () => {
|
|
1165
|
+
return await listPublishedUseCase.execute(model, params);
|
|
1000
1166
|
});
|
|
1001
|
-
if (!storageEntryToDelete) {
|
|
1002
|
-
throw new _handlerGraphql.NotFoundError(`Entry "${revisionId}" was not found!`);
|
|
1003
|
-
}
|
|
1004
|
-
(0, _ownership.checkOwnership)(context, permission, storageEntryToDelete);
|
|
1005
|
-
const latestEntryRevisionId = latestStorageEntry ? latestStorageEntry.id : null;
|
|
1006
|
-
const entryToDelete = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntryToDelete);
|
|
1007
|
-
/**
|
|
1008
|
-
* If targeted record is the latest entry record and there is no previous one, we need to run full delete with hooks.
|
|
1009
|
-
* At this point deleteRevision hooks are not fired.
|
|
1010
|
-
*/
|
|
1011
|
-
if (entryToDelete.id === latestEntryRevisionId && !previousStorageEntry) {
|
|
1012
|
-
return await deleteEntry({
|
|
1013
|
-
model,
|
|
1014
|
-
entry: entryToDelete
|
|
1015
|
-
});
|
|
1016
|
-
}
|
|
1017
|
-
/**
|
|
1018
|
-
* If targeted record is latest entry revision, set the previous one as the new latest
|
|
1019
|
-
*/
|
|
1020
|
-
let entryToSetAsLatest = null;
|
|
1021
|
-
let storageEntryToSetAsLatest = null;
|
|
1022
|
-
if (entryToDelete.id === latestEntryRevisionId && previousStorageEntry) {
|
|
1023
|
-
entryToSetAsLatest = await (0, _entryStorage.entryFromStorageTransform)(context, model, previousStorageEntry);
|
|
1024
|
-
storageEntryToSetAsLatest = previousStorageEntry;
|
|
1025
|
-
}
|
|
1026
|
-
try {
|
|
1027
|
-
await onEntryRevisionBeforeDelete.publish({
|
|
1028
|
-
entry: entryToDelete,
|
|
1029
|
-
model
|
|
1030
|
-
});
|
|
1031
|
-
await storageOperations.entries.deleteRevision(model, {
|
|
1032
|
-
entry: entryToDelete,
|
|
1033
|
-
storageEntry: storageEntryToDelete,
|
|
1034
|
-
latestEntry: entryToSetAsLatest,
|
|
1035
|
-
latestStorageEntry: storageEntryToSetAsLatest
|
|
1036
|
-
});
|
|
1037
|
-
await onEntryRevisionAfterDelete.publish({
|
|
1038
|
-
entry: entryToDelete,
|
|
1039
|
-
model
|
|
1040
|
-
});
|
|
1041
|
-
} catch (ex) {
|
|
1042
|
-
await onEntryRevisionDeleteError.publish({
|
|
1043
|
-
entry: entryToDelete,
|
|
1044
|
-
model,
|
|
1045
|
-
error: ex
|
|
1046
|
-
});
|
|
1047
|
-
throw new _error.default(ex.message, ex.code || "DELETE_REVISION_ERROR", {
|
|
1048
|
-
error: ex,
|
|
1049
|
-
entry: entryToDelete,
|
|
1050
|
-
storageEntry: storageEntryToDelete,
|
|
1051
|
-
latestEntry: entryToSetAsLatest,
|
|
1052
|
-
latestStorageEntry: storageEntryToSetAsLatest
|
|
1053
|
-
});
|
|
1054
|
-
}
|
|
1055
1167
|
},
|
|
1056
|
-
async
|
|
1057
|
-
|
|
1058
|
-
|
|
1168
|
+
async createEntry(model, input, options) {
|
|
1169
|
+
return context.benchmark.measure("headlessCms.crud.entries.createEntry", async () => {
|
|
1170
|
+
return createEntry(model, input, options);
|
|
1059
1171
|
});
|
|
1060
|
-
|
|
1061
|
-
|
|
1062
|
-
|
|
1063
|
-
|
|
1172
|
+
},
|
|
1173
|
+
async createEntryRevisionFrom(model, sourceId, input, options) {
|
|
1174
|
+
return context.benchmark.measure("headlessCms.crud.entries.createEntryRevisionFrom", async () => {
|
|
1175
|
+
return createEntryRevisionFrom(model, sourceId, input, options);
|
|
1064
1176
|
});
|
|
1065
|
-
|
|
1066
|
-
|
|
1177
|
+
},
|
|
1178
|
+
async updateEntry(model, id, input, meta, options) {
|
|
1179
|
+
return context.benchmark.measure("headlessCms.crud.entries.updateEntry", async () => {
|
|
1180
|
+
return updateEntry(model, id, input, meta, options);
|
|
1067
1181
|
});
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
const entry = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntry);
|
|
1073
|
-
return await deleteEntry({
|
|
1074
|
-
model,
|
|
1075
|
-
entry
|
|
1182
|
+
},
|
|
1183
|
+
async validateEntry(model, id, input) {
|
|
1184
|
+
return context.benchmark.measure("headlessCms.crud.entries.validateEntry", async () => {
|
|
1185
|
+
return validateEntry(model, id, input);
|
|
1076
1186
|
});
|
|
1077
1187
|
},
|
|
1078
|
-
async
|
|
1079
|
-
|
|
1080
|
-
|
|
1188
|
+
async moveEntry(model, id, folderId) {
|
|
1189
|
+
return context.benchmark.measure("headlessCms.crud.entries.moveEntry", async () => {
|
|
1190
|
+
return moveEntry(model, id, folderId);
|
|
1081
1191
|
});
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1192
|
+
},
|
|
1193
|
+
/**
|
|
1194
|
+
* Method used internally. Not documented and should not be used in users systems.
|
|
1195
|
+
* @internal
|
|
1196
|
+
*/
|
|
1197
|
+
async republishEntry(model, id) {
|
|
1198
|
+
return context.benchmark.measure("headlessCms.crud.entries.republishEntry", async () => {
|
|
1199
|
+
return republishEntry(model, id);
|
|
1086
1200
|
});
|
|
1087
|
-
|
|
1088
|
-
|
|
1201
|
+
},
|
|
1202
|
+
async deleteEntryRevision(model, id) {
|
|
1203
|
+
return context.benchmark.measure("headlessCms.crud.entries.deleteEntryRevision", async () => {
|
|
1204
|
+
return deleteEntryRevision(model, id);
|
|
1089
1205
|
});
|
|
1090
|
-
if (!originalStorageEntry) {
|
|
1091
|
-
throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
|
|
1092
|
-
}
|
|
1093
|
-
(0, _ownership.checkOwnership)(context, permission, originalStorageEntry);
|
|
1094
|
-
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
1095
|
-
const currentDate = new Date().toISOString();
|
|
1096
|
-
const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
|
|
1097
|
-
status: STATUS_PUBLISHED,
|
|
1098
|
-
locked: true,
|
|
1099
|
-
savedOn: currentDate,
|
|
1100
|
-
publishedOn: currentDate
|
|
1101
|
-
});
|
|
1102
|
-
let storageEntry = null;
|
|
1103
|
-
try {
|
|
1104
|
-
await onEntryBeforePublish.publish({
|
|
1105
|
-
entry,
|
|
1106
|
-
model
|
|
1107
|
-
});
|
|
1108
|
-
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
1109
|
-
const result = await storageOperations.entries.publish(model, {
|
|
1110
|
-
entry,
|
|
1111
|
-
storageEntry
|
|
1112
|
-
});
|
|
1113
|
-
await onEntryAfterPublish.publish({
|
|
1114
|
-
entry,
|
|
1115
|
-
storageEntry: result,
|
|
1116
|
-
model
|
|
1117
|
-
});
|
|
1118
|
-
return result;
|
|
1119
|
-
} catch (ex) {
|
|
1120
|
-
await onEntryPublishError.publish({
|
|
1121
|
-
entry,
|
|
1122
|
-
model,
|
|
1123
|
-
error: ex
|
|
1124
|
-
});
|
|
1125
|
-
throw new _error.default(ex.message || "Could not publish entry.", ex.code || "PUBLISH_ERROR", {
|
|
1126
|
-
error: ex,
|
|
1127
|
-
entry,
|
|
1128
|
-
storageEntry,
|
|
1129
|
-
originalEntry,
|
|
1130
|
-
originalStorageEntry
|
|
1131
|
-
});
|
|
1132
|
-
}
|
|
1133
1206
|
},
|
|
1134
|
-
async
|
|
1135
|
-
|
|
1136
|
-
|
|
1207
|
+
async deleteEntry(model, entryId, options) {
|
|
1208
|
+
return context.benchmark.measure("headlessCms.crud.entries.deleteEntry", async () => {
|
|
1209
|
+
return deleteEntry(model, entryId, options);
|
|
1137
1210
|
});
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1211
|
+
},
|
|
1212
|
+
async restoreEntryFromBin(model, entryId) {
|
|
1213
|
+
return context.benchmark.measure("headlessCms.crud.entries.restoreEntryFromBin", async () => {
|
|
1214
|
+
return await restoreEntryFromBinUseCase.execute(model, entryId);
|
|
1141
1215
|
});
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1216
|
+
},
|
|
1217
|
+
async deleteMultipleEntries(model, ids) {
|
|
1218
|
+
return context.benchmark.measure("headlessCms.crud.entries.deleteMultipleEntries", async () => {
|
|
1219
|
+
return deleteMultipleEntries(model, ids);
|
|
1220
|
+
});
|
|
1221
|
+
},
|
|
1222
|
+
async publishEntry(model, id) {
|
|
1223
|
+
return context.benchmark.measure("headlessCms.crud.entries.publishEntry", async () => {
|
|
1224
|
+
return publishEntry(model, id);
|
|
1225
|
+
});
|
|
1226
|
+
},
|
|
1227
|
+
async unpublishEntry(model, id) {
|
|
1228
|
+
return context.benchmark.measure("headlessCms.crud.entries.unpublishEntry", async () => {
|
|
1229
|
+
return unpublishEntry(model, id);
|
|
1230
|
+
});
|
|
1231
|
+
},
|
|
1232
|
+
async getUniqueFieldValues(model, params) {
|
|
1233
|
+
return context.benchmark.measure("headlessCms.crud.entries.getUniqueFieldValues", async () => {
|
|
1234
|
+
return getUniqueFieldValues(model, params);
|
|
1147
1235
|
});
|
|
1148
|
-
if (!originalStorageEntry) {
|
|
1149
|
-
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
1150
|
-
}
|
|
1151
|
-
if (originalStorageEntry.id !== id) {
|
|
1152
|
-
throw new _error.default(`Entry is not published.`, "UNPUBLISH_ERROR", {
|
|
1153
|
-
entry: originalStorageEntry
|
|
1154
|
-
});
|
|
1155
|
-
}
|
|
1156
|
-
(0, _ownership.checkOwnership)(context, permission, originalStorageEntry);
|
|
1157
|
-
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
1158
|
-
const entry = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, originalEntry), {}, {
|
|
1159
|
-
status: STATUS_UNPUBLISHED
|
|
1160
|
-
});
|
|
1161
|
-
let storageEntry = null;
|
|
1162
|
-
try {
|
|
1163
|
-
await onEntryBeforeUnpublish.publish({
|
|
1164
|
-
entry,
|
|
1165
|
-
model
|
|
1166
|
-
});
|
|
1167
|
-
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
1168
|
-
const result = await storageOperations.entries.unpublish(model, {
|
|
1169
|
-
entry,
|
|
1170
|
-
storageEntry
|
|
1171
|
-
});
|
|
1172
|
-
await onEntryAfterUnpublish.publish({
|
|
1173
|
-
entry,
|
|
1174
|
-
storageEntry: result,
|
|
1175
|
-
model
|
|
1176
|
-
});
|
|
1177
|
-
return result;
|
|
1178
|
-
} catch (ex) {
|
|
1179
|
-
await onEntryUnpublishError.publish({
|
|
1180
|
-
entry,
|
|
1181
|
-
model,
|
|
1182
|
-
error: ex
|
|
1183
|
-
});
|
|
1184
|
-
throw new _error.default(ex.message || "Could not unpublish entry.", ex.code || "UNPUBLISH_ERROR", {
|
|
1185
|
-
originalEntry,
|
|
1186
|
-
originalStorageEntry,
|
|
1187
|
-
entry,
|
|
1188
|
-
storageEntry
|
|
1189
|
-
});
|
|
1190
|
-
}
|
|
1191
1236
|
}
|
|
1192
1237
|
};
|
|
1193
1238
|
};
|
|
1194
|
-
exports.createContentEntryCrud = createContentEntryCrud;
|
|
1239
|
+
exports.createContentEntryCrud = createContentEntryCrud;
|
|
1240
|
+
|
|
1241
|
+
//# sourceMappingURL=contentEntry.crud.js.map
|