@strapi/core 0.0.0-experimental.22e8a4f31c0b65da00cc6c524a94de53fabc7a28 → 0.0.0-experimental.235f232c2d3f5110341c4933bf23785a81913797
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.
Potentially problematic release.
This version of @strapi/core might be problematic. Click here for more details.
- package/dist/Strapi.d.ts +5 -3
- package/dist/Strapi.d.ts.map +1 -1
- package/dist/Strapi.js +19 -7
- package/dist/Strapi.js.map +1 -1
- package/dist/Strapi.mjs +19 -7
- package/dist/Strapi.mjs.map +1 -1
- package/dist/configuration/index.d.ts.map +1 -1
- package/dist/configuration/index.js +4 -4
- package/dist/configuration/index.js.map +1 -1
- package/dist/configuration/index.mjs +1 -1
- package/dist/configuration/index.mjs.map +1 -1
- package/dist/configuration/urls.d.ts +8 -0
- package/dist/configuration/urls.d.ts.map +1 -0
- package/dist/configuration/urls.js +68 -0
- package/dist/configuration/urls.js.map +1 -0
- package/dist/configuration/urls.mjs +66 -0
- package/dist/configuration/urls.mjs.map +1 -0
- package/dist/core-api/controller/collection-type.js.map +1 -1
- package/dist/core-api/controller/collection-type.mjs.map +1 -1
- package/dist/core-api/controller/index.d.ts.map +1 -1
- package/dist/core-api/controller/index.js +6 -1
- package/dist/core-api/controller/index.js.map +1 -1
- package/dist/core-api/controller/index.mjs +6 -1
- package/dist/core-api/controller/index.mjs.map +1 -1
- package/dist/core-api/controller/single-type.js.map +1 -1
- package/dist/core-api/controller/single-type.mjs.map +1 -1
- package/dist/core-api/controller/transform.d.ts +8 -7
- package/dist/core-api/controller/transform.d.ts.map +1 -1
- package/dist/core-api/controller/transform.js +18 -9
- package/dist/core-api/controller/transform.js.map +1 -1
- package/dist/core-api/controller/transform.mjs +18 -9
- package/dist/core-api/controller/transform.mjs.map +1 -1
- package/dist/core-api/service/collection-type.d.ts.map +1 -1
- package/dist/core-api/service/collection-type.js.map +1 -1
- package/dist/core-api/service/collection-type.mjs.map +1 -1
- package/dist/core-api/service/single-type.d.ts +3 -2
- package/dist/core-api/service/single-type.d.ts.map +1 -1
- package/dist/core-api/service/single-type.js +14 -3
- package/dist/core-api/service/single-type.js.map +1 -1
- package/dist/core-api/service/single-type.mjs +14 -3
- package/dist/core-api/service/single-type.mjs.map +1 -1
- package/dist/domain/content-type/index.d.ts.map +1 -1
- package/dist/domain/content-type/index.js +3 -0
- package/dist/domain/content-type/index.js.map +1 -1
- package/dist/domain/content-type/index.mjs +3 -0
- package/dist/domain/content-type/index.mjs.map +1 -1
- package/dist/domain/content-type/validator.d.ts.map +1 -1
- package/dist/domain/content-type/validator.js +1 -1
- package/dist/domain/content-type/validator.js.map +1 -1
- package/dist/domain/content-type/validator.mjs +2 -2
- package/dist/domain/content-type/validator.mjs.map +1 -1
- package/dist/domain/module/index.d.ts.map +1 -1
- package/dist/domain/module/index.js +2 -3
- package/dist/domain/module/index.js.map +1 -1
- package/dist/domain/module/index.mjs +2 -3
- package/dist/domain/module/index.mjs.map +1 -1
- package/dist/ee/index.js.map +1 -1
- package/dist/ee/index.mjs.map +1 -1
- package/dist/loaders/apis.js +1 -1
- package/dist/loaders/apis.js.map +1 -1
- package/dist/loaders/apis.mjs +2 -2
- package/dist/loaders/apis.mjs.map +1 -1
- package/dist/loaders/plugins/get-enabled-plugins.js +1 -1
- package/dist/loaders/plugins/get-enabled-plugins.js.map +1 -1
- package/dist/loaders/plugins/get-enabled-plugins.mjs +2 -2
- package/dist/loaders/plugins/get-enabled-plugins.mjs.map +1 -1
- package/dist/middlewares/security.d.ts.map +1 -1
- package/dist/middlewares/security.js +2 -2
- package/dist/middlewares/security.js.map +1 -1
- package/dist/middlewares/security.mjs +2 -2
- package/dist/middlewares/security.mjs.map +1 -1
- package/dist/migrations/draft-publish.d.ts +17 -0
- package/dist/migrations/draft-publish.d.ts.map +1 -0
- package/dist/migrations/draft-publish.js +59 -0
- package/dist/migrations/draft-publish.js.map +1 -0
- package/dist/migrations/draft-publish.mjs +59 -0
- package/dist/migrations/draft-publish.mjs.map +1 -0
- package/dist/registries/config.d.ts +2 -2
- package/dist/registries/config.d.ts.map +1 -1
- package/dist/registries/config.js +14 -6
- package/dist/registries/config.js.map +1 -1
- package/dist/registries/config.mjs +15 -5
- package/dist/registries/config.mjs.map +1 -1
- package/dist/services/document-service/common.d.ts +2 -2
- package/dist/services/document-service/common.d.ts.map +1 -1
- package/dist/services/document-service/common.js.map +1 -1
- package/dist/services/document-service/common.mjs.map +1 -1
- package/dist/services/document-service/draft-and-publish.d.ts +9 -23
- package/dist/services/document-service/draft-and-publish.d.ts.map +1 -1
- package/dist/services/document-service/draft-and-publish.js +37 -9
- package/dist/services/document-service/draft-and-publish.js.map +1 -1
- package/dist/services/document-service/draft-and-publish.mjs +38 -10
- package/dist/services/document-service/draft-and-publish.mjs.map +1 -1
- package/dist/services/document-service/index.d.ts.map +1 -1
- package/dist/services/document-service/index.js +4 -4
- package/dist/services/document-service/index.js.map +1 -1
- package/dist/services/document-service/index.mjs +2 -2
- package/dist/services/document-service/index.mjs.map +1 -1
- package/dist/services/document-service/repository.d.ts +3 -0
- package/dist/services/document-service/repository.d.ts.map +1 -0
- package/dist/services/document-service/repository.js +295 -0
- package/dist/services/document-service/repository.js.map +1 -0
- package/dist/services/document-service/repository.mjs +295 -0
- package/dist/services/document-service/repository.mjs.map +1 -0
- package/dist/services/document-service/transform/fields.d.ts.map +1 -1
- package/dist/services/document-service/transform/fields.js +11 -10
- package/dist/services/document-service/transform/fields.js.map +1 -1
- package/dist/services/document-service/transform/fields.mjs +11 -10
- package/dist/services/document-service/transform/fields.mjs.map +1 -1
- package/dist/services/document-service/transform/id-map.d.ts +1 -1
- package/dist/services/document-service/transform/id-map.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-map.js +15 -9
- package/dist/services/document-service/transform/id-map.js.map +1 -1
- package/dist/services/document-service/transform/id-map.mjs +16 -10
- package/dist/services/document-service/transform/id-map.mjs.map +1 -1
- package/dist/services/document-service/transform/id-transform.d.ts +4 -25
- package/dist/services/document-service/transform/id-transform.d.ts.map +1 -1
- package/dist/services/document-service/transform/id-transform.js +19 -43
- package/dist/services/document-service/transform/id-transform.js.map +1 -1
- package/dist/services/document-service/transform/id-transform.mjs +20 -44
- package/dist/services/document-service/transform/id-transform.mjs.map +1 -1
- package/dist/services/document-service/transform/populate.d.ts +5 -2
- package/dist/services/document-service/transform/populate.d.ts.map +1 -1
- package/dist/services/document-service/transform/populate.js +0 -10
- package/dist/services/document-service/transform/populate.js.map +1 -1
- package/dist/services/document-service/transform/populate.mjs +0 -10
- package/dist/services/document-service/transform/populate.mjs.map +1 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts +1 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.js +28 -14
- package/dist/services/document-service/transform/relations/extract/data-ids.js.map +1 -1
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs +28 -14
- package/dist/services/document-service/transform/relations/extract/data-ids.mjs.map +1 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts +1 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.js +65 -39
- package/dist/services/document-service/transform/relations/transform/data-ids.js.map +1 -1
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs +66 -40
- package/dist/services/document-service/transform/relations/transform/data-ids.mjs.map +1 -1
- package/dist/services/document-service/transform/relations/utils/data.d.ts +2 -4
- package/dist/services/document-service/transform/relations/utils/data.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/data.js +1 -1
- package/dist/services/document-service/transform/relations/utils/data.js.map +1 -1
- package/dist/services/document-service/transform/relations/utils/data.mjs +1 -1
- package/dist/services/document-service/transform/relations/utils/data.mjs.map +1 -1
- package/dist/services/document-service/transform/relations/utils/dp.d.ts +10 -0
- package/dist/services/document-service/transform/relations/utils/dp.d.ts.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.js +25 -0
- package/dist/services/document-service/transform/relations/utils/dp.js.map +1 -0
- package/dist/services/document-service/transform/relations/utils/dp.mjs +25 -0
- package/dist/services/document-service/transform/relations/utils/dp.mjs.map +1 -0
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts +2 -2
- package/dist/services/document-service/transform/relations/utils/i18n.d.ts.map +1 -1
- package/dist/services/document-service/transform/relations/utils/i18n.js.map +1 -1
- package/dist/services/document-service/transform/relations/utils/i18n.mjs.map +1 -1
- package/dist/services/document-service/transform/relations/utils/types.d.ts +9 -2
- package/dist/services/document-service/transform/relations/utils/types.d.ts.map +1 -1
- package/dist/services/document-service/transform/types.d.ts +1 -1
- package/dist/services/document-service/transform/types.d.ts.map +1 -1
- package/dist/services/document-service/utils/populate.d.ts +8 -1
- package/dist/services/document-service/utils/populate.d.ts.map +1 -1
- package/dist/services/document-service/utils/populate.js +5 -5
- package/dist/services/document-service/utils/populate.js.map +1 -1
- package/dist/services/document-service/utils/populate.mjs +5 -5
- package/dist/services/document-service/utils/populate.mjs.map +1 -1
- package/dist/services/entity-service/components.d.ts +1 -4
- package/dist/services/entity-service/components.d.ts.map +1 -1
- package/dist/services/entity-service/components.js +13 -99
- package/dist/services/entity-service/components.js.map +1 -1
- package/dist/services/entity-service/components.mjs +14 -100
- package/dist/services/entity-service/components.mjs.map +1 -1
- package/dist/services/entity-service/index.d.ts +1 -3
- package/dist/services/entity-service/index.d.ts.map +1 -1
- package/dist/services/entity-service/index.js +34 -199
- package/dist/services/entity-service/index.js.map +1 -1
- package/dist/services/entity-service/index.mjs +27 -192
- package/dist/services/entity-service/index.mjs.map +1 -1
- package/dist/services/entity-service/params.d.ts +4 -4
- package/dist/services/entity-service/params.d.ts.map +1 -1
- package/dist/services/entity-service/params.js +1 -1
- package/dist/services/entity-service/params.js.map +1 -1
- package/dist/services/entity-service/params.mjs +1 -1
- package/dist/services/entity-service/params.mjs.map +1 -1
- package/dist/services/entity-validator/index.js +1 -1
- package/dist/services/entity-validator/index.js.map +1 -1
- package/dist/services/entity-validator/index.mjs +1 -1
- package/dist/services/entity-validator/index.mjs.map +1 -1
- package/dist/utils/is-initialized.js +1 -1
- package/dist/utils/is-initialized.js.map +1 -1
- package/dist/utils/is-initialized.mjs +1 -1
- package/dist/utils/is-initialized.mjs.map +1 -1
- package/dist/utils/load-config-file.js +1 -1
- package/dist/utils/load-config-file.js.map +1 -1
- package/dist/utils/load-config-file.mjs +2 -2
- package/dist/utils/load-config-file.mjs.map +1 -1
- package/dist/utils/transform-content-types-to-models.d.ts +174 -3
- package/dist/utils/transform-content-types-to-models.d.ts.map +1 -1
- package/dist/utils/transform-content-types-to-models.js +80 -41
- package/dist/utils/transform-content-types-to-models.js.map +1 -1
- package/dist/utils/transform-content-types-to-models.mjs +79 -41
- package/dist/utils/transform-content-types-to-models.mjs.map +1 -1
- package/package.json +15 -15
- package/dist/services/document-service/collection-type.d.ts +0 -4
- package/dist/services/document-service/collection-type.d.ts.map +0 -1
- package/dist/services/document-service/collection-type.js +0 -158
- package/dist/services/document-service/collection-type.js.map +0 -1
- package/dist/services/document-service/collection-type.mjs +0 -158
- package/dist/services/document-service/collection-type.mjs.map +0 -1
- package/dist/services/document-service/document-engine.d.ts +0 -8
- package/dist/services/document-service/document-engine.d.ts.map +0 -1
- package/dist/services/document-service/document-engine.js +0 -249
- package/dist/services/document-service/document-engine.js.map +0 -1
- package/dist/services/document-service/document-engine.mjs +0 -250
- package/dist/services/document-service/document-engine.mjs.map +0 -1
- package/dist/services/document-service/repository-factory.d.ts +0 -3
- package/dist/services/document-service/repository-factory.d.ts.map +0 -1
- package/dist/services/document-service/repository-factory.js +0 -12
- package/dist/services/document-service/repository-factory.js.map +0 -1
- package/dist/services/document-service/repository-factory.mjs +0 -12
- package/dist/services/document-service/repository-factory.mjs.map +0 -1
- package/dist/services/document-service/single-type.d.ts +0 -4
- package/dist/services/document-service/single-type.d.ts.map +0 -1
- package/dist/services/document-service/single-type.js +0 -105
- package/dist/services/document-service/single-type.js.map +0 -1
- package/dist/services/document-service/single-type.mjs +0 -105
- package/dist/services/document-service/single-type.mjs.map +0 -1
- package/dist/services/document-service/transform/filters.js +0 -49
- package/dist/services/document-service/transform/filters.js.map +0 -1
- package/dist/services/document-service/transform/filters.mjs +0 -49
- package/dist/services/document-service/transform/filters.mjs.map +0 -1
- package/dist/services/document-service/transform/relations/transform/output-ids.js +0 -26
- package/dist/services/document-service/transform/relations/transform/output-ids.js.map +0 -1
- package/dist/services/document-service/transform/relations/transform/output-ids.mjs +0 -26
- package/dist/services/document-service/transform/relations/transform/output-ids.mjs.map +0 -1
- package/dist/services/document-service/transform/sort.js +0 -44
- package/dist/services/document-service/transform/sort.js.map +0 -1
- package/dist/services/document-service/transform/sort.mjs +0 -44
- package/dist/services/document-service/transform/sort.mjs.map +0 -1
- package/dist/services/document-service/transform/utils.js +0 -23
- package/dist/services/document-service/transform/utils.js.map +0 -1
- package/dist/services/document-service/transform/utils.mjs +0 -23
- package/dist/services/document-service/transform/utils.mjs.map +0 -1
- package/dist/services/utils/upload-files.d.ts +0 -8
- package/dist/services/utils/upload-files.d.ts.map +0 -1
- package/dist/services/utils/upload-files.js +0 -64
- package/dist/services/utils/upload-files.js.map +0 -1
- package/dist/services/utils/upload-files.mjs +0 -63
- package/dist/services/utils/upload-files.mjs.map +0 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"common.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/common.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAEvD,MAAM,MAAM,uBAAuB,GAAG,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,CAAC,cAAc,KAAK,SAAS,CAAC,eAAe,CAAC;AAEpG,eAAO,MAAM,iBAAiB,iBAAkB,GAAG,KAAK,GAAG,eACxC,GAAG,EAAE,iBACvB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.js","sources":["../../../src/services/document-service/common.ts"],"sourcesContent":["import type {
|
|
1
|
+
{"version":3,"file":"common.js","sources":["../../../src/services/document-service/common.ts"],"sourcesContent":["import type { Common, Documents } from '@strapi/types';\n\nexport type RepositoryFactoryMethod = (uid: Common.UID.CollectionType) => Documents.ServiceInstance;\n\nexport const wrapInTransaction = (fn: (...args: any) => any) => {\n return (...args: any[]) => strapi.db.transaction?.(() => fn(...args));\n};\n"],"names":[],"mappings":";;AAIa,MAAA,oBAAoB,CAAC,OAA8B;AACvD,SAAA,IAAI,SAAgB,OAAO,GAAG,cAAc,MAAM,GAAG,GAAG,IAAI,CAAC;AACtE;;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"common.mjs","sources":["../../../src/services/document-service/common.ts"],"sourcesContent":["import type {
|
|
1
|
+
{"version":3,"file":"common.mjs","sources":["../../../src/services/document-service/common.ts"],"sourcesContent":["import type { Common, Documents } from '@strapi/types';\n\nexport type RepositoryFactoryMethod = (uid: Common.UID.CollectionType) => Documents.ServiceInstance;\n\nexport const wrapInTransaction = (fn: (...args: any) => any) => {\n return (...args: any[]) => strapi.db.transaction?.(() => fn(...args));\n};\n"],"names":[],"mappings":"AAIa,MAAA,oBAAoB,CAAC,OAA8B;AACvD,SAAA,IAAI,SAAgB,OAAO,GAAG,cAAc,MAAM,GAAG,GAAG,IAAI,CAAC;AACtE;"}
|
|
@@ -1,24 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
export declare const defaultToDraft: ParamsTransform;
|
|
11
|
-
/**
|
|
12
|
-
* In mutating actions we don't want user to set the publishedAt attribute.
|
|
13
|
-
*/
|
|
14
|
-
export declare const filterDataPublishedAt: ParamsTransform;
|
|
15
|
-
/**
|
|
16
|
-
* Add status lookup query to the params
|
|
17
|
-
*/
|
|
18
|
-
export declare const statusToLookup: ParamsTransform;
|
|
19
|
-
/**
|
|
20
|
-
* Translate publication status parameter into the data that will be saved
|
|
21
|
-
*/
|
|
22
|
-
export declare const statusToData: ParamsTransform;
|
|
23
|
-
export {};
|
|
1
|
+
/// <reference types="lodash" />
|
|
2
|
+
import { Schema, Documents } from '@strapi/types';
|
|
3
|
+
declare const setStatusToDraftCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
|
|
4
|
+
declare const defaultToDraftCurry: import("lodash").CurriedFunction1<Documents.Params.All, Documents.Params.All>;
|
|
5
|
+
declare const defaultStatusCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
|
|
6
|
+
declare const filterDataPublishedAtCurry: import("lodash").CurriedFunction1<Documents.Params.All, Documents.Params.All>;
|
|
7
|
+
declare const statusToLookupCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
|
|
8
|
+
declare const statusToDataCurry: import("lodash").CurriedFunction2<Schema.SingleType | Schema.CollectionType, Documents.Params.All, Documents.Params.All>;
|
|
9
|
+
export { setStatusToDraftCurry as setStatusToDraft, defaultToDraftCurry as defaultToDraft, defaultStatusCurry as defaultStatus, filterDataPublishedAtCurry as filterDataPublishedAt, statusToLookupCurry as statusToLookup, statusToDataCurry as statusToData, };
|
|
24
10
|
//# sourceMappingURL=draft-and-publish.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"draft-and-publish.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/draft-and-publish.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"draft-and-publish.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/draft-and-publish.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAwGlD,QAAA,MAAM,qBAAqB,0HAA0B,CAAC;AACtD,QAAA,MAAM,mBAAmB,+EAAwB,CAAC;AAClD,QAAA,MAAM,kBAAkB,0HAAuB,CAAC;AAChD,QAAA,MAAM,0BAA0B,+EAA+B,CAAC;AAChE,QAAA,MAAM,mBAAmB,0HAAwB,CAAC;AAClD,QAAA,MAAM,iBAAiB,0HAAsB,CAAC;AAE9C,OAAO,EACL,qBAAqB,IAAI,gBAAgB,EACzC,mBAAmB,IAAI,cAAc,EACrC,kBAAkB,IAAI,aAAa,EACnC,0BAA0B,IAAI,qBAAqB,EACnD,mBAAmB,IAAI,cAAc,EACrC,iBAAiB,IAAI,YAAY,GAClC,CAAC"}
|
|
@@ -1,10 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
3
|
const _ = require("lodash/fp");
|
|
4
|
-
const
|
|
4
|
+
const strapiUtils = require("@strapi/utils");
|
|
5
|
+
const setStatusToDraft = (contentType, params) => {
|
|
6
|
+
if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType) && params.status) {
|
|
7
|
+
return params;
|
|
8
|
+
}
|
|
9
|
+
return _.assoc("status", "draft", params);
|
|
10
|
+
};
|
|
5
11
|
const defaultToDraft = (params) => {
|
|
6
12
|
if (!params.status || params.status !== "published") {
|
|
7
|
-
return
|
|
13
|
+
return _.assoc("status", "draft", params);
|
|
14
|
+
}
|
|
15
|
+
return params;
|
|
16
|
+
};
|
|
17
|
+
const defaultStatus = (contentType, params) => {
|
|
18
|
+
if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
|
|
19
|
+
return params;
|
|
20
|
+
}
|
|
21
|
+
if (!params.status || params.status !== "published") {
|
|
22
|
+
return defaultToDraft(params);
|
|
8
23
|
}
|
|
9
24
|
return params;
|
|
10
25
|
};
|
|
@@ -14,7 +29,10 @@ const filterDataPublishedAt = (params) => {
|
|
|
14
29
|
}
|
|
15
30
|
return params;
|
|
16
31
|
};
|
|
17
|
-
const statusToLookup = (params) => {
|
|
32
|
+
const statusToLookup = (contentType, params) => {
|
|
33
|
+
if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
|
|
34
|
+
return params;
|
|
35
|
+
}
|
|
18
36
|
const lookup = params.lookup || {};
|
|
19
37
|
switch (params?.status) {
|
|
20
38
|
case "published":
|
|
@@ -24,7 +42,10 @@ const statusToLookup = (params) => {
|
|
|
24
42
|
}
|
|
25
43
|
return _.assoc("lookup", lookup, params);
|
|
26
44
|
};
|
|
27
|
-
const statusToData = (params) => {
|
|
45
|
+
const statusToData = (contentType, params) => {
|
|
46
|
+
if (!strapiUtils.contentTypes.hasDraftAndPublish(contentType)) {
|
|
47
|
+
return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
|
|
48
|
+
}
|
|
28
49
|
switch (params?.status) {
|
|
29
50
|
case "published":
|
|
30
51
|
return _.assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
|
|
@@ -33,9 +54,16 @@ const statusToData = (params) => {
|
|
|
33
54
|
}
|
|
34
55
|
return params;
|
|
35
56
|
};
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
57
|
+
const setStatusToDraftCurry = _.curry(setStatusToDraft);
|
|
58
|
+
const defaultToDraftCurry = _.curry(defaultToDraft);
|
|
59
|
+
const defaultStatusCurry = _.curry(defaultStatus);
|
|
60
|
+
const filterDataPublishedAtCurry = _.curry(filterDataPublishedAt);
|
|
61
|
+
const statusToLookupCurry = _.curry(statusToLookup);
|
|
62
|
+
const statusToDataCurry = _.curry(statusToData);
|
|
63
|
+
exports.defaultStatus = defaultStatusCurry;
|
|
64
|
+
exports.defaultToDraft = defaultToDraftCurry;
|
|
65
|
+
exports.filterDataPublishedAt = filterDataPublishedAtCurry;
|
|
66
|
+
exports.setStatusToDraft = setStatusToDraftCurry;
|
|
67
|
+
exports.statusToData = statusToDataCurry;
|
|
68
|
+
exports.statusToLookup = statusToLookupCurry;
|
|
41
69
|
//# sourceMappingURL=draft-and-publish.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"draft-and-publish.js","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { Documents } from '@strapi/types';\nimport {
|
|
1
|
+
{"version":3,"file":"draft-and-publish.js","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { assoc, curry } from 'lodash/fp';\n\nimport { Schema, Documents } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Documents.Params.All) => Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":["contentTypes","assoc","curry"],"mappings":";;;;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAACA,YAAa,aAAA,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,EACT;AAEO,SAAAC,QAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAAA,QAAM,UAAU,SAAS,MAAM;AAAA,EACxC;AAEO,SAAA;AACT;AAMA,MAAM,gBAA0C,CAAC,aAAa,WAAW;AACvE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAGA,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,eAAe,MAAM;AAAA,EAC9B;AAEO,SAAA;AACT;AAKA,MAAM,wBAAyC,CAAC,WAAW;AACrD,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAOC,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EACpD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA2C,CAAC,aAAa,WAAW;AACxE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAEM,QAAA,SAAS,OAAO,UAAU;AAEhC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAC,EAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,QAAQ,MAAM;AAAA,IACpE,KAAK;AACI,aAAAA,EAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,QAAQ,MAAM;AAAA,EAGnE;AAEO,SAAAA,QAAM,UAAU,QAAQ,MAAM;AACvC;AAKA,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAACD,YAAA,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAAC,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,EAC1D;AAEA,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAAA,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAOA,EAAAA,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAGtD;AAEO,SAAA;AACT;AAEM,MAAA,wBAAwBC,QAAM,gBAAgB;AAC9C,MAAA,sBAAsBA,QAAM,cAAc;AAC1C,MAAA,qBAAqBA,QAAM,aAAa;AACxC,MAAA,6BAA6BA,QAAM,qBAAqB;AACxD,MAAA,sBAAsBA,QAAM,cAAc;AAC1C,MAAA,oBAAoBA,QAAM,YAAY;;;;;;;"}
|
|
@@ -1,8 +1,23 @@
|
|
|
1
|
-
import { assoc } from "lodash/fp";
|
|
2
|
-
|
|
1
|
+
import { curry, assoc } from "lodash/fp";
|
|
2
|
+
import { contentTypes } from "@strapi/utils";
|
|
3
|
+
const setStatusToDraft = (contentType, params) => {
|
|
4
|
+
if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {
|
|
5
|
+
return params;
|
|
6
|
+
}
|
|
7
|
+
return assoc("status", "draft", params);
|
|
8
|
+
};
|
|
3
9
|
const defaultToDraft = (params) => {
|
|
4
10
|
if (!params.status || params.status !== "published") {
|
|
5
|
-
return
|
|
11
|
+
return assoc("status", "draft", params);
|
|
12
|
+
}
|
|
13
|
+
return params;
|
|
14
|
+
};
|
|
15
|
+
const defaultStatus = (contentType, params) => {
|
|
16
|
+
if (!contentTypes.hasDraftAndPublish(contentType)) {
|
|
17
|
+
return params;
|
|
18
|
+
}
|
|
19
|
+
if (!params.status || params.status !== "published") {
|
|
20
|
+
return defaultToDraft(params);
|
|
6
21
|
}
|
|
7
22
|
return params;
|
|
8
23
|
};
|
|
@@ -12,7 +27,10 @@ const filterDataPublishedAt = (params) => {
|
|
|
12
27
|
}
|
|
13
28
|
return params;
|
|
14
29
|
};
|
|
15
|
-
const statusToLookup = (params) => {
|
|
30
|
+
const statusToLookup = (contentType, params) => {
|
|
31
|
+
if (!contentTypes.hasDraftAndPublish(contentType)) {
|
|
32
|
+
return params;
|
|
33
|
+
}
|
|
16
34
|
const lookup = params.lookup || {};
|
|
17
35
|
switch (params?.status) {
|
|
18
36
|
case "published":
|
|
@@ -22,7 +40,10 @@ const statusToLookup = (params) => {
|
|
|
22
40
|
}
|
|
23
41
|
return assoc("lookup", lookup, params);
|
|
24
42
|
};
|
|
25
|
-
const statusToData = (params) => {
|
|
43
|
+
const statusToData = (contentType, params) => {
|
|
44
|
+
if (!contentTypes.hasDraftAndPublish(contentType)) {
|
|
45
|
+
return assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
|
|
46
|
+
}
|
|
26
47
|
switch (params?.status) {
|
|
27
48
|
case "published":
|
|
28
49
|
return assoc(["data", "publishedAt"], /* @__PURE__ */ new Date(), params);
|
|
@@ -31,11 +52,18 @@ const statusToData = (params) => {
|
|
|
31
52
|
}
|
|
32
53
|
return params;
|
|
33
54
|
};
|
|
55
|
+
const setStatusToDraftCurry = curry(setStatusToDraft);
|
|
56
|
+
const defaultToDraftCurry = curry(defaultToDraft);
|
|
57
|
+
const defaultStatusCurry = curry(defaultStatus);
|
|
58
|
+
const filterDataPublishedAtCurry = curry(filterDataPublishedAt);
|
|
59
|
+
const statusToLookupCurry = curry(statusToLookup);
|
|
60
|
+
const statusToDataCurry = curry(statusToData);
|
|
34
61
|
export {
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
62
|
+
defaultStatusCurry as defaultStatus,
|
|
63
|
+
defaultToDraftCurry as defaultToDraft,
|
|
64
|
+
filterDataPublishedAtCurry as filterDataPublishedAt,
|
|
65
|
+
setStatusToDraftCurry as setStatusToDraft,
|
|
66
|
+
statusToDataCurry as statusToData,
|
|
67
|
+
statusToLookupCurry as statusToLookup
|
|
40
68
|
};
|
|
41
69
|
//# sourceMappingURL=draft-and-publish.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"draft-and-publish.mjs","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { Documents } from '@strapi/types';\nimport {
|
|
1
|
+
{"version":3,"file":"draft-and-publish.mjs","sources":["../../../src/services/document-service/draft-and-publish.ts"],"sourcesContent":["import { assoc, curry } from 'lodash/fp';\n\nimport { Schema, Documents } from '@strapi/types';\nimport { contentTypes } from '@strapi/utils';\n\ntype ParamsTransform = (params: Documents.Params.All) => Documents.Params.All;\n\ntype TransformWithContentType = (\n contentType: Schema.SingleType | Schema.CollectionType,\n params: Documents.Params.All\n) => Documents.Params.All;\n\n/**\n * DP enabled -> set status to draft\n * DP disabled -> Used mostly for parsing relations, so there is not a need for a default.\n */\nconst setStatusToDraft: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType) && params.status) {\n return params;\n }\n\n return assoc('status', 'draft', params);\n};\n\n/**\n * Adds a default status of `draft` to the params\n */\nconst defaultToDraft: ParamsTransform = (params) => {\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return assoc('status', 'draft', params);\n }\n\n return params;\n};\n\n/**\n * DP disabled -> ignore status\n * DP enabled -> set status to draft if no status is provided or it's invalid\n */\nconst defaultStatus: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n // Default to draft if no status is provided or it's invalid\n if (!params.status || params.status !== 'published') {\n return defaultToDraft(params);\n }\n\n return params;\n};\n\n/**\n * In mutating actions we don't want user to set the publishedAt attribute.\n */\nconst filterDataPublishedAt: ParamsTransform = (params) => {\n if (params?.data?.publishedAt) {\n return assoc(['data', 'publishedAt'], null, params);\n }\n\n return params;\n};\n\n/**\n * Add status lookup query to the params\n */\nconst statusToLookup: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return params;\n }\n\n const lookup = params.lookup || {};\n\n switch (params?.status) {\n case 'published':\n return assoc(['lookup', 'publishedAt'], { $notNull: true }, params);\n case 'draft':\n return assoc(['lookup', 'publishedAt'], { $null: true }, params);\n default:\n break;\n }\n\n return assoc('lookup', lookup, params);\n};\n\n/**\n * Translate publication status parameter into the data that will be saved\n */\nconst statusToData: TransformWithContentType = (contentType, params) => {\n if (!contentTypes.hasDraftAndPublish(contentType)) {\n return assoc(['data', 'publishedAt'], new Date(), params);\n }\n\n switch (params?.status) {\n case 'published':\n return assoc(['data', 'publishedAt'], new Date(), params);\n case 'draft':\n return assoc(['data', 'publishedAt'], null, params);\n default:\n break;\n }\n\n return params;\n};\n\nconst setStatusToDraftCurry = curry(setStatusToDraft);\nconst defaultToDraftCurry = curry(defaultToDraft);\nconst defaultStatusCurry = curry(defaultStatus);\nconst filterDataPublishedAtCurry = curry(filterDataPublishedAt);\nconst statusToLookupCurry = curry(statusToLookup);\nconst statusToDataCurry = curry(statusToData);\n\nexport {\n setStatusToDraftCurry as setStatusToDraft,\n defaultToDraftCurry as defaultToDraft,\n defaultStatusCurry as defaultStatus,\n filterDataPublishedAtCurry as filterDataPublishedAt,\n statusToLookupCurry as statusToLookup,\n statusToDataCurry as statusToData,\n};\n"],"names":[],"mappings":";;AAgBA,MAAM,mBAA6C,CAAC,aAAa,WAAW;AAC1E,MAAI,CAAC,aAAa,mBAAmB,WAAW,KAAK,OAAO,QAAQ;AAC3D,WAAA;AAAA,EACT;AAEO,SAAA,MAAM,UAAU,SAAS,MAAM;AACxC;AAKA,MAAM,iBAAkC,CAAC,WAAW;AAElD,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AAC5C,WAAA,MAAM,UAAU,SAAS,MAAM;AAAA,EACxC;AAEO,SAAA;AACT;AAMA,MAAM,gBAA0C,CAAC,aAAa,WAAW;AACvE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAGA,MAAI,CAAC,OAAO,UAAU,OAAO,WAAW,aAAa;AACnD,WAAO,eAAe,MAAM;AAAA,EAC9B;AAEO,SAAA;AACT;AAKA,MAAM,wBAAyC,CAAC,WAAW;AACrD,MAAA,QAAQ,MAAM,aAAa;AAC7B,WAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EACpD;AAEO,SAAA;AACT;AAKA,MAAM,iBAA2C,CAAC,aAAa,WAAW;AACxE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA;AAAA,EACT;AAEM,QAAA,SAAS,OAAO,UAAU;AAEhC,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,UAAU,QAAQ,MAAM;AAAA,IACpE,KAAK;AACI,aAAA,MAAM,CAAC,UAAU,aAAa,GAAG,EAAE,OAAO,QAAQ,MAAM;AAAA,EAGnE;AAEO,SAAA,MAAM,UAAU,QAAQ,MAAM;AACvC;AAKA,MAAM,eAAyC,CAAC,aAAa,WAAW;AACtE,MAAI,CAAC,aAAa,mBAAmB,WAAW,GAAG;AAC1C,WAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,EAC1D;AAEA,UAAQ,QAAQ,QAAQ;AAAA,IACtB,KAAK;AACI,aAAA,MAAM,CAAC,QAAQ,aAAa,GAAO,oBAAA,KAAA,GAAQ,MAAM;AAAA,IAC1D,KAAK;AACH,aAAO,MAAM,CAAC,QAAQ,aAAa,GAAG,MAAM,MAAM;AAAA,EAGtD;AAEO,SAAA;AACT;AAEM,MAAA,wBAAwB,MAAM,gBAAgB;AAC9C,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,qBAAqB,MAAM,aAAa;AACxC,MAAA,6BAA6B,MAAM,qBAAqB;AACxD,MAAA,sBAAsB,MAAM,cAAc;AAC1C,MAAA,oBAAoB,MAAM,YAAY;"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAKlD;;;;;;;;;;;;;;;GAeG;AAEH,eAAO,MAAM,qBAAqB,WAAY,MAAM,KAAG,UAAU,OAoBhE,CAAC"}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
-
const repositoryFactory = require("./repository-factory.js");
|
|
4
3
|
const middlewares = require("./middlewares.js");
|
|
4
|
+
const repository = require("./repository.js");
|
|
5
5
|
const createDocumentService = (strapi) => {
|
|
6
6
|
const repositories = /* @__PURE__ */ new Map();
|
|
7
7
|
const middlewares$1 = middlewares.createMiddlewareManager();
|
|
@@ -10,9 +10,9 @@ const createDocumentService = (strapi) => {
|
|
|
10
10
|
return repositories.get(uid);
|
|
11
11
|
}
|
|
12
12
|
const contentType = strapi.contentType(uid);
|
|
13
|
-
const repository =
|
|
14
|
-
repositories.set(uid, middlewares$1.wrapObject(repository, { contentType }));
|
|
15
|
-
return repository;
|
|
13
|
+
const repository$1 = repository.createContentTypeRepository(uid);
|
|
14
|
+
repositories.set(uid, middlewares$1.wrapObject(repository$1, { contentType }));
|
|
15
|
+
return repository$1;
|
|
16
16
|
};
|
|
17
17
|
return Object.assign(factory, {
|
|
18
18
|
use: middlewares$1.use.bind(middlewares$1)
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import { Strapi, Documents
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import { Strapi, Documents } from '@strapi/types';\n\nimport { createMiddlewareManager } from './middlewares';\nimport { createContentTypeRepository } from './repository';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @param options.defaults - Default parameters to apply to all actions\n * @param options.parent - Parent repository, used when creating a new repository with .with()\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\n// TODO: support global document service middleware & per repo middlewares\nexport const createDocumentService = (strapi: Strapi): Documents.Service => {\n const repositories = new Map<string, Documents.ServiceInstance>();\n const middlewares = createMiddlewareManager();\n\n const factory = function factory(uid) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n repositories.set(uid, middlewares.wrapObject(repository, { contentType }));\n\n return repository;\n } as Documents.Service;\n\n return Object.assign(factory, {\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["middlewares","createMiddlewareManager","factory","repository","createContentTypeRepository"],"mappings":";;;;AAsBa,MAAA,wBAAwB,CAAC,WAAsC;AACpE,QAAA,mCAAmB;AACzB,QAAMA,gBAAcC,YAAAA;AAEd,QAAA,UAAU,SAASC,SAAQ,KAAK;AAChC,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAAC,eAAaC,uCAA4B,GAAG;AAErC,iBAAA,IAAI,KAAKJ,cAAY,WAAWG,cAAY,EAAE,YAAa,CAAA,CAAC;AAElE,WAAAA;AAAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,KAAKH,cAAY,IAAI,KAAKA,aAAW;AAAA,EAAA,CACtC;AACH;;"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { createContentTypeRepository } from "./repository-factory.mjs";
|
|
2
1
|
import { createMiddlewareManager } from "./middlewares.mjs";
|
|
2
|
+
import { createContentTypeRepository } from "./repository.mjs";
|
|
3
3
|
const createDocumentService = (strapi) => {
|
|
4
4
|
const repositories = /* @__PURE__ */ new Map();
|
|
5
5
|
const middlewares = createMiddlewareManager();
|
|
@@ -8,7 +8,7 @@ const createDocumentService = (strapi) => {
|
|
|
8
8
|
return repositories.get(uid);
|
|
9
9
|
}
|
|
10
10
|
const contentType = strapi.contentType(uid);
|
|
11
|
-
const repository = createContentTypeRepository(
|
|
11
|
+
const repository = createContentTypeRepository(uid);
|
|
12
12
|
repositories.set(uid, middlewares.wrapObject(repository, { contentType }));
|
|
13
13
|
return repository;
|
|
14
14
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import { Strapi, Documents
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../src/services/document-service/index.ts"],"sourcesContent":["import { Strapi, Documents } from '@strapi/types';\n\nimport { createMiddlewareManager } from './middlewares';\nimport { createContentTypeRepository } from './repository';\n\n/**\n * Repository to :\n * - Access documents via actions (findMany, findOne, create, update, delete, ...)\n * - Execute middlewares on document actions\n * - Apply default parameters to document actions\n *\n * @param strapi\n * @param options.defaults - Default parameters to apply to all actions\n * @param options.parent - Parent repository, used when creating a new repository with .with()\n * @returns DocumentService\n *\n * @example Access documents\n * const article = strapi.documents('api::article.article').create(params)\n * const allArticles = strapi.documents('api::article.article').findMany(params)\n *\n */\n// TODO: support global document service middleware & per repo middlewares\nexport const createDocumentService = (strapi: Strapi): Documents.Service => {\n const repositories = new Map<string, Documents.ServiceInstance>();\n const middlewares = createMiddlewareManager();\n\n const factory = function factory(uid) {\n if (repositories.has(uid)) {\n return repositories.get(uid)!;\n }\n\n const contentType = strapi.contentType(uid);\n const repository = createContentTypeRepository(uid);\n\n repositories.set(uid, middlewares.wrapObject(repository, { contentType }));\n\n return repository;\n } as Documents.Service;\n\n return Object.assign(factory, {\n use: middlewares.use.bind(middlewares),\n });\n};\n"],"names":["factory"],"mappings":";;AAsBa,MAAA,wBAAwB,CAAC,WAAsC;AACpE,QAAA,mCAAmB;AACzB,QAAM,cAAc;AAEd,QAAA,UAAU,SAASA,SAAQ,KAAK;AAChC,QAAA,aAAa,IAAI,GAAG,GAAG;AAClB,aAAA,aAAa,IAAI,GAAG;AAAA,IAC7B;AAEM,UAAA,cAAc,OAAO,YAAY,GAAG;AACpC,UAAA,aAAa,4BAA4B,GAAG;AAErC,iBAAA,IAAI,KAAK,YAAY,WAAW,YAAY,EAAE,YAAa,CAAA,CAAC;AAElE,WAAA;AAAA,EAAA;AAGF,SAAA,OAAO,OAAO,SAAS;AAAA,IAC5B,KAAK,YAAY,IAAI,KAAK,WAAW;AAAA,EAAA,CACtC;AACH;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"repository.d.ts","sourceRoot":"","sources":["../../../src/services/document-service/repository.ts"],"names":[],"mappings":"AAKA,OAAO,EAAqB,KAAK,uBAAuB,EAAE,MAAM,UAAU,CAAC;AA0B3E,eAAO,MAAM,2BAA2B,EAAE,uBAyVzC,CAAC"}
|
|
@@ -0,0 +1,295 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
3
|
+
const _ = require("lodash/fp");
|
|
4
|
+
const strapiUtils = require("@strapi/utils");
|
|
5
|
+
const common = require("./common.js");
|
|
6
|
+
const draftAndPublish = require("./draft-and-publish.js");
|
|
7
|
+
const internationalization = require("./internationalization.js");
|
|
8
|
+
const idTransform = require("./transform/id-transform.js");
|
|
9
|
+
const components = require("../entity-service/components.js");
|
|
10
|
+
const params = require("../entity-service/params.js");
|
|
11
|
+
const index = require("../entity-validator/index.js");
|
|
12
|
+
const index$1 = require("../entity-service/attributes/index.js");
|
|
13
|
+
const transformContentTypesToModels = require("../../utils/transform-content-types-to-models.js");
|
|
14
|
+
const populate = require("./utils/populate.js");
|
|
15
|
+
const data = require("./transform/data.js");
|
|
16
|
+
const transformParamsToQuery = _.curry((uid, params2) => {
|
|
17
|
+
const query = strapiUtils.convertQueryParams.transformParamsToQuery(uid, params2);
|
|
18
|
+
return _.assoc("where", { ...params2?.lookup, ...query.where }, query);
|
|
19
|
+
});
|
|
20
|
+
const createContentTypeRepository = (uid) => {
|
|
21
|
+
const contentType = strapi.contentType(uid);
|
|
22
|
+
const hasDraftAndPublish = strapiUtils.contentTypes.hasDraftAndPublish(contentType);
|
|
23
|
+
async function findMany(params2 = {}) {
|
|
24
|
+
const query = await strapiUtils.async.pipe(
|
|
25
|
+
draftAndPublish.defaultToDraft,
|
|
26
|
+
draftAndPublish.statusToLookup(contentType),
|
|
27
|
+
internationalization.defaultLocale(contentType),
|
|
28
|
+
internationalization.localeToLookup(contentType),
|
|
29
|
+
idTransform.transformParamsDocumentId(uid),
|
|
30
|
+
transformParamsToQuery(uid)
|
|
31
|
+
)(params2 || {});
|
|
32
|
+
return strapi.db.query(uid).findMany(query);
|
|
33
|
+
}
|
|
34
|
+
async function findFirst(params2 = {}) {
|
|
35
|
+
const query = await strapiUtils.async.pipe(
|
|
36
|
+
draftAndPublish.defaultToDraft,
|
|
37
|
+
draftAndPublish.statusToLookup(contentType),
|
|
38
|
+
internationalization.defaultLocale(contentType),
|
|
39
|
+
internationalization.localeToLookup(contentType),
|
|
40
|
+
idTransform.transformParamsDocumentId(uid),
|
|
41
|
+
transformParamsToQuery(uid)
|
|
42
|
+
)(params2);
|
|
43
|
+
return strapi.db.query(uid).findOne(query);
|
|
44
|
+
}
|
|
45
|
+
async function findOne(documentId, params2 = {}) {
|
|
46
|
+
const query = await strapiUtils.async.pipe(
|
|
47
|
+
draftAndPublish.defaultToDraft,
|
|
48
|
+
draftAndPublish.statusToLookup(contentType),
|
|
49
|
+
internationalization.defaultLocale(contentType),
|
|
50
|
+
internationalization.localeToLookup(contentType),
|
|
51
|
+
idTransform.transformParamsDocumentId(uid),
|
|
52
|
+
transformParamsToQuery(uid),
|
|
53
|
+
(query2) => _.assoc("where", { ...query2.where, documentId }, query2)
|
|
54
|
+
)(params2);
|
|
55
|
+
return strapi.db.query(uid).findOne(query);
|
|
56
|
+
}
|
|
57
|
+
async function deleteEntry(id) {
|
|
58
|
+
const componentsToDelete = await components.getComponents(uid, { id });
|
|
59
|
+
await strapi.db.query(uid).delete({ where: { id } });
|
|
60
|
+
await components.deleteComponents(uid, componentsToDelete, { loadComponents: false });
|
|
61
|
+
}
|
|
62
|
+
async function deleteFn(documentId, params2 = {}) {
|
|
63
|
+
const query = await strapiUtils.async.pipe(
|
|
64
|
+
_.omit("status"),
|
|
65
|
+
internationalization.defaultLocale(contentType),
|
|
66
|
+
internationalization.multiLocaleToLookup(contentType),
|
|
67
|
+
transformParamsToQuery(uid),
|
|
68
|
+
(query2) => _.assoc("where", { ...query2.where, documentId }, query2)
|
|
69
|
+
)(params2);
|
|
70
|
+
if (params2.status === "draft") {
|
|
71
|
+
throw new Error("Cannot delete a draft document");
|
|
72
|
+
}
|
|
73
|
+
const entriesToDelete = await strapi.db.query(uid).findMany(query);
|
|
74
|
+
await strapiUtils.async.map(entriesToDelete, (entryToDelete) => deleteEntry(entryToDelete.id));
|
|
75
|
+
return { deletedEntries: entriesToDelete };
|
|
76
|
+
}
|
|
77
|
+
async function createEntry(params$1 = {}) {
|
|
78
|
+
const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, params$1);
|
|
79
|
+
const query = transformParamsToQuery(uid, params.pickSelectionParams(restParams));
|
|
80
|
+
if (!params$1.data) {
|
|
81
|
+
throw new Error("Create requires data attribute");
|
|
82
|
+
}
|
|
83
|
+
const validData = await index.validateEntityCreation(contentType, data2, {
|
|
84
|
+
// Note: publishedAt value will always be set when DP is disabled
|
|
85
|
+
isDraft: !params$1?.data?.publishedAt,
|
|
86
|
+
locale: params$1?.locale
|
|
87
|
+
});
|
|
88
|
+
const componentData = await components.createComponents(uid, validData);
|
|
89
|
+
const entryData = index$1.applyTransforms(
|
|
90
|
+
Object.assign(components.omitComponentData(contentType, validData), componentData),
|
|
91
|
+
{ contentType }
|
|
92
|
+
);
|
|
93
|
+
const doc = await strapi.db.query(uid).create({ ...query, data: entryData });
|
|
94
|
+
return doc;
|
|
95
|
+
}
|
|
96
|
+
async function create(params2 = {}) {
|
|
97
|
+
const queryParams = await strapiUtils.async.pipe(
|
|
98
|
+
draftAndPublish.filterDataPublishedAt,
|
|
99
|
+
draftAndPublish.setStatusToDraft(contentType),
|
|
100
|
+
draftAndPublish.statusToData(contentType),
|
|
101
|
+
internationalization.defaultLocale(contentType),
|
|
102
|
+
internationalization.localeToData(contentType)
|
|
103
|
+
)(params2);
|
|
104
|
+
const doc = await createEntry(queryParams);
|
|
105
|
+
if (hasDraftAndPublish && params2.status === "published") {
|
|
106
|
+
return publish(doc.documentId, params2).then((doc2) => doc2.versions[0]);
|
|
107
|
+
}
|
|
108
|
+
return doc;
|
|
109
|
+
}
|
|
110
|
+
async function clone(documentId, params2 = {}) {
|
|
111
|
+
const queryParams = await strapiUtils.async.pipe(
|
|
112
|
+
draftAndPublish.filterDataPublishedAt,
|
|
113
|
+
internationalization.defaultLocale(contentType),
|
|
114
|
+
internationalization.multiLocaleToLookup(contentType)
|
|
115
|
+
)(params2);
|
|
116
|
+
const entriesToClone = await strapi.db?.query(uid).findMany({
|
|
117
|
+
where: {
|
|
118
|
+
...queryParams?.lookup,
|
|
119
|
+
documentId,
|
|
120
|
+
// DP Enabled: Clone drafts
|
|
121
|
+
// DP Disabled: Clone only the existing version (published)
|
|
122
|
+
publishedAt: { $null: hasDraftAndPublish }
|
|
123
|
+
},
|
|
124
|
+
populate: populate.getDeepPopulate(uid, { relationalFields: ["id"] })
|
|
125
|
+
});
|
|
126
|
+
const clonedEntries = await strapiUtils.async.map(
|
|
127
|
+
entriesToClone,
|
|
128
|
+
strapiUtils.async.pipe(
|
|
129
|
+
_.omit("id"),
|
|
130
|
+
// assign new documentId
|
|
131
|
+
_.assoc("documentId", transformContentTypesToModels.createDocumentId()),
|
|
132
|
+
// Merge new data into it
|
|
133
|
+
(data2) => _.merge(data2, queryParams.data),
|
|
134
|
+
(data2) => createEntry({ ...queryParams, data: data2, status: "draft" })
|
|
135
|
+
)
|
|
136
|
+
);
|
|
137
|
+
return { documentId: clonedEntries.at(0)?.documentId, versions: clonedEntries };
|
|
138
|
+
}
|
|
139
|
+
async function update(documentId, params$1 = {}) {
|
|
140
|
+
const queryParams = await strapiUtils.async.pipe(
|
|
141
|
+
draftAndPublish.filterDataPublishedAt,
|
|
142
|
+
draftAndPublish.setStatusToDraft(contentType),
|
|
143
|
+
draftAndPublish.statusToLookup(contentType),
|
|
144
|
+
draftAndPublish.statusToData(contentType),
|
|
145
|
+
// Default locale will be set if not provided
|
|
146
|
+
internationalization.defaultLocale(contentType),
|
|
147
|
+
internationalization.localeToLookup(contentType),
|
|
148
|
+
internationalization.localeToData(contentType)
|
|
149
|
+
)(params$1);
|
|
150
|
+
const { data: data2, ...restParams } = await idTransform.transformParamsDocumentId(uid, queryParams || {});
|
|
151
|
+
const query = transformParamsToQuery(uid, params.pickSelectionParams(restParams || {}));
|
|
152
|
+
const model = strapi.contentType(uid);
|
|
153
|
+
const entryToUpdate = await strapi.db.query(uid).findOne({ ...query, where: { ...queryParams?.lookup, ...query?.where, documentId } });
|
|
154
|
+
let updatedDraft = null;
|
|
155
|
+
if (entryToUpdate) {
|
|
156
|
+
const validData = await index.validateEntityUpdate(
|
|
157
|
+
model,
|
|
158
|
+
data2,
|
|
159
|
+
{
|
|
160
|
+
isDraft: !queryParams?.data?.publishedAt,
|
|
161
|
+
// Always update the draft version
|
|
162
|
+
locale: queryParams?.locale
|
|
163
|
+
},
|
|
164
|
+
entryToUpdate
|
|
165
|
+
);
|
|
166
|
+
const componentData = await components.updateComponents(uid, entryToUpdate, validData);
|
|
167
|
+
const entryData = index$1.applyTransforms(
|
|
168
|
+
Object.assign(components.omitComponentData(model, validData), componentData),
|
|
169
|
+
{ contentType: model }
|
|
170
|
+
);
|
|
171
|
+
updatedDraft = await strapi.db.query(uid).update({ ...query, where: { id: entryToUpdate.id }, data: entryData });
|
|
172
|
+
}
|
|
173
|
+
if (!updatedDraft) {
|
|
174
|
+
const documentExists = await strapi.db.query(contentType.uid).findOne({ where: { documentId } });
|
|
175
|
+
if (documentExists) {
|
|
176
|
+
updatedDraft = await createEntry({
|
|
177
|
+
...queryParams,
|
|
178
|
+
data: { ...queryParams.data, documentId }
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
if (hasDraftAndPublish && updatedDraft && params$1.status === "published") {
|
|
183
|
+
return publish(documentId, params$1).then((doc) => doc.versions[0]);
|
|
184
|
+
}
|
|
185
|
+
return updatedDraft;
|
|
186
|
+
}
|
|
187
|
+
async function count(params2 = {}) {
|
|
188
|
+
const query = await strapiUtils.async.pipe(
|
|
189
|
+
draftAndPublish.defaultStatus(contentType),
|
|
190
|
+
draftAndPublish.statusToLookup(contentType),
|
|
191
|
+
internationalization.defaultLocale(contentType),
|
|
192
|
+
internationalization.localeToLookup(contentType),
|
|
193
|
+
transformParamsToQuery(uid)
|
|
194
|
+
)(params2);
|
|
195
|
+
return strapi.db.query(uid).count(query);
|
|
196
|
+
}
|
|
197
|
+
async function publish(documentId, params2 = {}) {
|
|
198
|
+
const queryParams = await strapiUtils.async.pipe(
|
|
199
|
+
internationalization.defaultLocale(contentType),
|
|
200
|
+
internationalization.multiLocaleToLookup(contentType)
|
|
201
|
+
)(params2);
|
|
202
|
+
await deleteFn(documentId, {
|
|
203
|
+
...queryParams,
|
|
204
|
+
lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
|
|
205
|
+
});
|
|
206
|
+
const entriesToPublish = await strapi.db?.query(uid).findMany({
|
|
207
|
+
where: {
|
|
208
|
+
...queryParams?.lookup,
|
|
209
|
+
documentId,
|
|
210
|
+
publishedAt: null
|
|
211
|
+
},
|
|
212
|
+
populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
|
|
213
|
+
});
|
|
214
|
+
const publishedEntries = await strapiUtils.async.map(
|
|
215
|
+
entriesToPublish,
|
|
216
|
+
strapiUtils.async.pipe(
|
|
217
|
+
// Updated at value is used to know if draft has been modified
|
|
218
|
+
// If both versions share the same value, it means the draft has not been modified
|
|
219
|
+
(draft) => _.assoc("updatedAt", draft.updatedAt, draft),
|
|
220
|
+
_.assoc("publishedAt", /* @__PURE__ */ new Date()),
|
|
221
|
+
_.assoc("documentId", documentId),
|
|
222
|
+
_.omit("id"),
|
|
223
|
+
// Transform relations to target published versions
|
|
224
|
+
(entry) => {
|
|
225
|
+
const opts = { uid, locale: entry.locale, status: "published", allowMissingId: true };
|
|
226
|
+
return data.transformData(entry, opts);
|
|
227
|
+
},
|
|
228
|
+
// Create the published entry
|
|
229
|
+
(data2) => createEntry({ ...queryParams, data: data2, locale: data2.locale, status: "published" })
|
|
230
|
+
)
|
|
231
|
+
);
|
|
232
|
+
return { versions: publishedEntries };
|
|
233
|
+
}
|
|
234
|
+
async function unpublish(documentId, params2 = {}) {
|
|
235
|
+
const queryParams = await strapiUtils.async.pipe(
|
|
236
|
+
internationalization.defaultLocale(contentType),
|
|
237
|
+
internationalization.multiLocaleToLookup(contentType)
|
|
238
|
+
)(params2);
|
|
239
|
+
const { deletedEntries } = await deleteFn(documentId, {
|
|
240
|
+
...params2,
|
|
241
|
+
lookup: { ...queryParams?.lookup, publishedAt: { $ne: null } }
|
|
242
|
+
});
|
|
243
|
+
return { versions: deletedEntries };
|
|
244
|
+
}
|
|
245
|
+
async function discardDraft(documentId, params2 = {}) {
|
|
246
|
+
const queryParams = await strapiUtils.async.pipe(
|
|
247
|
+
internationalization.defaultLocale(contentType),
|
|
248
|
+
internationalization.multiLocaleToLookup(contentType)
|
|
249
|
+
)(params2);
|
|
250
|
+
await deleteFn(documentId, {
|
|
251
|
+
...queryParams,
|
|
252
|
+
// Delete all drafts that match query
|
|
253
|
+
lookup: { ...queryParams?.lookup, publishedAt: null }
|
|
254
|
+
});
|
|
255
|
+
const entriesToDraft = await strapi.db?.query(uid).findMany({
|
|
256
|
+
where: {
|
|
257
|
+
...queryParams?.lookup,
|
|
258
|
+
documentId,
|
|
259
|
+
publishedAt: { $ne: null }
|
|
260
|
+
},
|
|
261
|
+
populate: populate.getDeepPopulate(uid, { relationalFields: ["documentId", "locale"] })
|
|
262
|
+
});
|
|
263
|
+
const draftEntries = await strapiUtils.async.map(
|
|
264
|
+
entriesToDraft,
|
|
265
|
+
strapiUtils.async.pipe(
|
|
266
|
+
_.assoc("publishedAt", null),
|
|
267
|
+
_.assoc("documentId", documentId),
|
|
268
|
+
_.omit("id"),
|
|
269
|
+
// Transform relations to target draft versions
|
|
270
|
+
(entry) => {
|
|
271
|
+
const opts = { uid, locale: entry.locale, status: "draft", allowMissingId: true };
|
|
272
|
+
return data.transformData(entry, opts);
|
|
273
|
+
},
|
|
274
|
+
// Create the draft entry
|
|
275
|
+
(data2) => createEntry({ ...queryParams, locale: data2.locale, data: data2, status: "draft" })
|
|
276
|
+
)
|
|
277
|
+
);
|
|
278
|
+
return { versions: draftEntries };
|
|
279
|
+
}
|
|
280
|
+
return {
|
|
281
|
+
findMany: common.wrapInTransaction(findMany),
|
|
282
|
+
findFirst: common.wrapInTransaction(findFirst),
|
|
283
|
+
findOne: common.wrapInTransaction(findOne),
|
|
284
|
+
delete: common.wrapInTransaction(deleteFn),
|
|
285
|
+
create: common.wrapInTransaction(create),
|
|
286
|
+
clone: common.wrapInTransaction(clone),
|
|
287
|
+
update: common.wrapInTransaction(update),
|
|
288
|
+
count: common.wrapInTransaction(count),
|
|
289
|
+
publish: hasDraftAndPublish ? common.wrapInTransaction(publish) : void 0,
|
|
290
|
+
unpublish: hasDraftAndPublish ? common.wrapInTransaction(unpublish) : void 0,
|
|
291
|
+
discardDraft: hasDraftAndPublish ? common.wrapInTransaction(discardDraft) : void 0
|
|
292
|
+
};
|
|
293
|
+
};
|
|
294
|
+
exports.createContentTypeRepository = createContentTypeRepository;
|
|
295
|
+
//# sourceMappingURL=repository.js.map
|