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