@webiny/api-headless-cms 0.0.0-unstable.e3f4727c56 → 0.0.0-unstable.eb196ccd2f
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 +9 -0
- package/crud/contentEntry/useCases/GetEntriesByIds/GetEntriesByIds.js +21 -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 +13 -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 +9 -0
- package/crud/contentEntry/useCases/GetLatestEntriesByIds/GetLatestEntriesByIds.js +21 -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 +13 -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 +9 -0
- package/crud/contentEntry/useCases/GetLatestRevisionByEntryId/GetLatestRevisionByEntryId.js +22 -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 +15 -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 +9 -0
- package/crud/contentEntry/useCases/GetPreviousRevisionByEntryId/GetPreviousRevisionByEntryId.js +22 -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 +11 -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 +9 -0
- package/crud/contentEntry/useCases/GetPublishedEntriesByIds/GetPublishedEntriesByIds.js +21 -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 +13 -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 +9 -0
- package/crud/contentEntry/useCases/GetPublishedRevisionByEntryId/GetPublishedRevisionByEntryId.js +22 -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 +11 -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 +9 -0
- package/crud/contentEntry/useCases/GetRevisionById/GetRevisionById.js +22 -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 +11 -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 +9 -0
- package/crud/contentEntry/useCases/GetRevisionsByEntryId/GetRevisionsByEntryId.js +21 -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 +13 -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 +14 -0
- package/crud/contentEntry/useCases/ListEntries/ListEntriesOperation.js +24 -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 +26 -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 +9 -0
- package/crud/contentEntry/useCases/RestoreEntryFromBin/RestoreEntryFromBinOperation.js +19 -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 +25 -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 +1057 -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 +583 -167
- 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 +9 -6
- 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 -11
- 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 -13
- 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 +60 -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 -7
- 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 -44
- 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 +16 -4
- package/utils/entryStorage.js +41 -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/createFieldModels.d.ts +0 -2
- package/crud/contentModel/createFieldModels.js +0 -26
- package/crud/contentModel/createFieldModels.js.map +0 -1
- package/crud/contentModel/fieldIdValidation.d.ts +0 -1
- package/crud/contentModel/fieldIdValidation.js +0 -25
- package/crud/contentModel/fieldIdValidation.js.map +0 -1
- package/crud/contentModel/idValidation.d.ts +0 -1
- package/crud/contentModel/idValidation.js +0 -22
- package/crud/contentModel/idValidation.js.map +0 -1
- package/crud/contentModel/models.d.ts +0 -4
- package/crud/contentModel/models.js +0 -192
- package/crud/contentModel/models.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 -2634
- package/types.js.map +0 -1
- package/upgrades/5.33.0/index.d.ts +0 -3
- package/upgrades/5.33.0/index.js +0 -182
- package/upgrades/5.33.0/index.js.map +0 -1
- package/upgrades/index.d.ts +0 -1
- package/upgrades/index.js +0 -12
- 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,1123 @@ const createContentEntryCrud = params => {
|
|
|
268
131
|
context,
|
|
269
132
|
onEntryAfterDelete
|
|
270
133
|
});
|
|
271
|
-
const
|
|
272
|
-
|
|
273
|
-
};
|
|
134
|
+
const transformEntryFromStorageCallable = (0, _entryStorage.createTransformEntryCallable)({
|
|
135
|
+
context
|
|
136
|
+
});
|
|
137
|
+
/**
|
|
138
|
+
* List entries
|
|
139
|
+
*/
|
|
140
|
+
const {
|
|
141
|
+
listEntriesUseCase,
|
|
142
|
+
listLatestUseCase,
|
|
143
|
+
listDeletedUseCase,
|
|
144
|
+
listPublishedUseCase,
|
|
145
|
+
getEntryUseCase
|
|
146
|
+
} = (0, _useCases.listEntriesUseCases)({
|
|
147
|
+
transform: transformEntryFromStorageCallable,
|
|
148
|
+
operation: storageOperations.entries.list,
|
|
149
|
+
accessControl,
|
|
150
|
+
topics: {
|
|
151
|
+
onEntryBeforeList
|
|
152
|
+
},
|
|
153
|
+
context,
|
|
154
|
+
getIdentity: getSecurityIdentity
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* Get entries by ids
|
|
159
|
+
*/
|
|
160
|
+
const {
|
|
161
|
+
getEntriesByIdsUseCase
|
|
162
|
+
} = (0, _useCases.getEntriesByIdsUseCases)({
|
|
163
|
+
transform: transformEntryFromStorageCallable,
|
|
164
|
+
operation: storageOperations.entries.getByIds,
|
|
165
|
+
accessControl
|
|
166
|
+
});
|
|
167
|
+
|
|
168
|
+
/**
|
|
169
|
+
* Get latest entries by ids
|
|
170
|
+
*/
|
|
171
|
+
const {
|
|
172
|
+
getLatestEntriesByIdsUseCase
|
|
173
|
+
} = (0, _useCases.getLatestEntriesByIdsUseCases)({
|
|
174
|
+
transform: transformEntryFromStorageCallable,
|
|
175
|
+
operation: storageOperations.entries.getLatestByIds,
|
|
176
|
+
accessControl
|
|
177
|
+
});
|
|
178
|
+
|
|
179
|
+
/**
|
|
180
|
+
* Get published entries by ids
|
|
181
|
+
*/
|
|
182
|
+
const {
|
|
183
|
+
getPublishedEntriesByIdsUseCase
|
|
184
|
+
} = (0, _useCases.getPublishedEntriesByIdsUseCases)({
|
|
185
|
+
transform: transformEntryFromStorageCallable,
|
|
186
|
+
operation: storageOperations.entries.getPublishedByIds,
|
|
187
|
+
accessControl
|
|
188
|
+
});
|
|
189
|
+
|
|
190
|
+
/**
|
|
191
|
+
* Get revisions by entryId
|
|
192
|
+
*/
|
|
193
|
+
const {
|
|
194
|
+
getRevisionsByEntryIdUseCase
|
|
195
|
+
} = (0, _useCases.getRevisionsByEntryIdUseCases)({
|
|
196
|
+
transform: transformEntryFromStorageCallable,
|
|
197
|
+
operation: storageOperations.entries.getRevisions,
|
|
198
|
+
accessControl
|
|
199
|
+
});
|
|
200
|
+
|
|
201
|
+
/**
|
|
202
|
+
* Get revision by id
|
|
203
|
+
*/
|
|
204
|
+
const {
|
|
205
|
+
getRevisionByIdUseCase
|
|
206
|
+
} = (0, _useCases.getRevisionByIdUseCases)({
|
|
207
|
+
transform: transformEntryFromStorageCallable,
|
|
208
|
+
operation: storageOperations.entries.getRevisionById
|
|
209
|
+
});
|
|
210
|
+
|
|
211
|
+
/**
|
|
212
|
+
* Get latest revision by entryId
|
|
213
|
+
*/
|
|
214
|
+
const {
|
|
215
|
+
getLatestRevisionByEntryIdUseCase,
|
|
216
|
+
getLatestRevisionByEntryIdWithDeletedUseCase,
|
|
217
|
+
getLatestRevisionByEntryIdDeletedUseCase
|
|
218
|
+
} = (0, _useCases.getLatestRevisionByEntryIdUseCases)({
|
|
219
|
+
transform: transformEntryFromStorageCallable,
|
|
220
|
+
operation: storageOperations.entries.getLatestRevisionByEntryId
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* Get previous revision by entryId
|
|
225
|
+
*/
|
|
226
|
+
const {
|
|
227
|
+
getPreviousRevisionByEntryIdUseCase
|
|
228
|
+
} = (0, _useCases.getPreviousRevisionByEntryIdUseCases)({
|
|
229
|
+
transform: transformEntryFromStorageCallable,
|
|
230
|
+
operation: storageOperations.entries.getPreviousRevision
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
/**
|
|
234
|
+
* Get published revision by entryId
|
|
235
|
+
*/
|
|
236
|
+
const {
|
|
237
|
+
getPublishedRevisionByEntryIdUseCase
|
|
238
|
+
} = (0, _useCases.getPublishedRevisionByEntryIdUseCases)({
|
|
239
|
+
transform: transformEntryFromStorageCallable,
|
|
240
|
+
operation: storageOperations.entries.getPublishedRevisionByEntryId
|
|
241
|
+
});
|
|
242
|
+
|
|
243
|
+
/**
|
|
244
|
+
* Delete entry
|
|
245
|
+
*/
|
|
246
|
+
const {
|
|
247
|
+
deleteEntryUseCase,
|
|
248
|
+
moveEntryToBinUseCase,
|
|
249
|
+
deleteEntryOperation
|
|
250
|
+
} = (0, _useCases.deleteEntryUseCases)({
|
|
251
|
+
deleteOperation: storageOperations.entries.delete,
|
|
252
|
+
moveToBinOperation: storageOperations.entries.moveToBin,
|
|
253
|
+
getEntry: getLatestRevisionByEntryIdUseCase,
|
|
254
|
+
getEntryWithDeleted: getLatestRevisionByEntryIdWithDeletedUseCase,
|
|
255
|
+
getIdentity: getSecurityIdentity,
|
|
256
|
+
topics: {
|
|
257
|
+
onEntryBeforeDelete,
|
|
258
|
+
onEntryAfterDelete,
|
|
259
|
+
onEntryDeleteError
|
|
260
|
+
},
|
|
261
|
+
accessControl,
|
|
262
|
+
context
|
|
263
|
+
});
|
|
274
264
|
|
|
275
265
|
/**
|
|
276
|
-
*
|
|
266
|
+
* Restore entry from bin
|
|
277
267
|
*/
|
|
278
|
-
const
|
|
268
|
+
const {
|
|
269
|
+
restoreEntryFromBinUseCase
|
|
270
|
+
} = (0, _useCases.restoreEntryFromBinUseCases)({
|
|
271
|
+
transform: transformEntryFromStorageCallable,
|
|
272
|
+
getEntry: getLatestRevisionByEntryIdDeletedUseCase,
|
|
273
|
+
getIdentity: getSecurityIdentity,
|
|
274
|
+
restoreOperation: storageOperations.entries.restoreFromBin,
|
|
275
|
+
topics: {
|
|
276
|
+
onEntryBeforeRestoreFromBin,
|
|
277
|
+
onEntryAfterRestoreFromBin,
|
|
278
|
+
onEntryRestoreFromBinError
|
|
279
|
+
},
|
|
280
|
+
accessControl,
|
|
281
|
+
context
|
|
282
|
+
});
|
|
283
|
+
const getEntryById = async (model, id) => {
|
|
284
|
+
const where = {
|
|
285
|
+
id
|
|
286
|
+
};
|
|
287
|
+
await onEntryBeforeGet.publish({
|
|
288
|
+
where,
|
|
289
|
+
model
|
|
290
|
+
});
|
|
291
|
+
const [entry] = await getEntriesByIdsUseCase.execute(model, {
|
|
292
|
+
ids: [id]
|
|
293
|
+
});
|
|
294
|
+
if (!entry) {
|
|
295
|
+
throw new _handlerGraphql.NotFoundError(`Entry by ID "${id}" not found.`);
|
|
296
|
+
}
|
|
297
|
+
// TODO figure out without casting
|
|
298
|
+
return entry;
|
|
299
|
+
};
|
|
300
|
+
const createEntry = async (model, rawInput, options) => {
|
|
301
|
+
await accessControl.ensureCanAccessEntry({
|
|
302
|
+
model,
|
|
303
|
+
rwd: "w"
|
|
304
|
+
});
|
|
279
305
|
const {
|
|
306
|
+
entry,
|
|
307
|
+
input
|
|
308
|
+
} = await (0, _entryDataFactories.createEntryData)({
|
|
309
|
+
context,
|
|
280
310
|
model,
|
|
281
|
-
|
|
282
|
-
|
|
311
|
+
options,
|
|
312
|
+
rawInput,
|
|
313
|
+
getLocale,
|
|
314
|
+
getTenant,
|
|
315
|
+
getIdentity: getSecurityIdentity,
|
|
316
|
+
accessControl
|
|
317
|
+
});
|
|
318
|
+
await accessControl.ensureCanAccessEntry({
|
|
319
|
+
model,
|
|
320
|
+
entry,
|
|
321
|
+
rwd: "w"
|
|
322
|
+
});
|
|
323
|
+
let storageEntry = null;
|
|
283
324
|
try {
|
|
284
|
-
await
|
|
325
|
+
await onEntryBeforeCreate.publish({
|
|
285
326
|
entry,
|
|
327
|
+
input,
|
|
286
328
|
model
|
|
287
329
|
});
|
|
288
|
-
await
|
|
289
|
-
|
|
330
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
331
|
+
const result = await storageOperations.entries.create(model, {
|
|
332
|
+
entry,
|
|
333
|
+
storageEntry
|
|
290
334
|
});
|
|
291
|
-
await
|
|
335
|
+
await onEntryAfterCreate.publish({
|
|
292
336
|
entry,
|
|
293
|
-
|
|
337
|
+
storageEntry: result,
|
|
338
|
+
model,
|
|
339
|
+
input
|
|
294
340
|
});
|
|
341
|
+
return entry;
|
|
295
342
|
} catch (ex) {
|
|
296
|
-
await
|
|
343
|
+
await onEntryCreateError.publish({
|
|
344
|
+
error: ex,
|
|
297
345
|
entry,
|
|
298
346
|
model,
|
|
299
|
-
|
|
347
|
+
input
|
|
300
348
|
});
|
|
301
|
-
throw new _error.default(ex.message || "Could not
|
|
302
|
-
|
|
349
|
+
throw new _error.default(ex.message || "Could not create content entry.", ex.code || "CREATE_ENTRY_ERROR", ex.data || {
|
|
350
|
+
error: ex,
|
|
351
|
+
input,
|
|
352
|
+
entry,
|
|
353
|
+
storageEntry
|
|
303
354
|
});
|
|
304
355
|
}
|
|
305
356
|
};
|
|
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
|
|
357
|
+
const createEntryRevisionFrom = async (model, sourceId, rawInput, options) => {
|
|
358
|
+
await accessControl.ensureCanAccessEntry({
|
|
359
|
+
model,
|
|
360
|
+
rwd: "w"
|
|
320
361
|
});
|
|
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,
|
|
362
|
+
|
|
395
363
|
/**
|
|
396
|
-
*
|
|
364
|
+
* Entries are identified by a common parent ID + Revision number.
|
|
397
365
|
*/
|
|
398
|
-
|
|
366
|
+
const {
|
|
367
|
+
id: uniqueId
|
|
368
|
+
} = (0, _utils.parseIdentifier)(sourceId);
|
|
369
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
370
|
+
id: sourceId
|
|
371
|
+
});
|
|
372
|
+
const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
|
|
373
|
+
id: uniqueId
|
|
374
|
+
});
|
|
375
|
+
if (!originalStorageEntry) {
|
|
376
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${sourceId}" of model "${model.modelId}" was not found.`);
|
|
377
|
+
}
|
|
378
|
+
if (!latestStorageEntry) {
|
|
379
|
+
throw new _handlerGraphql.NotFoundError(`Latest entry "${uniqueId}" of model "${model.modelId}" was not found.`);
|
|
380
|
+
}
|
|
381
|
+
|
|
399
382
|
/**
|
|
400
|
-
*
|
|
383
|
+
* We need to convert data from DB to its original form before using it further.
|
|
401
384
|
*/
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
385
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
386
|
+
const {
|
|
387
|
+
entry,
|
|
388
|
+
input
|
|
389
|
+
} = await (0, _entryDataFactories.createEntryRevisionFromData)({
|
|
390
|
+
sourceId,
|
|
391
|
+
model,
|
|
392
|
+
rawInput,
|
|
393
|
+
options,
|
|
394
|
+
context,
|
|
395
|
+
getIdentity: getSecurityIdentity,
|
|
396
|
+
getTenant,
|
|
397
|
+
getLocale,
|
|
398
|
+
originalEntry,
|
|
399
|
+
latestStorageEntry,
|
|
400
|
+
accessControl
|
|
401
|
+
});
|
|
402
|
+
await accessControl.ensureCanAccessEntry({
|
|
403
|
+
model,
|
|
404
|
+
entry,
|
|
405
|
+
rwd: "w"
|
|
406
|
+
});
|
|
407
|
+
let storageEntry = null;
|
|
408
|
+
try {
|
|
409
|
+
await onEntryBeforeCreateRevision.publish({
|
|
410
|
+
input,
|
|
411
|
+
entry,
|
|
412
|
+
original: originalEntry,
|
|
412
413
|
model
|
|
413
414
|
});
|
|
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"
|
|
415
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
416
|
+
const result = await storageOperations.entries.createRevisionFrom(model, {
|
|
417
|
+
entry,
|
|
418
|
+
storageEntry
|
|
426
419
|
});
|
|
427
|
-
await
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
420
|
+
await onEntryRevisionAfterCreate.publish({
|
|
421
|
+
input,
|
|
422
|
+
entry,
|
|
423
|
+
model,
|
|
424
|
+
original: originalEntry,
|
|
425
|
+
storageEntry: result
|
|
431
426
|
});
|
|
432
|
-
|
|
433
|
-
|
|
427
|
+
return entry;
|
|
428
|
+
} catch (ex) {
|
|
429
|
+
await onEntryCreateRevisionError.publish({
|
|
430
|
+
entry,
|
|
431
|
+
original: originalEntry,
|
|
432
|
+
model,
|
|
433
|
+
input,
|
|
434
|
+
error: ex
|
|
434
435
|
});
|
|
435
|
-
|
|
436
|
-
|
|
436
|
+
throw new _error.default(ex.message || "Could not create entry from existing one.", ex.code || "CREATE_FROM_REVISION_ERROR", {
|
|
437
|
+
error: ex,
|
|
438
|
+
entry,
|
|
439
|
+
storageEntry,
|
|
440
|
+
originalEntry,
|
|
441
|
+
originalStorageEntry
|
|
442
|
+
});
|
|
443
|
+
}
|
|
444
|
+
};
|
|
445
|
+
const updateEntry = async (model, id, rawInput, metaInput, options) => {
|
|
446
|
+
await accessControl.ensureCanAccessEntry({
|
|
447
|
+
model,
|
|
448
|
+
rwd: "w"
|
|
449
|
+
});
|
|
450
|
+
|
|
437
451
|
/**
|
|
438
|
-
*
|
|
452
|
+
* The entry we are going to update.
|
|
439
453
|
*/
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
|
|
454
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
455
|
+
id
|
|
456
|
+
});
|
|
457
|
+
if (!originalStorageEntry) {
|
|
458
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
459
|
+
}
|
|
460
|
+
if (originalStorageEntry.locked) {
|
|
461
|
+
throw new _error.default(`Cannot update entry because it's locked.`, "CONTENT_ENTRY_UPDATE_ERROR");
|
|
462
|
+
}
|
|
463
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
464
|
+
const {
|
|
465
|
+
entry,
|
|
466
|
+
input
|
|
467
|
+
} = await (0, _entryDataFactories.createUpdateEntryData)({
|
|
468
|
+
model,
|
|
469
|
+
rawInput,
|
|
470
|
+
options,
|
|
471
|
+
context,
|
|
472
|
+
getIdentity: getSecurityIdentity,
|
|
473
|
+
getTenant,
|
|
474
|
+
getLocale,
|
|
475
|
+
originalEntry,
|
|
476
|
+
metaInput
|
|
477
|
+
});
|
|
478
|
+
await accessControl.ensureCanAccessEntry({
|
|
479
|
+
model,
|
|
480
|
+
entry,
|
|
481
|
+
rwd: "w"
|
|
482
|
+
});
|
|
483
|
+
let storageEntry = null;
|
|
484
|
+
try {
|
|
485
|
+
await onEntryBeforeUpdate.publish({
|
|
486
|
+
entry,
|
|
487
|
+
model,
|
|
488
|
+
input,
|
|
489
|
+
original: originalEntry
|
|
443
490
|
});
|
|
444
|
-
await (0,
|
|
445
|
-
const
|
|
446
|
-
|
|
447
|
-
|
|
491
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
492
|
+
const result = await storageOperations.entries.update(model, {
|
|
493
|
+
entry,
|
|
494
|
+
storageEntry
|
|
448
495
|
});
|
|
449
|
-
|
|
450
|
-
|
|
496
|
+
await onEntryAfterUpdate.publish({
|
|
497
|
+
entry,
|
|
498
|
+
storageEntry: result,
|
|
499
|
+
model,
|
|
500
|
+
input,
|
|
501
|
+
original: originalEntry
|
|
451
502
|
});
|
|
452
|
-
return
|
|
453
|
-
}
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
model
|
|
457
|
-
|
|
503
|
+
return entry;
|
|
504
|
+
} catch (ex) {
|
|
505
|
+
await onEntryUpdateError.publish({
|
|
506
|
+
entry,
|
|
507
|
+
model,
|
|
508
|
+
input,
|
|
509
|
+
error: ex
|
|
458
510
|
});
|
|
459
|
-
|
|
460
|
-
|
|
511
|
+
throw new _error.default(ex.message || "Could not update existing entry.", ex.code || "UPDATE_ERROR", {
|
|
512
|
+
error: ex,
|
|
513
|
+
entry,
|
|
514
|
+
storageEntry,
|
|
515
|
+
originalEntry,
|
|
516
|
+
input
|
|
461
517
|
});
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
518
|
+
}
|
|
519
|
+
};
|
|
520
|
+
const validateEntry = async (model, id, inputData) => {
|
|
521
|
+
await accessControl.ensureCanAccessEntry({
|
|
522
|
+
model,
|
|
523
|
+
rwd: "w"
|
|
524
|
+
});
|
|
525
|
+
const input = (0, _entryDataFactories.mapAndCleanUpdatedInputData)(model, inputData || {});
|
|
526
|
+
let originalEntry;
|
|
527
|
+
if (id) {
|
|
528
|
+
/**
|
|
529
|
+
* The entry we are going to update.
|
|
530
|
+
*/
|
|
531
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
532
|
+
id
|
|
533
|
+
});
|
|
534
|
+
if (!originalStorageEntry) {
|
|
535
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
536
|
+
}
|
|
537
|
+
originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
538
|
+
}
|
|
539
|
+
await accessControl.ensureCanAccessEntry({
|
|
540
|
+
model,
|
|
541
|
+
entry: originalEntry,
|
|
542
|
+
rwd: "w"
|
|
543
|
+
});
|
|
544
|
+
const result = await (0, _entryDataValidation.validateModelEntryData)({
|
|
545
|
+
context,
|
|
546
|
+
model,
|
|
547
|
+
data: input,
|
|
548
|
+
entry: originalEntry
|
|
549
|
+
});
|
|
550
|
+
return result.length > 0 ? result : [];
|
|
551
|
+
};
|
|
552
|
+
const moveEntry = async (model, id, folderId) => {
|
|
553
|
+
await accessControl.ensureCanAccessEntry({
|
|
554
|
+
model,
|
|
555
|
+
rwd: "w"
|
|
556
|
+
});
|
|
557
|
+
|
|
558
|
+
/**
|
|
559
|
+
* The entry we are going to move to another folder.
|
|
467
560
|
*/
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
561
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
562
|
+
id
|
|
563
|
+
});
|
|
564
|
+
if (!originalStorageEntry) {
|
|
565
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
566
|
+
}
|
|
567
|
+
const entry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
568
|
+
await accessControl.ensureCanAccessEntry({
|
|
569
|
+
model,
|
|
570
|
+
entry,
|
|
571
|
+
rwd: "w"
|
|
572
|
+
});
|
|
573
|
+
|
|
574
|
+
/**
|
|
575
|
+
* No need to continue if the entry is already in the requested folder.
|
|
576
|
+
*/
|
|
577
|
+
if (entry.location?.folderId === folderId) {
|
|
578
|
+
return entry;
|
|
579
|
+
}
|
|
580
|
+
try {
|
|
581
|
+
await onEntryBeforeMove.publish({
|
|
582
|
+
entry,
|
|
583
|
+
model,
|
|
584
|
+
folderId
|
|
471
585
|
});
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
586
|
+
await storageOperations.entries.move(model, id, folderId);
|
|
587
|
+
await onEntryAfterMove.publish({
|
|
588
|
+
entry,
|
|
589
|
+
model,
|
|
590
|
+
folderId
|
|
475
591
|
});
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
592
|
+
return entry;
|
|
593
|
+
} catch (ex) {
|
|
594
|
+
await onEntryMoveError.publish({
|
|
595
|
+
entry,
|
|
596
|
+
model,
|
|
597
|
+
folderId,
|
|
598
|
+
error: ex
|
|
483
599
|
});
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
487
|
-
limit: 1
|
|
600
|
+
throw _error.default.from(ex, {
|
|
601
|
+
message: `Could not move entry "${id}" of model "${model.modelId}".`,
|
|
602
|
+
code: "MOVE_ENTRY_ERROR"
|
|
488
603
|
});
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
604
|
+
}
|
|
605
|
+
};
|
|
606
|
+
const republishEntry = async (model, id) => {
|
|
607
|
+
await accessControl.ensureCanAccessEntry({
|
|
608
|
+
model,
|
|
609
|
+
rwd: "w",
|
|
610
|
+
pw: "p"
|
|
611
|
+
});
|
|
612
|
+
|
|
494
613
|
/**
|
|
495
|
-
*
|
|
496
|
-
|
|
497
|
-
|
|
614
|
+
* Fetch the entry from the storage.
|
|
615
|
+
*/
|
|
616
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
617
|
+
id
|
|
618
|
+
});
|
|
619
|
+
if (!originalStorageEntry) {
|
|
620
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" was not found!`);
|
|
621
|
+
}
|
|
622
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
623
|
+
await accessControl.ensureCanAccessEntry({
|
|
624
|
+
model,
|
|
625
|
+
entry: originalEntry,
|
|
626
|
+
rwd: "w",
|
|
627
|
+
pw: "p"
|
|
628
|
+
});
|
|
629
|
+
const {
|
|
630
|
+
entry
|
|
631
|
+
} = await (0, _entryDataFactories.createRepublishEntryData)({
|
|
632
|
+
context,
|
|
633
|
+
model,
|
|
634
|
+
originalEntry,
|
|
635
|
+
getIdentity: getSecurityIdentity
|
|
636
|
+
});
|
|
637
|
+
const storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
638
|
+
/**
|
|
639
|
+
* First we need to update existing entry.
|
|
498
640
|
*/
|
|
499
|
-
|
|
500
|
-
|
|
501
|
-
|
|
641
|
+
try {
|
|
642
|
+
await storageOperations.entries.update(model, {
|
|
643
|
+
entry,
|
|
644
|
+
storageEntry
|
|
502
645
|
});
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
plugins
|
|
646
|
+
} catch (ex) {
|
|
647
|
+
throw new _error.default("Could not update existing entry with new data while re-publishing.", "REPUBLISH_UPDATE_ERROR", {
|
|
648
|
+
entry
|
|
507
649
|
});
|
|
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"
|
|
650
|
+
}
|
|
651
|
+
/**
|
|
652
|
+
* Then we move onto publishing it again.
|
|
653
|
+
*/
|
|
654
|
+
try {
|
|
655
|
+
await onEntryBeforeRepublish.publish({
|
|
656
|
+
entry,
|
|
657
|
+
model
|
|
604
658
|
});
|
|
605
|
-
await
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
plugins
|
|
659
|
+
const result = await storageOperations.entries.publish(model, {
|
|
660
|
+
entry,
|
|
661
|
+
storageEntry
|
|
609
662
|
});
|
|
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,
|
|
663
|
+
await onEntryAfterRepublish.publish({
|
|
664
|
+
entry,
|
|
617
665
|
model,
|
|
618
|
-
|
|
666
|
+
storageEntry: result
|
|
619
667
|
});
|
|
620
|
-
|
|
621
|
-
|
|
668
|
+
return entry;
|
|
669
|
+
} catch (ex) {
|
|
670
|
+
await onEntryRepublishError.publish({
|
|
671
|
+
entry,
|
|
622
672
|
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"
|
|
673
|
+
error: ex
|
|
695
674
|
});
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
model: initialModel,
|
|
699
|
-
plugins
|
|
675
|
+
throw new _error.default("Could not publish existing entry while re-publishing.", "REPUBLISH_PUBLISH_ERROR", {
|
|
676
|
+
entry
|
|
700
677
|
});
|
|
678
|
+
}
|
|
679
|
+
};
|
|
680
|
+
const deleteEntryRevision = async (model, revisionId) => {
|
|
681
|
+
await accessControl.ensureCanAccessEntry({
|
|
682
|
+
model,
|
|
683
|
+
rwd: "d"
|
|
684
|
+
});
|
|
685
|
+
const {
|
|
686
|
+
id: entryId,
|
|
687
|
+
version
|
|
688
|
+
} = (0, _utils.parseIdentifier)(revisionId);
|
|
689
|
+
const storageEntryToDelete = await getRevisionByIdUseCase.execute(model, {
|
|
690
|
+
id: revisionId
|
|
691
|
+
});
|
|
692
|
+
const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
|
|
693
|
+
id: entryId
|
|
694
|
+
});
|
|
695
|
+
const storagePreviousEntry = await getPreviousRevisionByEntryIdUseCase.execute(model, {
|
|
696
|
+
entryId,
|
|
697
|
+
version: version
|
|
698
|
+
});
|
|
699
|
+
if (!storageEntryToDelete) {
|
|
700
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${revisionId}" was not found!`);
|
|
701
|
+
}
|
|
702
|
+
const latestEntryRevisionId = latestStorageEntry ? latestStorageEntry.id : null;
|
|
703
|
+
const entryToDelete = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntryToDelete);
|
|
704
|
+
await accessControl.ensureCanAccessEntry({
|
|
705
|
+
model,
|
|
706
|
+
entry: entryToDelete,
|
|
707
|
+
rwd: "d"
|
|
708
|
+
});
|
|
701
709
|
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
710
|
+
/**
|
|
711
|
+
* If targeted record is the latest entry record and there is no previous one, we need
|
|
712
|
+
* to run full delete with hooks. In this case, `deleteRevision` hooks are not fired.
|
|
713
|
+
*/
|
|
714
|
+
if (entryToDelete.id === latestEntryRevisionId && !storagePreviousEntry) {
|
|
715
|
+
return await deleteEntryOperation.execute(model, {
|
|
716
|
+
entry: entryToDelete
|
|
717
|
+
});
|
|
718
|
+
}
|
|
719
|
+
/**
|
|
720
|
+
* If targeted record is the latest entry revision, set the previous one as the new latest.
|
|
721
|
+
*/
|
|
722
|
+
let entryToSetAsLatest = null;
|
|
723
|
+
let storageEntryToSetAsLatest = null;
|
|
724
|
+
let updatedEntryToSetAsLatest = null;
|
|
725
|
+
let storageUpdatedEntryToSetAsLatest = null;
|
|
726
|
+
if (entryToDelete.id === latestEntryRevisionId && storagePreviousEntry) {
|
|
727
|
+
entryToSetAsLatest = await (0, _entryStorage.entryFromStorageTransform)(context, model, storagePreviousEntry);
|
|
728
|
+
storageEntryToSetAsLatest = storagePreviousEntry;
|
|
706
729
|
|
|
707
730
|
/**
|
|
708
|
-
*
|
|
731
|
+
* Since we're setting a different revision as the latest, we need to update entry-level meta
|
|
732
|
+
* fields. The values are taken from the latest revision we're about to delete. The update of the
|
|
733
|
+
* new latest revision is performed within storage operations.
|
|
709
734
|
*/
|
|
710
|
-
const
|
|
711
|
-
|
|
712
|
-
|
|
713
|
-
|
|
714
|
-
|
|
735
|
+
const pickedEntryLevelMetaFields = (0, _constants.pickEntryMetaFields)(entryToDelete, _constants.isEntryLevelEntryMetaField);
|
|
736
|
+
updatedEntryToSetAsLatest = {
|
|
737
|
+
...entryToSetAsLatest,
|
|
738
|
+
...pickedEntryLevelMetaFields
|
|
739
|
+
};
|
|
740
|
+
storageUpdatedEntryToSetAsLatest = {
|
|
741
|
+
...storageEntryToSetAsLatest,
|
|
742
|
+
...pickedEntryLevelMetaFields
|
|
743
|
+
};
|
|
744
|
+
}
|
|
745
|
+
try {
|
|
746
|
+
await onEntryRevisionBeforeDelete.publish({
|
|
747
|
+
entry: entryToDelete,
|
|
748
|
+
model
|
|
715
749
|
});
|
|
716
|
-
|
|
717
|
-
|
|
750
|
+
await storageOperations.entries.deleteRevision(model, {
|
|
751
|
+
entry: entryToDelete,
|
|
752
|
+
storageEntry: storageEntryToDelete,
|
|
753
|
+
latestEntry: updatedEntryToSetAsLatest,
|
|
754
|
+
latestStorageEntry: storageUpdatedEntryToSetAsLatest
|
|
718
755
|
});
|
|
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
|
|
756
|
+
await onEntryRevisionAfterDelete.publish({
|
|
757
|
+
entry: entryToDelete,
|
|
758
|
+
model
|
|
733
759
|
});
|
|
734
|
-
|
|
735
|
-
|
|
760
|
+
} catch (ex) {
|
|
761
|
+
await onEntryRevisionDeleteError.publish({
|
|
762
|
+
entry: entryToDelete,
|
|
736
763
|
model,
|
|
737
|
-
|
|
738
|
-
|
|
764
|
+
error: ex
|
|
765
|
+
});
|
|
766
|
+
throw new _error.default(ex.message, ex.code || "DELETE_REVISION_ERROR", {
|
|
767
|
+
error: ex,
|
|
768
|
+
entry: entryToDelete,
|
|
769
|
+
storageEntry: storageEntryToDelete,
|
|
770
|
+
latestEntry: updatedEntryToSetAsLatest,
|
|
771
|
+
latestStorageEntry: storageUpdatedEntryToSetAsLatest
|
|
739
772
|
});
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
773
|
+
}
|
|
774
|
+
};
|
|
775
|
+
const deleteMultipleEntries = async (model, params) => {
|
|
776
|
+
const {
|
|
777
|
+
entries: input
|
|
778
|
+
} = params;
|
|
779
|
+
const maxDeletableEntries = 50;
|
|
780
|
+
const entryIdList = new Set();
|
|
781
|
+
for (const id of input) {
|
|
743
782
|
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"
|
|
783
|
+
id: entryId
|
|
784
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
785
|
+
entryIdList.add(entryId);
|
|
786
|
+
}
|
|
787
|
+
const ids = Array.from(entryIdList);
|
|
788
|
+
if (ids.length > maxDeletableEntries) {
|
|
789
|
+
throw new _error.default("Cannot delete more than 50 entries at once.", "DELETE_ENTRIES_MAX", {
|
|
790
|
+
entries: ids
|
|
791
|
+
});
|
|
792
|
+
}
|
|
793
|
+
await accessControl.ensureCanAccessEntry({
|
|
794
|
+
model,
|
|
795
|
+
rwd: "d"
|
|
796
|
+
});
|
|
797
|
+
const {
|
|
798
|
+
items: entries
|
|
799
|
+
} = await storageOperations.entries.list(model, {
|
|
800
|
+
where: {
|
|
801
|
+
latest: true,
|
|
802
|
+
entryId_in: ids
|
|
803
|
+
},
|
|
804
|
+
limit: maxDeletableEntries + 1
|
|
805
|
+
});
|
|
806
|
+
/**
|
|
807
|
+
* We do not want to allow deleting entries that user does not own or cannot access.
|
|
808
|
+
*/
|
|
809
|
+
const items = (await (0, _filterAsync.filterAsync)(entries, async entry => {
|
|
810
|
+
return accessControl.canAccessEntry({
|
|
811
|
+
model,
|
|
812
|
+
entry: entry
|
|
803
813
|
});
|
|
804
|
-
|
|
805
|
-
|
|
806
|
-
|
|
807
|
-
|
|
814
|
+
})).map(entry => entry.id);
|
|
815
|
+
try {
|
|
816
|
+
await onEntryBeforeDeleteMultiple.publish({
|
|
817
|
+
entries,
|
|
818
|
+
ids,
|
|
819
|
+
model
|
|
820
|
+
});
|
|
821
|
+
await storageOperations.entries.deleteMultipleEntries(model, {
|
|
822
|
+
entries: items
|
|
823
|
+
});
|
|
824
|
+
await onEntryAfterDeleteMultiple.publish({
|
|
825
|
+
entries,
|
|
826
|
+
ids,
|
|
827
|
+
model
|
|
828
|
+
});
|
|
829
|
+
return items.map(id => {
|
|
830
|
+
return {
|
|
831
|
+
id
|
|
832
|
+
};
|
|
808
833
|
});
|
|
834
|
+
} catch (ex) {
|
|
835
|
+
await onEntryDeleteMultipleError.publish({
|
|
836
|
+
entries,
|
|
837
|
+
ids,
|
|
838
|
+
model,
|
|
839
|
+
error: ex
|
|
840
|
+
});
|
|
841
|
+
throw new _error.default(ex.message, ex.code || "DELETE_ENTRIES_MULTIPLE_ERROR", {
|
|
842
|
+
error: ex,
|
|
843
|
+
entries
|
|
844
|
+
});
|
|
845
|
+
}
|
|
846
|
+
};
|
|
847
|
+
const deleteEntry = async (model, id, options = {}) => {
|
|
848
|
+
const {
|
|
849
|
+
permanently = true
|
|
850
|
+
} = options;
|
|
809
851
|
|
|
810
|
-
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
852
|
+
/**
|
|
853
|
+
* If the 'permanently' flag is set to false, the entry must be moved to the bin; otherwise, deleted.
|
|
854
|
+
*/
|
|
855
|
+
if (!permanently) {
|
|
856
|
+
return await moveEntryToBinUseCase.execute(model, id, options);
|
|
857
|
+
}
|
|
858
|
+
return await deleteEntryUseCase.execute(model, id, options);
|
|
859
|
+
};
|
|
860
|
+
const publishEntry = async (model, id) => {
|
|
861
|
+
await accessControl.ensureCanAccessEntry({
|
|
862
|
+
model,
|
|
863
|
+
pw: "p"
|
|
864
|
+
});
|
|
865
|
+
const originalStorageEntry = await getRevisionByIdUseCase.execute(model, {
|
|
866
|
+
id
|
|
867
|
+
});
|
|
868
|
+
if (!originalStorageEntry) {
|
|
869
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
|
|
870
|
+
}
|
|
871
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
872
|
+
await accessControl.ensureCanAccessEntry({
|
|
873
|
+
model,
|
|
874
|
+
entry: originalEntry,
|
|
875
|
+
pw: "p"
|
|
876
|
+
});
|
|
814
877
|
|
|
815
|
-
|
|
816
|
-
|
|
817
|
-
|
|
818
|
-
|
|
819
|
-
|
|
878
|
+
// We need the latest entry to get the latest entry-level meta fields.
|
|
879
|
+
const latestStorageEntry = await getLatestRevisionByEntryIdUseCase.execute(model, {
|
|
880
|
+
id: originalEntry.entryId
|
|
881
|
+
});
|
|
882
|
+
if (!latestStorageEntry) {
|
|
883
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" in the model "${model.modelId}" was not found.`);
|
|
884
|
+
}
|
|
885
|
+
const latestEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, latestStorageEntry);
|
|
886
|
+
const {
|
|
887
|
+
entry
|
|
888
|
+
} = await (0, _entryDataFactories.createPublishEntryData)({
|
|
889
|
+
context,
|
|
890
|
+
model,
|
|
891
|
+
originalEntry,
|
|
892
|
+
latestEntry,
|
|
893
|
+
getIdentity: getSecurityIdentity
|
|
894
|
+
});
|
|
895
|
+
let storageEntry = null;
|
|
896
|
+
try {
|
|
897
|
+
await onEntryBeforePublish.publish({
|
|
898
|
+
original: originalEntry,
|
|
899
|
+
entry,
|
|
900
|
+
model
|
|
820
901
|
});
|
|
821
|
-
|
|
822
|
-
|
|
823
|
-
|
|
824
|
-
|
|
825
|
-
|
|
826
|
-
|
|
827
|
-
|
|
828
|
-
|
|
829
|
-
|
|
902
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
903
|
+
const result = await storageOperations.entries.publish(model, {
|
|
904
|
+
entry,
|
|
905
|
+
storageEntry
|
|
906
|
+
});
|
|
907
|
+
await onEntryAfterPublish.publish({
|
|
908
|
+
original: originalEntry,
|
|
909
|
+
entry,
|
|
910
|
+
storageEntry: result,
|
|
911
|
+
model
|
|
912
|
+
});
|
|
913
|
+
return entry;
|
|
914
|
+
} catch (ex) {
|
|
915
|
+
await onEntryPublishError.publish({
|
|
916
|
+
original: originalEntry,
|
|
917
|
+
entry,
|
|
830
918
|
model,
|
|
831
|
-
|
|
832
|
-
|
|
919
|
+
error: ex
|
|
920
|
+
});
|
|
921
|
+
throw new _error.default(ex.message || "Could not publish entry.", ex.code || "PUBLISH_ERROR", {
|
|
922
|
+
error: ex,
|
|
923
|
+
entry,
|
|
924
|
+
storageEntry,
|
|
925
|
+
originalEntry,
|
|
926
|
+
originalStorageEntry
|
|
927
|
+
});
|
|
928
|
+
}
|
|
929
|
+
};
|
|
930
|
+
const unpublishEntry = async (model, id) => {
|
|
931
|
+
await accessControl.ensureCanAccessEntry({
|
|
932
|
+
model,
|
|
933
|
+
pw: "u"
|
|
934
|
+
});
|
|
935
|
+
const {
|
|
936
|
+
id: entryId
|
|
937
|
+
} = (0, _utils.parseIdentifier)(id);
|
|
938
|
+
const originalStorageEntry = await getPublishedRevisionByEntryIdUseCase.execute(model, {
|
|
939
|
+
id: entryId
|
|
940
|
+
});
|
|
941
|
+
if (!originalStorageEntry) {
|
|
942
|
+
throw new _handlerGraphql.NotFoundError(`Entry "${id}" of model "${model.modelId}" was not found.`);
|
|
943
|
+
}
|
|
944
|
+
if (originalStorageEntry.id !== id) {
|
|
945
|
+
throw new _error.default(`Entry is not published.`, "UNPUBLISH_ERROR", {
|
|
946
|
+
entry: originalStorageEntry
|
|
947
|
+
});
|
|
948
|
+
}
|
|
949
|
+
const originalEntry = await (0, _entryStorage.entryFromStorageTransform)(context, model, originalStorageEntry);
|
|
950
|
+
await accessControl.ensureCanAccessEntry({
|
|
951
|
+
model,
|
|
952
|
+
entry: originalEntry,
|
|
953
|
+
pw: "u"
|
|
954
|
+
});
|
|
955
|
+
const {
|
|
956
|
+
entry
|
|
957
|
+
} = await (0, _entryDataFactories.createUnpublishEntryData)({
|
|
958
|
+
context,
|
|
959
|
+
model,
|
|
960
|
+
originalEntry,
|
|
961
|
+
getIdentity: getSecurityIdentity
|
|
962
|
+
});
|
|
963
|
+
let storageEntry = null;
|
|
964
|
+
try {
|
|
965
|
+
await onEntryBeforeUnpublish.publish({
|
|
966
|
+
entry,
|
|
967
|
+
model
|
|
968
|
+
});
|
|
969
|
+
storageEntry = await (0, _entryStorage.entryToStorageTransform)(context, model, entry);
|
|
970
|
+
const result = await storageOperations.entries.unpublish(model, {
|
|
971
|
+
entry,
|
|
972
|
+
storageEntry
|
|
833
973
|
});
|
|
834
|
-
|
|
835
|
-
|
|
836
|
-
|
|
837
|
-
|
|
974
|
+
await onEntryAfterUnpublish.publish({
|
|
975
|
+
entry,
|
|
976
|
+
storageEntry: result,
|
|
977
|
+
model
|
|
978
|
+
});
|
|
979
|
+
return entry;
|
|
980
|
+
} catch (ex) {
|
|
981
|
+
await onEntryUnpublishError.publish({
|
|
982
|
+
entry,
|
|
838
983
|
model,
|
|
839
|
-
|
|
840
|
-
validateEntries: false
|
|
984
|
+
error: ex
|
|
841
985
|
});
|
|
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
|
-
},
|
|
986
|
+
throw new _error.default(ex.message || "Could not unpublish entry.", ex.code || "UNPUBLISH_ERROR", {
|
|
987
|
+
originalEntry,
|
|
988
|
+
originalStorageEntry,
|
|
989
|
+
entry,
|
|
990
|
+
storageEntry
|
|
991
|
+
});
|
|
992
|
+
}
|
|
993
|
+
};
|
|
994
|
+
const getUniqueFieldValues = async (model, params) => {
|
|
995
|
+
await accessControl.ensureCanAccessEntry({
|
|
996
|
+
model
|
|
997
|
+
});
|
|
998
|
+
const {
|
|
999
|
+
where: initialWhere,
|
|
1000
|
+
fieldId
|
|
1001
|
+
} = params;
|
|
1002
|
+
const where = {
|
|
1003
|
+
...initialWhere
|
|
1004
|
+
};
|
|
892
1005
|
/**
|
|
893
|
-
*
|
|
894
|
-
*
|
|
1006
|
+
* Possibly only get records which are owned by current user.
|
|
1007
|
+
* Or if searching for the owner set that value - in the case that user can see other entries than their own.
|
|
1008
|
+
*/
|
|
1009
|
+
if (await accessControl.canAccessOnlyOwnedEntries({
|
|
1010
|
+
model
|
|
1011
|
+
})) {
|
|
1012
|
+
where.createdBy = getSecurityIdentity().id;
|
|
1013
|
+
}
|
|
1014
|
+
|
|
1015
|
+
/**
|
|
1016
|
+
* Where must contain either latest or published keys.
|
|
1017
|
+
* We cannot list entries without one of those
|
|
895
1018
|
*/
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
1019
|
+
if (where.latest && where.published) {
|
|
1020
|
+
throw new _error.default("Cannot list entries that are both published and latest.", "LIST_ENTRIES_ERROR", {
|
|
1021
|
+
where
|
|
899
1022
|
});
|
|
900
|
-
|
|
901
|
-
|
|
902
|
-
|
|
903
|
-
plugins
|
|
1023
|
+
} else if (!where.latest && !where.published) {
|
|
1024
|
+
throw new _error.default("Cannot list entries if we do not have latest or published defined.", "LIST_ENTRIES_ERROR", {
|
|
1025
|
+
where
|
|
904
1026
|
});
|
|
905
|
-
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
909
|
-
|
|
1027
|
+
}
|
|
1028
|
+
/**
|
|
1029
|
+
* We need to verify that the field in question is searchable.
|
|
1030
|
+
*/
|
|
1031
|
+
const fields = (0, _searchableFields.getSearchableFields)({
|
|
1032
|
+
fields: model.fields,
|
|
1033
|
+
plugins: context.plugins,
|
|
1034
|
+
input: []
|
|
1035
|
+
});
|
|
1036
|
+
if (!fields.includes(fieldId)) {
|
|
1037
|
+
throw new _error.default("Cannot list unique entry field values if the field is not searchable.", "LIST_UNIQUE_ENTRY_VALUES_ERROR", {
|
|
1038
|
+
fieldId
|
|
910
1039
|
});
|
|
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
|
|
1040
|
+
}
|
|
1041
|
+
try {
|
|
1042
|
+
return await storageOperations.entries.getUniqueFieldValues(model, {
|
|
1043
|
+
where,
|
|
1044
|
+
fieldId
|
|
929
1045
|
});
|
|
930
|
-
|
|
931
|
-
|
|
932
|
-
|
|
933
|
-
|
|
1046
|
+
} catch (ex) {
|
|
1047
|
+
throw new _error.default("Error while fetching unique entry values from storage.", "LIST_UNIQUE_ENTRY_VALUES_ERROR", {
|
|
1048
|
+
error: {
|
|
1049
|
+
message: ex.message,
|
|
1050
|
+
code: ex.code,
|
|
1051
|
+
data: ex.data
|
|
1052
|
+
},
|
|
1053
|
+
model,
|
|
1054
|
+
where,
|
|
1055
|
+
fieldId
|
|
934
1056
|
});
|
|
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
|
-
|
|
1057
|
+
}
|
|
1058
|
+
};
|
|
1059
|
+
const getEntryTraverser = async modelId => {
|
|
1060
|
+
const modelAstConverter = context.cms.getModelToAstConverter();
|
|
1061
|
+
const model = await context.cms.getModel(modelId);
|
|
1062
|
+
if (!model) {
|
|
1063
|
+
throw new Error(`Missing "${modelId}" model!`);
|
|
1064
|
+
}
|
|
1065
|
+
const modelAst = modelAstConverter.toAst(model);
|
|
1066
|
+
return new _ContentEntryTraverser.ContentEntryTraverser(modelAst);
|
|
1067
|
+
};
|
|
1068
|
+
return {
|
|
1069
|
+
getEntryTraverser,
|
|
1070
|
+
onEntryBeforeCreate,
|
|
1071
|
+
onEntryAfterCreate,
|
|
1072
|
+
onEntryCreateError,
|
|
1073
|
+
onEntryRevisionBeforeCreate: onEntryBeforeCreateRevision,
|
|
1074
|
+
onEntryRevisionAfterCreate,
|
|
1075
|
+
onEntryRevisionCreateError: onEntryCreateRevisionError,
|
|
1076
|
+
onEntryBeforeUpdate,
|
|
1077
|
+
onEntryAfterUpdate,
|
|
1078
|
+
onEntryUpdateError,
|
|
1079
|
+
onEntryBeforeMove,
|
|
1080
|
+
onEntryAfterMove,
|
|
1081
|
+
onEntryMoveError,
|
|
1082
|
+
onEntryBeforeDelete,
|
|
1083
|
+
onEntryAfterDelete,
|
|
1084
|
+
onEntryDeleteError,
|
|
1085
|
+
onEntryBeforeRestoreFromBin,
|
|
1086
|
+
onEntryAfterRestoreFromBin,
|
|
1087
|
+
onEntryRestoreFromBinError,
|
|
1088
|
+
onEntryRevisionBeforeDelete,
|
|
1089
|
+
onEntryRevisionAfterDelete,
|
|
1090
|
+
onEntryRevisionDeleteError,
|
|
1091
|
+
onEntryBeforePublish,
|
|
1092
|
+
onEntryAfterPublish,
|
|
1093
|
+
onEntryPublishError,
|
|
1094
|
+
onEntryBeforeRepublish,
|
|
1095
|
+
onEntryAfterRepublish,
|
|
1096
|
+
onEntryRepublishError,
|
|
1097
|
+
onEntryBeforeUnpublish,
|
|
1098
|
+
onEntryAfterUnpublish,
|
|
1099
|
+
onEntryUnpublishError,
|
|
1100
|
+
onEntryBeforeGet,
|
|
1101
|
+
onEntryBeforeList,
|
|
1102
|
+
/**
|
|
1103
|
+
* Get entries by exact revision IDs from the database.
|
|
1104
|
+
*/
|
|
1105
|
+
async getEntriesByIds(model, ids) {
|
|
1106
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntriesByIds", async () => {
|
|
1107
|
+
return getEntriesByIdsUseCase.execute(model, {
|
|
1108
|
+
ids
|
|
960
1109
|
});
|
|
961
|
-
|
|
962
|
-
|
|
963
|
-
|
|
964
|
-
|
|
1110
|
+
});
|
|
1111
|
+
},
|
|
1112
|
+
/**
|
|
1113
|
+
* Get a single entry by revision ID from the database.
|
|
1114
|
+
*/
|
|
1115
|
+
async getEntryById(model, id) {
|
|
1116
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntryById", async () => {
|
|
1117
|
+
return getEntryById(model, id);
|
|
1118
|
+
});
|
|
1119
|
+
},
|
|
1120
|
+
/**
|
|
1121
|
+
* Get published revisions by entry IDs.
|
|
1122
|
+
*/
|
|
1123
|
+
async getPublishedEntriesByIds(model, ids) {
|
|
1124
|
+
return context.benchmark.measure("headlessCms.crud.entries.getPublishedEntriesByIds", async () => {
|
|
1125
|
+
return getPublishedEntriesByIdsUseCase.execute(model, {
|
|
1126
|
+
ids
|
|
965
1127
|
});
|
|
966
|
-
|
|
967
|
-
|
|
968
|
-
|
|
969
|
-
|
|
970
|
-
|
|
971
|
-
|
|
1128
|
+
});
|
|
1129
|
+
},
|
|
1130
|
+
/**
|
|
1131
|
+
* Get the latest revisions by entry IDs.
|
|
1132
|
+
*/
|
|
1133
|
+
async getLatestEntriesByIds(model, ids) {
|
|
1134
|
+
return context.benchmark.measure("headlessCms.crud.entries.getLatestEntriesByIds", async () => {
|
|
1135
|
+
return await getLatestEntriesByIdsUseCase.execute(model, {
|
|
1136
|
+
ids
|
|
972
1137
|
});
|
|
973
|
-
|
|
974
|
-
|
|
1138
|
+
});
|
|
1139
|
+
},
|
|
1140
|
+
async getEntryRevisions(model, entryId) {
|
|
1141
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntryRevisions", async () => {
|
|
1142
|
+
return getRevisionsByEntryIdUseCase.execute(model, {
|
|
1143
|
+
id: entryId
|
|
975
1144
|
});
|
|
976
|
-
}
|
|
1145
|
+
});
|
|
977
1146
|
},
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
1147
|
+
/**
|
|
1148
|
+
* @internal
|
|
1149
|
+
*/
|
|
1150
|
+
async getEntry(model, params) {
|
|
1151
|
+
return context.benchmark.measure("headlessCms.crud.entries.getEntry", async () => {
|
|
1152
|
+
return await getEntryUseCase.execute(model, params);
|
|
981
1153
|
});
|
|
982
|
-
|
|
983
|
-
|
|
984
|
-
|
|
985
|
-
|
|
1154
|
+
},
|
|
1155
|
+
/**
|
|
1156
|
+
* @description Should not be used directly. Internal use only!
|
|
1157
|
+
*
|
|
1158
|
+
* @internal
|
|
1159
|
+
*/
|
|
1160
|
+
async listEntries(model, params) {
|
|
1161
|
+
return context.benchmark.measure("headlessCms.crud.entries.listEntries", async () => {
|
|
1162
|
+
return await listEntriesUseCase.execute(model, params);
|
|
986
1163
|
});
|
|
987
|
-
|
|
988
|
-
|
|
989
|
-
|
|
990
|
-
|
|
991
|
-
const storageEntryToDelete = await storageOperations.entries.getRevisionById(model, {
|
|
992
|
-
id: revisionId
|
|
1164
|
+
},
|
|
1165
|
+
async listLatestEntries(model, params) {
|
|
1166
|
+
return context.benchmark.measure("headlessCms.crud.entries.listLatestEntries", async () => {
|
|
1167
|
+
return await listLatestUseCase.execute(model, params);
|
|
993
1168
|
});
|
|
994
|
-
|
|
995
|
-
|
|
1169
|
+
},
|
|
1170
|
+
async listDeletedEntries(model, params) {
|
|
1171
|
+
return context.benchmark.measure("headlessCms.crud.entries.listDeletedEntries", async () => {
|
|
1172
|
+
return await listDeletedUseCase.execute(model, params);
|
|
996
1173
|
});
|
|
997
|
-
|
|
998
|
-
|
|
999
|
-
|
|
1174
|
+
},
|
|
1175
|
+
async listPublishedEntries(model, params) {
|
|
1176
|
+
return context.benchmark.measure("headlessCms.crud.entries.listPublishedEntries", async () => {
|
|
1177
|
+
return await listPublishedUseCase.execute(model, params);
|
|
1000
1178
|
});
|
|
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
1179
|
},
|
|
1056
|
-
async
|
|
1057
|
-
|
|
1058
|
-
|
|
1180
|
+
async createEntry(model, input, options) {
|
|
1181
|
+
return context.benchmark.measure("headlessCms.crud.entries.createEntry", async () => {
|
|
1182
|
+
return createEntry(model, input, options);
|
|
1059
1183
|
});
|
|
1060
|
-
|
|
1061
|
-
|
|
1062
|
-
|
|
1063
|
-
|
|
1184
|
+
},
|
|
1185
|
+
async createEntryRevisionFrom(model, sourceId, input, options) {
|
|
1186
|
+
return context.benchmark.measure("headlessCms.crud.entries.createEntryRevisionFrom", async () => {
|
|
1187
|
+
return createEntryRevisionFrom(model, sourceId, input, options);
|
|
1064
1188
|
});
|
|
1065
|
-
|
|
1066
|
-
|
|
1189
|
+
},
|
|
1190
|
+
async updateEntry(model, id, input, meta, options) {
|
|
1191
|
+
return context.benchmark.measure("headlessCms.crud.entries.updateEntry", async () => {
|
|
1192
|
+
return updateEntry(model, id, input, meta, options);
|
|
1067
1193
|
});
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
const entry = await (0, _entryStorage.entryFromStorageTransform)(context, model, storageEntry);
|
|
1073
|
-
return await deleteEntry({
|
|
1074
|
-
model,
|
|
1075
|
-
entry
|
|
1194
|
+
},
|
|
1195
|
+
async validateEntry(model, id, input) {
|
|
1196
|
+
return context.benchmark.measure("headlessCms.crud.entries.validateEntry", async () => {
|
|
1197
|
+
return validateEntry(model, id, input);
|
|
1076
1198
|
});
|
|
1077
1199
|
},
|
|
1078
|
-
async
|
|
1079
|
-
|
|
1080
|
-
|
|
1200
|
+
async moveEntry(model, id, folderId) {
|
|
1201
|
+
return context.benchmark.measure("headlessCms.crud.entries.moveEntry", async () => {
|
|
1202
|
+
return moveEntry(model, id, folderId);
|
|
1081
1203
|
});
|
|
1082
|
-
|
|
1083
|
-
|
|
1084
|
-
|
|
1085
|
-
|
|
1204
|
+
},
|
|
1205
|
+
/**
|
|
1206
|
+
* Method used internally. Not documented and should not be used in users systems.
|
|
1207
|
+
* @internal
|
|
1208
|
+
*/
|
|
1209
|
+
async republishEntry(model, id) {
|
|
1210
|
+
return context.benchmark.measure("headlessCms.crud.entries.republishEntry", async () => {
|
|
1211
|
+
return republishEntry(model, id);
|
|
1086
1212
|
});
|
|
1087
|
-
|
|
1088
|
-
|
|
1213
|
+
},
|
|
1214
|
+
async deleteEntryRevision(model, id) {
|
|
1215
|
+
return context.benchmark.measure("headlessCms.crud.entries.deleteEntryRevision", async () => {
|
|
1216
|
+
return deleteEntryRevision(model, id);
|
|
1089
1217
|
});
|
|
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
1218
|
},
|
|
1134
|
-
async
|
|
1135
|
-
|
|
1136
|
-
|
|
1219
|
+
async deleteEntry(model, entryId, options) {
|
|
1220
|
+
return context.benchmark.measure("headlessCms.crud.entries.deleteEntry", async () => {
|
|
1221
|
+
return deleteEntry(model, entryId, options);
|
|
1137
1222
|
});
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1223
|
+
},
|
|
1224
|
+
async restoreEntryFromBin(model, entryId) {
|
|
1225
|
+
return context.benchmark.measure("headlessCms.crud.entries.restoreEntryFromBin", async () => {
|
|
1226
|
+
return await restoreEntryFromBinUseCase.execute(model, entryId);
|
|
1141
1227
|
});
|
|
1142
|
-
|
|
1143
|
-
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1228
|
+
},
|
|
1229
|
+
async deleteMultipleEntries(model, ids) {
|
|
1230
|
+
return context.benchmark.measure("headlessCms.crud.entries.deleteMultipleEntries", async () => {
|
|
1231
|
+
return deleteMultipleEntries(model, ids);
|
|
1232
|
+
});
|
|
1233
|
+
},
|
|
1234
|
+
async publishEntry(model, id) {
|
|
1235
|
+
return context.benchmark.measure("headlessCms.crud.entries.publishEntry", async () => {
|
|
1236
|
+
return publishEntry(model, id);
|
|
1237
|
+
});
|
|
1238
|
+
},
|
|
1239
|
+
async unpublishEntry(model, id) {
|
|
1240
|
+
return context.benchmark.measure("headlessCms.crud.entries.unpublishEntry", async () => {
|
|
1241
|
+
return unpublishEntry(model, id);
|
|
1242
|
+
});
|
|
1243
|
+
},
|
|
1244
|
+
async getUniqueFieldValues(model, params) {
|
|
1245
|
+
return context.benchmark.measure("headlessCms.crud.entries.getUniqueFieldValues", async () => {
|
|
1246
|
+
return getUniqueFieldValues(model, params);
|
|
1147
1247
|
});
|
|
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
1248
|
}
|
|
1192
1249
|
};
|
|
1193
1250
|
};
|
|
1194
|
-
exports.createContentEntryCrud = createContentEntryCrud;
|
|
1251
|
+
exports.createContentEntryCrud = createContentEntryCrud;
|
|
1252
|
+
|
|
1253
|
+
//# sourceMappingURL=contentEntry.crud.js.map
|