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