@strapi/utils 5.46.1 → 5.47.0

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.
Files changed (39) hide show
  1. package/dist/content-api-constants.d.ts +2 -2
  2. package/dist/content-api-constants.d.ts.map +1 -1
  3. package/dist/content-api-constants.js +2 -0
  4. package/dist/content-api-constants.js.map +1 -1
  5. package/dist/content-api-constants.mjs +2 -0
  6. package/dist/content-api-constants.mjs.map +1 -1
  7. package/dist/convert-query-params.d.ts +4 -2
  8. package/dist/convert-query-params.d.ts.map +1 -1
  9. package/dist/convert-query-params.js.map +1 -1
  10. package/dist/convert-query-params.mjs.map +1 -1
  11. package/dist/has-published-version-param.d.ts +9 -0
  12. package/dist/has-published-version-param.d.ts.map +1 -0
  13. package/dist/has-published-version-param.js +24 -0
  14. package/dist/has-published-version-param.js.map +1 -0
  15. package/dist/has-published-version-param.mjs +21 -0
  16. package/dist/has-published-version-param.mjs.map +1 -0
  17. package/dist/index.d.ts +2 -0
  18. package/dist/index.d.ts.map +1 -1
  19. package/dist/index.js +7 -0
  20. package/dist/index.js.map +1 -1
  21. package/dist/index.mjs +2 -0
  22. package/dist/index.mjs.map +1 -1
  23. package/dist/publication-filter.d.ts +14 -0
  24. package/dist/publication-filter.d.ts.map +1 -0
  25. package/dist/publication-filter.js +189 -0
  26. package/dist/publication-filter.js.map +1 -0
  27. package/dist/publication-filter.mjs +185 -0
  28. package/dist/publication-filter.mjs.map +1 -0
  29. package/dist/sanitize/index.d.ts.map +1 -1
  30. package/dist/sanitize/index.js +4 -0
  31. package/dist/sanitize/index.js.map +1 -1
  32. package/dist/sanitize/index.mjs +4 -0
  33. package/dist/sanitize/index.mjs.map +1 -1
  34. package/dist/validate/index.d.ts.map +1 -1
  35. package/dist/validate/index.js +5 -0
  36. package/dist/validate/index.js.map +1 -1
  37. package/dist/validate/index.mjs +5 -0
  38. package/dist/validate/index.mjs.map +1 -1
  39. package/package.json +3 -3
@@ -2,13 +2,13 @@
2
2
  * Param keys shared by the Content API (query) and the document service (query building).
3
3
  * Add new shared params here only; both ALLOWED_QUERY_PARAM_KEYS and ALLOWED_DOCUMENT_PARAM_KEYS derive from this.
4
4
  */
5
- export declare const SHARED_QUERY_PARAM_KEYS: readonly ["filters", "sort", "fields", "populate", "status", "locale", "page", "pageSize", "start", "limit", "_q", "hasPublishedVersion"];
5
+ export declare const SHARED_QUERY_PARAM_KEYS: readonly ["filters", "sort", "fields", "populate", "status", "locale", "page", "pageSize", "start", "limit", "_q", "publicationFilter", "hasPublishedVersion"];
6
6
  /**
7
7
  * Core query param keys allowed by the Content API (validate/sanitize query).
8
8
  * Used when strictParams is true. User code and plugins can add additional keys via contentAPI.addQueryParams.
9
9
  * = SHARED_QUERY_PARAM_KEYS + Content API–only keys (pagination, count, ordering).
10
10
  */
11
- export declare const ALLOWED_QUERY_PARAM_KEYS: readonly ["filters", "sort", "fields", "populate", "status", "locale", "page", "pageSize", "start", "limit", "_q", "hasPublishedVersion", "pagination", "count", "ordering"];
11
+ export declare const ALLOWED_QUERY_PARAM_KEYS: readonly ["filters", "sort", "fields", "populate", "status", "locale", "page", "pageSize", "start", "limit", "_q", "publicationFilter", "hasPublishedVersion", "pagination", "count", "ordering"];
12
12
  /**
13
13
  * Root-level body.data keys reserved for core (id, documentId).
14
14
  * These cannot be added as custom input params via contentAPI.addInputParams.
@@ -1 +1 @@
1
- {"version":3,"file":"content-api-constants.d.ts","sourceRoot":"","sources":["../src/content-api-constants.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,eAAO,MAAM,uBAAuB,2IAa1B,CAAC;AAEX;;;;GAIG;AACH,eAAO,MAAM,wBAAwB,8KAK3B,CAAC;AAEX;;;GAGG;AACH,eAAO,MAAM,yBAAyB,2BAG5B,CAAC"}
1
+ {"version":3,"file":"content-api-constants.d.ts","sourceRoot":"","sources":["../src/content-api-constants.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,eAAO,MAAM,uBAAuB,gKAe1B,CAAC;AAEX;;;;GAIG;AACH,eAAO,MAAM,wBAAwB,mMAK3B,CAAC;AAEX;;;GAGG;AACH,eAAO,MAAM,yBAAyB,2BAG5B,CAAC"}
@@ -17,6 +17,8 @@ var contentTypes = require('./content-types.js');
17
17
  'start',
18
18
  'limit',
19
19
  '_q',
20
+ 'publicationFilter',
21
+ // Deprecated: replaced by `publicationFilter` for richer cohorts; kept for backward compatibility.
20
22
  'hasPublishedVersion'
21
23
  ];
22
24
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"content-api-constants.js","sources":["../src/content-api-constants.ts"],"sourcesContent":["import { constants } from './content-types';\n\n/**\n * Param keys shared by the Content API (query) and the document service (query building).\n * Add new shared params here only; both ALLOWED_QUERY_PARAM_KEYS and ALLOWED_DOCUMENT_PARAM_KEYS derive from this.\n */\nexport const SHARED_QUERY_PARAM_KEYS = [\n 'filters',\n 'sort',\n 'fields',\n 'populate',\n 'status',\n 'locale',\n 'page',\n 'pageSize',\n 'start',\n 'limit',\n '_q',\n 'hasPublishedVersion',\n] as const;\n\n/**\n * Core query param keys allowed by the Content API (validate/sanitize query).\n * Used when strictParams is true. User code and plugins can add additional keys via contentAPI.addQueryParams.\n * = SHARED_QUERY_PARAM_KEYS + Content API–only keys (pagination, count, ordering).\n */\nexport const ALLOWED_QUERY_PARAM_KEYS = [\n ...SHARED_QUERY_PARAM_KEYS,\n 'pagination',\n 'count',\n 'ordering',\n] as const;\n\n/**\n * Root-level body.data keys reserved for core (id, documentId).\n * These cannot be added as custom input params via contentAPI.addInputParams.\n */\nexport const RESERVED_INPUT_PARAM_KEYS = [\n constants.ID_ATTRIBUTE,\n constants.DOC_ID_ATTRIBUTE,\n] as const;\n"],"names":["SHARED_QUERY_PARAM_KEYS","ALLOWED_QUERY_PARAM_KEYS","RESERVED_INPUT_PARAM_KEYS","constants","ID_ATTRIBUTE","DOC_ID_ATTRIBUTE"],"mappings":";;;;AAEA;;;UAIaA,uBAAAA,GAA0B;AACrC,IAAA,SAAA;AACA,IAAA,MAAA;AACA,IAAA,QAAA;AACA,IAAA,UAAA;AACA,IAAA,QAAA;AACA,IAAA,QAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,OAAA;AACA,IAAA,OAAA;AACA,IAAA,IAAA;AACA,IAAA;;AAGF;;;;UAKaC,wBAAAA,GAA2B;AACnCD,IAAAA,GAAAA,uBAAAA;AACH,IAAA,YAAA;AACA,IAAA,OAAA;AACA,IAAA;;AAGF;;;UAIaE,yBAAAA,GAA4B;AACvCC,IAAAA,sBAAAA,CAAUC,YAAY;AACtBD,IAAAA,sBAAAA,CAAUE;;;;;;;"}
1
+ {"version":3,"file":"content-api-constants.js","sources":["../src/content-api-constants.ts"],"sourcesContent":["import { constants } from './content-types';\n\n/**\n * Param keys shared by the Content API (query) and the document service (query building).\n * Add new shared params here only; both ALLOWED_QUERY_PARAM_KEYS and ALLOWED_DOCUMENT_PARAM_KEYS derive from this.\n */\nexport const SHARED_QUERY_PARAM_KEYS = [\n 'filters',\n 'sort',\n 'fields',\n 'populate',\n 'status',\n 'locale',\n 'page',\n 'pageSize',\n 'start',\n 'limit',\n '_q',\n 'publicationFilter',\n // Deprecated: replaced by `publicationFilter` for richer cohorts; kept for backward compatibility.\n 'hasPublishedVersion',\n] as const;\n\n/**\n * Core query param keys allowed by the Content API (validate/sanitize query).\n * Used when strictParams is true. User code and plugins can add additional keys via contentAPI.addQueryParams.\n * = SHARED_QUERY_PARAM_KEYS + Content API–only keys (pagination, count, ordering).\n */\nexport const ALLOWED_QUERY_PARAM_KEYS = [\n ...SHARED_QUERY_PARAM_KEYS,\n 'pagination',\n 'count',\n 'ordering',\n] as const;\n\n/**\n * Root-level body.data keys reserved for core (id, documentId).\n * These cannot be added as custom input params via contentAPI.addInputParams.\n */\nexport const RESERVED_INPUT_PARAM_KEYS = [\n constants.ID_ATTRIBUTE,\n constants.DOC_ID_ATTRIBUTE,\n] as const;\n"],"names":["SHARED_QUERY_PARAM_KEYS","ALLOWED_QUERY_PARAM_KEYS","RESERVED_INPUT_PARAM_KEYS","constants","ID_ATTRIBUTE","DOC_ID_ATTRIBUTE"],"mappings":";;;;AAEA;;;UAIaA,uBAAAA,GAA0B;AACrC,IAAA,SAAA;AACA,IAAA,MAAA;AACA,IAAA,QAAA;AACA,IAAA,UAAA;AACA,IAAA,QAAA;AACA,IAAA,QAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,OAAA;AACA,IAAA,OAAA;AACA,IAAA,IAAA;AACA,IAAA,mBAAA;;AAEA,IAAA;;AAGF;;;;UAKaC,wBAAAA,GAA2B;AACnCD,IAAAA,GAAAA,uBAAAA;AACH,IAAA,YAAA;AACA,IAAA,OAAA;AACA,IAAA;;AAGF;;;UAIaE,yBAAAA,GAA4B;AACvCC,IAAAA,sBAAAA,CAAUC,YAAY;AACtBD,IAAAA,sBAAAA,CAAUE;;;;;;;"}
@@ -15,6 +15,8 @@ import { constants } from './content-types.mjs';
15
15
  'start',
16
16
  'limit',
17
17
  '_q',
18
+ 'publicationFilter',
19
+ // Deprecated: replaced by `publicationFilter` for richer cohorts; kept for backward compatibility.
18
20
  'hasPublishedVersion'
19
21
  ];
20
22
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"content-api-constants.mjs","sources":["../src/content-api-constants.ts"],"sourcesContent":["import { constants } from './content-types';\n\n/**\n * Param keys shared by the Content API (query) and the document service (query building).\n * Add new shared params here only; both ALLOWED_QUERY_PARAM_KEYS and ALLOWED_DOCUMENT_PARAM_KEYS derive from this.\n */\nexport const SHARED_QUERY_PARAM_KEYS = [\n 'filters',\n 'sort',\n 'fields',\n 'populate',\n 'status',\n 'locale',\n 'page',\n 'pageSize',\n 'start',\n 'limit',\n '_q',\n 'hasPublishedVersion',\n] as const;\n\n/**\n * Core query param keys allowed by the Content API (validate/sanitize query).\n * Used when strictParams is true. User code and plugins can add additional keys via contentAPI.addQueryParams.\n * = SHARED_QUERY_PARAM_KEYS + Content API–only keys (pagination, count, ordering).\n */\nexport const ALLOWED_QUERY_PARAM_KEYS = [\n ...SHARED_QUERY_PARAM_KEYS,\n 'pagination',\n 'count',\n 'ordering',\n] as const;\n\n/**\n * Root-level body.data keys reserved for core (id, documentId).\n * These cannot be added as custom input params via contentAPI.addInputParams.\n */\nexport const RESERVED_INPUT_PARAM_KEYS = [\n constants.ID_ATTRIBUTE,\n constants.DOC_ID_ATTRIBUTE,\n] as const;\n"],"names":["SHARED_QUERY_PARAM_KEYS","ALLOWED_QUERY_PARAM_KEYS","RESERVED_INPUT_PARAM_KEYS","constants","ID_ATTRIBUTE","DOC_ID_ATTRIBUTE"],"mappings":";;AAEA;;;UAIaA,uBAAAA,GAA0B;AACrC,IAAA,SAAA;AACA,IAAA,MAAA;AACA,IAAA,QAAA;AACA,IAAA,UAAA;AACA,IAAA,QAAA;AACA,IAAA,QAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,OAAA;AACA,IAAA,OAAA;AACA,IAAA,IAAA;AACA,IAAA;;AAGF;;;;UAKaC,wBAAAA,GAA2B;AACnCD,IAAAA,GAAAA,uBAAAA;AACH,IAAA,YAAA;AACA,IAAA,OAAA;AACA,IAAA;;AAGF;;;UAIaE,yBAAAA,GAA4B;AACvCC,IAAAA,SAAAA,CAAUC,YAAY;AACtBD,IAAAA,SAAAA,CAAUE;;;;;"}
1
+ {"version":3,"file":"content-api-constants.mjs","sources":["../src/content-api-constants.ts"],"sourcesContent":["import { constants } from './content-types';\n\n/**\n * Param keys shared by the Content API (query) and the document service (query building).\n * Add new shared params here only; both ALLOWED_QUERY_PARAM_KEYS and ALLOWED_DOCUMENT_PARAM_KEYS derive from this.\n */\nexport const SHARED_QUERY_PARAM_KEYS = [\n 'filters',\n 'sort',\n 'fields',\n 'populate',\n 'status',\n 'locale',\n 'page',\n 'pageSize',\n 'start',\n 'limit',\n '_q',\n 'publicationFilter',\n // Deprecated: replaced by `publicationFilter` for richer cohorts; kept for backward compatibility.\n 'hasPublishedVersion',\n] as const;\n\n/**\n * Core query param keys allowed by the Content API (validate/sanitize query).\n * Used when strictParams is true. User code and plugins can add additional keys via contentAPI.addQueryParams.\n * = SHARED_QUERY_PARAM_KEYS + Content API–only keys (pagination, count, ordering).\n */\nexport const ALLOWED_QUERY_PARAM_KEYS = [\n ...SHARED_QUERY_PARAM_KEYS,\n 'pagination',\n 'count',\n 'ordering',\n] as const;\n\n/**\n * Root-level body.data keys reserved for core (id, documentId).\n * These cannot be added as custom input params via contentAPI.addInputParams.\n */\nexport const RESERVED_INPUT_PARAM_KEYS = [\n constants.ID_ATTRIBUTE,\n constants.DOC_ID_ATTRIBUTE,\n] as const;\n"],"names":["SHARED_QUERY_PARAM_KEYS","ALLOWED_QUERY_PARAM_KEYS","RESERVED_INPUT_PARAM_KEYS","constants","ID_ATTRIBUTE","DOC_ID_ATTRIBUTE"],"mappings":";;AAEA;;;UAIaA,uBAAAA,GAA0B;AACrC,IAAA,SAAA;AACA,IAAA,MAAA;AACA,IAAA,QAAA;AACA,IAAA,UAAA;AACA,IAAA,QAAA;AACA,IAAA,QAAA;AACA,IAAA,MAAA;AACA,IAAA,UAAA;AACA,IAAA,OAAA;AACA,IAAA,OAAA;AACA,IAAA,IAAA;AACA,IAAA,mBAAA;;AAEA,IAAA;;AAGF;;;;UAKaC,wBAAAA,GAA2B;AACnCD,IAAAA,GAAAA,uBAAAA;AACH,IAAA,YAAA;AACA,IAAA,OAAA;AACA,IAAA;;AAGF;;;UAIaE,yBAAAA,GAA4B;AACvCC,IAAAA,SAAAA,CAAUC,YAAY;AACtBD,IAAAA,SAAAA,CAAUE;;;;;"}
@@ -1,3 +1,4 @@
1
+ import type { PublicationFilterMode } from './publication-filter';
1
2
  import { Model } from './types';
2
3
  type SortOrder = 'asc' | 'desc';
3
4
  export interface SortMap {
@@ -40,9 +41,10 @@ export interface Params {
40
41
  page?: number | string;
41
42
  pageSize?: number | string;
42
43
  status?: 'draft' | 'published';
44
+ publicationFilter?: PublicationFilterMode;
43
45
  /**
44
- * Filter documents by whether they have a published version.
45
- * Use with `status: 'draft'` to find documents that have never been published.
46
+ * @deprecated Replaced by `publicationFilter` (`never-published`, `has-published-version`, …).
47
+ * Retained for backward compatibility with existing REST and GraphQL clients.
46
48
  */
47
49
  hasPublishedVersion?: boolean | 'true' | 'false';
48
50
  }
@@ -1 +1 @@
1
- {"version":3,"file":"convert-query-params.d.ts","sourceRoot":"","sources":["../src/convert-query-params.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"convert-query-params.d.ts","sourceRoot":"","sources":["../src/convert-query-params.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"convert-query-params.js","sources":["../src/convert-query-params.ts"],"sourcesContent":["/* eslint-disable max-classes-per-file */\n\n/**\n * Converts the standard Strapi REST query params to a more usable format for querying\n * You can read more here: https://docs.strapi.io/developer-docs/latest/developer-resources/database-apis-reference/rest-api.html#filters\n */\n\nimport _ from 'lodash';\nimport {\n cloneDeep,\n get,\n isArray,\n isEmpty,\n isInteger,\n isNil,\n isObject,\n isString,\n toNumber,\n} from 'lodash/fp';\nimport {\n constants,\n hasDraftAndPublish,\n isDynamicZoneAttribute,\n isMorphToRelationalAttribute,\n} from './content-types';\nimport { PaginationError, ValidationError } from './errors';\nimport { isOperator } from './operators';\n\nimport parseType from './parse-type';\nimport { Model } from './types';\n\nconst { ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, PUBLISHED_AT_ATTRIBUTE } = constants;\n\ntype SortOrder = 'asc' | 'desc';\n\nexport interface SortMap {\n [key: string]: SortOrder | SortMap;\n}\n\nexport interface SortParamsObject {\n [key: string]: SortOrder | SortParamsObject;\n}\n\ntype SortParams = string | string[] | SortParamsObject | SortParamsObject[];\ntype FieldsParams = string | string[];\n\ntype FiltersParams = unknown;\n\nexport interface PopulateAttributesParams {\n [key: string]: boolean | PopulateObjectParams;\n}\n\nexport interface PopulateObjectParams {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: string | string[] | PopulateAttributesParams;\n on?: PopulateAttributesParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n}\n\ntype PopulateParams = string | string[] | PopulateAttributesParams;\n\nexport interface Params {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: PopulateParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n status?: 'draft' | 'published';\n /**\n * Filter documents by whether they have a published version.\n * Use with `status: 'draft'` to find documents that have never been published.\n */\n hasPublishedVersion?: boolean | 'true' | 'false';\n}\n\ntype FiltersQuery = (options: { meta: Model }) => WhereQuery | undefined;\ntype OrderByQuery = SortMap | SortMap[];\ntype SelectQuery = string | string[];\n\nexport interface WhereQuery {\n [key: string]: any;\n}\n\ntype PopulateQuery =\n | boolean\n | string[]\n | {\n [key: string]: PopulateQuery;\n };\n\nexport interface Query {\n orderBy?: OrderByQuery;\n select?: SelectQuery;\n where?: WhereQuery;\n // NOTE: those are internal DB filters do not modify\n filters?: FiltersQuery;\n populate?: PopulateQuery;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number;\n offset?: number;\n page?: number;\n pageSize?: number;\n}\n\nclass InvalidOrderError extends Error {\n constructor() {\n super();\n this.message = 'Invalid order. order can only be one of asc|desc|ASC|DESC';\n }\n}\n\nclass InvalidSortError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid sort parameter. Expected a string, an array of strings, a sort object or an array of sort objects';\n }\n}\n\nfunction validateOrder(order: string): asserts order is SortOrder {\n if (!isString(order) || !['asc', 'desc'].includes(order.toLocaleLowerCase())) {\n throw new InvalidOrderError();\n }\n}\n\nconst convertCountQueryParams = (countQuery: unknown): boolean => {\n return parseType({ type: 'boolean', value: countQuery });\n};\n\nconst convertOrderingQueryParams = (ordering: unknown) => {\n return ordering;\n};\n\nconst isPlainObject = (value: unknown): value is Record<string, unknown> => _.isPlainObject(value);\nconst isStringArray = (value: unknown): value is string[] =>\n isArray(value) && value.every(isString);\n\ninterface TransformerOptions {\n getModel: (uid: string) => Model | undefined;\n}\n\nconst createTransformer = ({ getModel }: TransformerOptions) => {\n /**\n * Sort query parser\n */\n const convertSortQueryParams = (sortQuery: SortParams): OrderByQuery => {\n if (typeof sortQuery === 'string') {\n return convertStringSortQueryParam(sortQuery);\n }\n\n if (isStringArray(sortQuery)) {\n return sortQuery.flatMap((sortValue: string) => convertStringSortQueryParam(sortValue));\n }\n\n if (Array.isArray(sortQuery)) {\n return sortQuery.map((sortValue) => convertNestedSortQueryParam(sortValue));\n }\n\n if (isPlainObject(sortQuery)) {\n return convertNestedSortQueryParam(sortQuery);\n }\n\n throw new InvalidSortError();\n };\n\n const convertStringSortQueryParam = (sortQuery: string): SortMap[] => {\n return sortQuery.split(',').map((value) => convertSingleSortQueryParam(value));\n };\n\n const convertSingleSortQueryParam = (sortQuery: string): SortMap => {\n if (!sortQuery) {\n return {};\n }\n\n if (!isString(sortQuery)) {\n throw new Error('Invalid sort query');\n }\n\n // split field and order param with default order to ascending\n const [field, order = 'asc'] = sortQuery.split(':');\n\n if (field.length === 0) {\n throw new Error('Field cannot be empty');\n }\n\n validateOrder(order);\n\n // TODO: field should be a valid path on an object model\n\n return _.set({}, field, order);\n };\n\n const convertNestedSortQueryParam = (sortQuery: SortParamsObject): SortMap => {\n const transformedSort: SortMap = {};\n for (const field of Object.keys(sortQuery)) {\n const order = sortQuery[field];\n\n // this is a deep sort\n if (isPlainObject(order)) {\n transformedSort[field] = convertNestedSortQueryParam(order);\n } else if (typeof order === 'string') {\n validateOrder(order);\n transformedSort[field] = order;\n } else {\n throw Error(`Invalid sort type expected object or string got ${typeof order}`);\n }\n }\n\n return transformedSort;\n };\n\n /**\n * Start query parser\n */\n const convertStartQueryParams = (startQuery: unknown): number => {\n const startAsANumber = toNumber(startQuery);\n\n if (!_.isInteger(startAsANumber) || startAsANumber < 0) {\n throw new ValidationError(\n `convertStartQueryParams expected a positive integer got ${startAsANumber}`\n );\n }\n\n return startAsANumber;\n };\n\n /**\n * Limit query parser\n */\n const convertLimitQueryParams = (limitQuery: unknown): number | undefined => {\n const limitAsANumber = toNumber(limitQuery);\n\n if (!_.isInteger(limitAsANumber) || (limitAsANumber !== -1 && limitAsANumber < 0)) {\n throw new ValidationError(\n `convertLimitQueryParams expected a positive integer got ${limitAsANumber}`\n );\n }\n\n if (limitAsANumber === -1) {\n return undefined;\n }\n\n return limitAsANumber;\n };\n\n const convertPageQueryParams = (page: unknown): number => {\n const pageVal = toNumber(page);\n\n if (!isInteger(pageVal) || pageVal <= 0) {\n throw new PaginationError(\n `Invalid 'page' parameter. Expected an integer > 0, received: ${page}`\n );\n }\n\n return pageVal;\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const convertPageSizeQueryParams = (pageSize: unknown, _page: unknown): number => {\n const pageSizeVal = toNumber(pageSize);\n\n if (!isInteger(pageSizeVal) || pageSizeVal <= 0) {\n throw new PaginationError(\n `Invalid 'pageSize' parameter. Expected an integer > 0, received: ${pageSize}`\n );\n }\n\n return pageSizeVal;\n };\n\n const validatePaginationParams = (\n page: unknown,\n pageSize: unknown,\n start: unknown,\n limit: unknown\n ) => {\n const isPagePagination = !isNil(page) || !isNil(pageSize);\n const isOffsetPagination = !isNil(start) || !isNil(limit);\n\n if (isPagePagination && isOffsetPagination) {\n throw new PaginationError(\n 'Invalid pagination attributes. The page parameters are incorrect and must be in the pagination object'\n );\n }\n };\n\n class InvalidPopulateError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid populate parameter. Expected a string, an array of strings, a populate object';\n }\n }\n\n // NOTE: we could support foo.* or foo.bar.* etc later on\n const convertPopulateQueryParams = (\n populate: PopulateParams,\n schema?: Model,\n depth = 0\n ): PopulateQuery => {\n if (depth === 0 && populate === '*') {\n return true;\n }\n\n if (typeof populate === 'string') {\n return populate.split(',').map((value) => _.trim(value));\n }\n\n if (Array.isArray(populate)) {\n // map convert\n return _.uniq(\n populate.flatMap((value) => {\n if (typeof value !== 'string') {\n throw new InvalidPopulateError();\n }\n\n return value.split(',').map((value) => _.trim(value));\n })\n );\n }\n\n if (_.isPlainObject(populate)) {\n return convertPopulateObject(populate, schema);\n }\n\n throw new InvalidPopulateError();\n };\n\n const hasPopulateFragmentDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & Required<Pick<PopulateObjectParams, 'on'>> => {\n return typeof populate === 'object' && 'on' in populate && !isNil(populate.on);\n };\n\n const hasCountDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & { count: boolean } => {\n return (\n typeof populate === 'object' && 'count' in populate && typeof populate.count === 'boolean'\n );\n };\n\n const convertPopulateObject = (populate: PopulateAttributesParams, schema?: Model) => {\n if (!schema) {\n return {};\n }\n\n const { attributes } = schema;\n return Object.entries(populate).reduce((acc, [key, subPopulate]) => {\n // Try converting strings to regular booleans if possible\n if (_.isString(subPopulate)) {\n try {\n const subPopulateAsBoolean = parseType({ type: 'boolean', value: subPopulate });\n // Only true is accepted as a boolean populate value\n return subPopulateAsBoolean ? { ...acc, [key]: true } : acc;\n } catch {\n // ignore\n }\n }\n\n if (_.isBoolean(subPopulate)) {\n // Only true is accepted as a boolean populate value\n return subPopulate === true ? { ...acc, [key]: true } : acc;\n }\n\n const attribute = attributes[key];\n\n if (!attribute) {\n return acc;\n }\n\n // Allow adding an 'on' strategy to populate queries for morphTo relations and dynamic zones\n const isMorphLikeRelationalAttribute =\n isDynamicZoneAttribute(attribute) || isMorphToRelationalAttribute(attribute);\n\n if (isMorphLikeRelationalAttribute) {\n const hasInvalidProperties = Object.keys(subPopulate).some(\n (key) => !['populate', 'on', 'count'].includes(key)\n );\n\n if (hasInvalidProperties) {\n throw new ValidationError(\n `Invalid nested populate for ${schema.info?.singularName}.${key} (${schema.uid}). Expected a fragment (\"on\") or \"count\" but found ${JSON.stringify(subPopulate)}`\n );\n }\n\n /**\n * Validate nested population queries in the context of a polymorphic attribute (dynamic zone, morph relation).\n *\n * If 'populate' exists in subPopulate, its value should be constrained to a wildcard ('*').\n */\n if ('populate' in subPopulate && subPopulate.populate !== '*') {\n throw new ValidationError(\n `Invalid nested population query detected. When using 'populate' within polymorphic structures, ` +\n `its value must be '*' to indicate all second level links. Specific field targeting is not supported here. ` +\n `Consider using the fragment API for more granular population control.`\n );\n }\n\n // TODO: Remove the possibility to have multiple properties at the same time (on/count/populate)\n const newSubPopulate = {};\n\n // case: { populate: '*' }\n if ('populate' in subPopulate) {\n Object.assign(newSubPopulate, { populate: true });\n }\n\n // case: { on: { <clauses> } }\n if (hasPopulateFragmentDefined(subPopulate)) {\n // If the fragment API is used, it applies the transformation to every\n // sub-populate, then assign the result to the new sub-populate\n Object.assign(newSubPopulate, {\n on: Object.entries(subPopulate.on).reduce(\n (acc, [type, typeSubPopulate]) => ({\n ...acc,\n [type]: convertNestedPopulate(typeSubPopulate, getModel(type)),\n }),\n {}\n ),\n });\n }\n\n // case: { count: true | false }\n if (hasCountDefined(subPopulate)) {\n Object.assign(newSubPopulate, { count: subPopulate.count });\n }\n\n return { ...acc, [key]: newSubPopulate };\n }\n\n // Edge case when trying to use the fragment ('on') on a non-morph like attribute\n if (!isMorphLikeRelationalAttribute && hasPopulateFragmentDefined(subPopulate)) {\n throw new ValidationError(\n `Using fragments is not permitted to populate \"${key}\" in \"${schema.uid}\"`\n );\n }\n\n // NOTE: Retrieve the target schema UID.\n // Only handles basic relations, medias and component since it's not possible\n // to populate with options for a dynamic zone or a polymorphic relation\n let targetSchemaUID;\n\n if (attribute.type === 'relation') {\n targetSchemaUID = attribute.target;\n } else if (attribute.type === 'component') {\n targetSchemaUID = attribute.component;\n } else if (attribute.type === 'media') {\n targetSchemaUID = 'plugin::upload.file';\n } else {\n return acc;\n }\n\n const targetSchema = getModel(targetSchemaUID!);\n\n // ignore the sub-populate for the current key if there is no schema associated\n if (!targetSchema) {\n return acc;\n }\n\n const populateObject = convertNestedPopulate(subPopulate, targetSchema);\n\n if (!populateObject) {\n return acc;\n }\n\n return {\n ...acc,\n [key]: populateObject,\n };\n }, {});\n };\n\n const convertNestedPopulate = (subPopulate: boolean | PopulateObjectParams, schema?: Model) => {\n if (_.isString(subPopulate)) {\n return parseType({ type: 'boolean', value: subPopulate, forceCast: true });\n }\n\n if (_.isBoolean(subPopulate)) {\n return subPopulate;\n }\n\n if (!isPlainObject(subPopulate)) {\n throw new ValidationError(`Invalid nested populate. Expected '*' or an object`);\n }\n\n const { sort, filters, fields, populate, count, ordering, page, pageSize, start, limit } =\n subPopulate as PopulateObjectParams;\n\n const query: Query = {};\n\n if (sort) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (filters) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (fields) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (populate) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n if (count) {\n query.count = convertCountQueryParams(count);\n }\n\n if (ordering) {\n query.ordering = convertOrderingQueryParams(ordering);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return query;\n };\n\n // TODO: ensure field is valid in content types (will probably have to check strapi.contentTypes since it can be a string.path)\n const convertFieldsQueryParams = (\n fields: FieldsParams,\n schema?: Model,\n depth = 0\n ): SelectQuery | undefined => {\n if (depth === 0 && fields === '*') {\n return undefined;\n }\n\n if (typeof fields === 'string') {\n const fieldsValues = fields.split(',').map((value) => _.trim(value));\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n if (isStringArray(fields)) {\n // map convert\n const fieldsValues = fields\n .flatMap((value) => convertFieldsQueryParams(value, schema, depth + 1))\n .filter((v) => !isNil(v)) as string[];\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n throw new ValidationError('Invalid fields parameter. Expected a string or an array of strings');\n };\n\n const isValidSchemaAttribute = (key: string, schema?: Model) => {\n if ([DOC_ID_ATTRIBUTE, ID_ATTRIBUTE].includes(key)) {\n return true;\n }\n\n if (!schema) {\n return false;\n }\n\n return Object.keys(schema.attributes).includes(key);\n };\n\n const convertFiltersQueryParams = (filters: FiltersParams, schema?: Model): WhereQuery => {\n // Filters need to be either an array or an object\n // Here we're only checking for 'object' type since typeof [] => object and typeof {} => object\n if (!isObject(filters)) {\n throw new ValidationError('The filters parameter must be an object or an array');\n }\n\n // Don't mutate the original object\n const filtersCopy = cloneDeep(filters);\n\n return convertAndSanitizeFilters(filtersCopy, schema);\n };\n\n const convertAndSanitizeFilters = (filters: FiltersParams, schema?: Model): WhereQuery => {\n if (Array.isArray(filters)) {\n return (\n filters\n // Sanitize each filter\n .map((filter) => convertAndSanitizeFilters(filter, schema))\n // Filter out empty filters\n .filter((filter) => !isPlainObject(filter) || !isEmpty(filter))\n );\n }\n\n if (!isPlainObject(filters)) {\n return filters as WhereQuery;\n }\n\n const removeOperator = (operator: string) => delete filters[operator];\n\n // Here, `key` can either be an operator or an attribute name\n for (const [key, value] of Object.entries(filters)) {\n const attribute = get(key, schema?.attributes);\n const validKey = isOperator(key) || isValidSchemaAttribute(key, schema);\n\n if (!validKey) {\n removeOperator(key);\n }\n // Handle attributes\n else if (attribute) {\n // Relations\n if (attribute.type === 'relation') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.target!));\n }\n\n // Components\n else if (attribute.type === 'component') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.component));\n }\n\n // Media\n else if (attribute.type === 'media') {\n filters[key] = convertAndSanitizeFilters(value, getModel('plugin::upload.file'));\n }\n\n // Dynamic Zones\n else if (attribute.type === 'dynamiczone') {\n removeOperator(key);\n }\n\n // Password attributes\n else if (attribute.type === 'password') {\n // Always remove password attributes from filters object\n removeOperator(key);\n }\n\n // Scalar attributes\n else {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n }\n\n // Handle operators\n else if (['$null', '$notNull'].includes(key)) {\n filters[key] = parseType({ type: 'boolean', value: filters[key], forceCast: true });\n } else if (isObject(value)) {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n\n // Remove empty objects & arrays\n if (isPlainObject(filters[key]) && isEmpty(filters[key])) {\n removeOperator(key);\n }\n }\n\n return filters;\n };\n\n const convertStatusParams = (status?: 'draft' | 'published', query: Query = {}) => {\n // NOTE: this is the query layer filters not the document/entity service filters\n query.filters = ({ meta }: { meta: Model }) => {\n const contentType = getModel(meta.uid);\n\n // Ignore if target model has disabled DP, as it doesn't make sense to filter by its status\n if (!contentType || !hasDraftAndPublish(contentType)) {\n return {};\n }\n\n return { [PUBLISHED_AT_ATTRIBUTE]: { $null: status === 'draft' } };\n };\n };\n\n const transformQueryParams = (uid: string, params: Params): Query => {\n // NOTE: can be a CT, a Compo or nothing in the case of polymorphism (DZ & morph relations)\n const schema = getModel(uid);\n\n const query: Query = {};\n\n const { _q, sort, filters, fields, populate, page, pageSize, start, limit, status, ...rest } =\n params;\n\n if (!isNil(status)) {\n convertStatusParams(status, query);\n }\n\n if (!isNil(_q)) {\n query._q = _q;\n }\n\n if (!isNil(sort)) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (!isNil(filters)) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (!isNil(fields)) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (!isNil(populate)) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return {\n ...rest,\n ...query,\n };\n };\n\n return {\n private_convertSortQueryParams: convertSortQueryParams,\n private_convertStartQueryParams: convertStartQueryParams,\n private_convertLimitQueryParams: convertLimitQueryParams,\n private_convertPopulateQueryParams: convertPopulateQueryParams,\n private_convertFiltersQueryParams: convertFiltersQueryParams,\n private_convertFieldsQueryParams: convertFieldsQueryParams,\n transformQueryParams,\n };\n};\n\nexport { createTransformer };\n"],"names":["ID_ATTRIBUTE","DOC_ID_ATTRIBUTE","PUBLISHED_AT_ATTRIBUTE","constants","InvalidOrderError","Error","message","InvalidSortError","validateOrder","order","isString","includes","toLocaleLowerCase","convertCountQueryParams","countQuery","parseType","type","value","convertOrderingQueryParams","ordering","isPlainObject","_","isStringArray","isArray","every","createTransformer","getModel","convertSortQueryParams","sortQuery","convertStringSortQueryParam","flatMap","sortValue","Array","map","convertNestedSortQueryParam","split","convertSingleSortQueryParam","field","length","set","transformedSort","Object","keys","convertStartQueryParams","startQuery","startAsANumber","toNumber","isInteger","ValidationError","convertLimitQueryParams","limitQuery","limitAsANumber","undefined","convertPageQueryParams","page","pageVal","PaginationError","convertPageSizeQueryParams","pageSize","_page","pageSizeVal","validatePaginationParams","start","limit","isPagePagination","isNil","isOffsetPagination","InvalidPopulateError","convertPopulateQueryParams","populate","schema","depth","trim","uniq","convertPopulateObject","hasPopulateFragmentDefined","on","hasCountDefined","count","attributes","entries","reduce","acc","key","subPopulate","subPopulateAsBoolean","isBoolean","attribute","isMorphLikeRelationalAttribute","isDynamicZoneAttribute","isMorphToRelationalAttribute","hasInvalidProperties","some","info","singularName","uid","JSON","stringify","newSubPopulate","assign","typeSubPopulate","convertNestedPopulate","targetSchemaUID","target","component","targetSchema","populateObject","forceCast","sort","filters","fields","query","orderBy","where","convertFiltersQueryParams","select","convertFieldsQueryParams","offset","fieldsValues","modelType","filter","v","isValidSchemaAttribute","isObject","filtersCopy","cloneDeep","convertAndSanitizeFilters","isEmpty","removeOperator","operator","get","validKey","isOperator","convertStatusParams","status","meta","contentType","hasDraftAndPublish","$null","transformQueryParams","params","_q","rest","private_convertSortQueryParams","private_convertStartQueryParams","private_convertLimitQueryParams","private_convertPopulateQueryParams","private_convertFiltersQueryParams","private_convertFieldsQueryParams"],"mappings":"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"}
1
+ {"version":3,"file":"convert-query-params.js","sources":["../src/convert-query-params.ts"],"sourcesContent":["/* eslint-disable max-classes-per-file */\n\n/**\n * Converts the standard Strapi REST query params to a more usable format for querying\n * You can read more here: https://docs.strapi.io/developer-docs/latest/developer-resources/database-apis-reference/rest-api.html#filters\n */\n\nimport _ from 'lodash';\nimport {\n cloneDeep,\n get,\n isArray,\n isEmpty,\n isInteger,\n isNil,\n isObject,\n isString,\n toNumber,\n} from 'lodash/fp';\nimport {\n constants,\n hasDraftAndPublish,\n isDynamicZoneAttribute,\n isMorphToRelationalAttribute,\n} from './content-types';\nimport { PaginationError, ValidationError } from './errors';\nimport { isOperator } from './operators';\n\nimport parseType from './parse-type';\nimport type { PublicationFilterMode } from './publication-filter';\nimport { Model } from './types';\n\nconst { ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, PUBLISHED_AT_ATTRIBUTE } = constants;\n\ntype SortOrder = 'asc' | 'desc';\n\nexport interface SortMap {\n [key: string]: SortOrder | SortMap;\n}\n\nexport interface SortParamsObject {\n [key: string]: SortOrder | SortParamsObject;\n}\n\ntype SortParams = string | string[] | SortParamsObject | SortParamsObject[];\ntype FieldsParams = string | string[];\n\ntype FiltersParams = unknown;\n\nexport interface PopulateAttributesParams {\n [key: string]: boolean | PopulateObjectParams;\n}\n\nexport interface PopulateObjectParams {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: string | string[] | PopulateAttributesParams;\n on?: PopulateAttributesParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n}\n\ntype PopulateParams = string | string[] | PopulateAttributesParams;\n\nexport interface Params {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: PopulateParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n status?: 'draft' | 'published';\n publicationFilter?: PublicationFilterMode;\n /**\n * @deprecated Replaced by `publicationFilter` (`never-published`, `has-published-version`, …).\n * Retained for backward compatibility with existing REST and GraphQL clients.\n */\n hasPublishedVersion?: boolean | 'true' | 'false';\n}\n\ntype FiltersQuery = (options: { meta: Model }) => WhereQuery | undefined;\ntype OrderByQuery = SortMap | SortMap[];\ntype SelectQuery = string | string[];\n\nexport interface WhereQuery {\n [key: string]: any;\n}\n\ntype PopulateQuery =\n | boolean\n | string[]\n | {\n [key: string]: PopulateQuery;\n };\n\nexport interface Query {\n orderBy?: OrderByQuery;\n select?: SelectQuery;\n where?: WhereQuery;\n // NOTE: those are internal DB filters do not modify\n filters?: FiltersQuery;\n populate?: PopulateQuery;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number;\n offset?: number;\n page?: number;\n pageSize?: number;\n}\n\nclass InvalidOrderError extends Error {\n constructor() {\n super();\n this.message = 'Invalid order. order can only be one of asc|desc|ASC|DESC';\n }\n}\n\nclass InvalidSortError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid sort parameter. Expected a string, an array of strings, a sort object or an array of sort objects';\n }\n}\n\nfunction validateOrder(order: string): asserts order is SortOrder {\n if (!isString(order) || !['asc', 'desc'].includes(order.toLocaleLowerCase())) {\n throw new InvalidOrderError();\n }\n}\n\nconst convertCountQueryParams = (countQuery: unknown): boolean => {\n return parseType({ type: 'boolean', value: countQuery });\n};\n\nconst convertOrderingQueryParams = (ordering: unknown) => {\n return ordering;\n};\n\nconst isPlainObject = (value: unknown): value is Record<string, unknown> => _.isPlainObject(value);\nconst isStringArray = (value: unknown): value is string[] =>\n isArray(value) && value.every(isString);\n\ninterface TransformerOptions {\n getModel: (uid: string) => Model | undefined;\n}\n\nconst createTransformer = ({ getModel }: TransformerOptions) => {\n /**\n * Sort query parser\n */\n const convertSortQueryParams = (sortQuery: SortParams): OrderByQuery => {\n if (typeof sortQuery === 'string') {\n return convertStringSortQueryParam(sortQuery);\n }\n\n if (isStringArray(sortQuery)) {\n return sortQuery.flatMap((sortValue: string) => convertStringSortQueryParam(sortValue));\n }\n\n if (Array.isArray(sortQuery)) {\n return sortQuery.map((sortValue) => convertNestedSortQueryParam(sortValue));\n }\n\n if (isPlainObject(sortQuery)) {\n return convertNestedSortQueryParam(sortQuery);\n }\n\n throw new InvalidSortError();\n };\n\n const convertStringSortQueryParam = (sortQuery: string): SortMap[] => {\n return sortQuery.split(',').map((value) => convertSingleSortQueryParam(value));\n };\n\n const convertSingleSortQueryParam = (sortQuery: string): SortMap => {\n if (!sortQuery) {\n return {};\n }\n\n if (!isString(sortQuery)) {\n throw new Error('Invalid sort query');\n }\n\n // split field and order param with default order to ascending\n const [field, order = 'asc'] = sortQuery.split(':');\n\n if (field.length === 0) {\n throw new Error('Field cannot be empty');\n }\n\n validateOrder(order);\n\n // TODO: field should be a valid path on an object model\n\n return _.set({}, field, order);\n };\n\n const convertNestedSortQueryParam = (sortQuery: SortParamsObject): SortMap => {\n const transformedSort: SortMap = {};\n for (const field of Object.keys(sortQuery)) {\n const order = sortQuery[field];\n\n // this is a deep sort\n if (isPlainObject(order)) {\n transformedSort[field] = convertNestedSortQueryParam(order);\n } else if (typeof order === 'string') {\n validateOrder(order);\n transformedSort[field] = order;\n } else {\n throw Error(`Invalid sort type expected object or string got ${typeof order}`);\n }\n }\n\n return transformedSort;\n };\n\n /**\n * Start query parser\n */\n const convertStartQueryParams = (startQuery: unknown): number => {\n const startAsANumber = toNumber(startQuery);\n\n if (!_.isInteger(startAsANumber) || startAsANumber < 0) {\n throw new ValidationError(\n `convertStartQueryParams expected a positive integer got ${startAsANumber}`\n );\n }\n\n return startAsANumber;\n };\n\n /**\n * Limit query parser\n */\n const convertLimitQueryParams = (limitQuery: unknown): number | undefined => {\n const limitAsANumber = toNumber(limitQuery);\n\n if (!_.isInteger(limitAsANumber) || (limitAsANumber !== -1 && limitAsANumber < 0)) {\n throw new ValidationError(\n `convertLimitQueryParams expected a positive integer got ${limitAsANumber}`\n );\n }\n\n if (limitAsANumber === -1) {\n return undefined;\n }\n\n return limitAsANumber;\n };\n\n const convertPageQueryParams = (page: unknown): number => {\n const pageVal = toNumber(page);\n\n if (!isInteger(pageVal) || pageVal <= 0) {\n throw new PaginationError(\n `Invalid 'page' parameter. Expected an integer > 0, received: ${page}`\n );\n }\n\n return pageVal;\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const convertPageSizeQueryParams = (pageSize: unknown, _page: unknown): number => {\n const pageSizeVal = toNumber(pageSize);\n\n if (!isInteger(pageSizeVal) || pageSizeVal <= 0) {\n throw new PaginationError(\n `Invalid 'pageSize' parameter. Expected an integer > 0, received: ${pageSize}`\n );\n }\n\n return pageSizeVal;\n };\n\n const validatePaginationParams = (\n page: unknown,\n pageSize: unknown,\n start: unknown,\n limit: unknown\n ) => {\n const isPagePagination = !isNil(page) || !isNil(pageSize);\n const isOffsetPagination = !isNil(start) || !isNil(limit);\n\n if (isPagePagination && isOffsetPagination) {\n throw new PaginationError(\n 'Invalid pagination attributes. The page parameters are incorrect and must be in the pagination object'\n );\n }\n };\n\n class InvalidPopulateError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid populate parameter. Expected a string, an array of strings, a populate object';\n }\n }\n\n // NOTE: we could support foo.* or foo.bar.* etc later on\n const convertPopulateQueryParams = (\n populate: PopulateParams,\n schema?: Model,\n depth = 0\n ): PopulateQuery => {\n if (depth === 0 && populate === '*') {\n return true;\n }\n\n if (typeof populate === 'string') {\n return populate.split(',').map((value) => _.trim(value));\n }\n\n if (Array.isArray(populate)) {\n // map convert\n return _.uniq(\n populate.flatMap((value) => {\n if (typeof value !== 'string') {\n throw new InvalidPopulateError();\n }\n\n return value.split(',').map((value) => _.trim(value));\n })\n );\n }\n\n if (_.isPlainObject(populate)) {\n return convertPopulateObject(populate, schema);\n }\n\n throw new InvalidPopulateError();\n };\n\n const hasPopulateFragmentDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & Required<Pick<PopulateObjectParams, 'on'>> => {\n return typeof populate === 'object' && 'on' in populate && !isNil(populate.on);\n };\n\n const hasCountDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & { count: boolean } => {\n return (\n typeof populate === 'object' && 'count' in populate && typeof populate.count === 'boolean'\n );\n };\n\n const convertPopulateObject = (populate: PopulateAttributesParams, schema?: Model) => {\n if (!schema) {\n return {};\n }\n\n const { attributes } = schema;\n return Object.entries(populate).reduce((acc, [key, subPopulate]) => {\n // Try converting strings to regular booleans if possible\n if (_.isString(subPopulate)) {\n try {\n const subPopulateAsBoolean = parseType({ type: 'boolean', value: subPopulate });\n // Only true is accepted as a boolean populate value\n return subPopulateAsBoolean ? { ...acc, [key]: true } : acc;\n } catch {\n // ignore\n }\n }\n\n if (_.isBoolean(subPopulate)) {\n // Only true is accepted as a boolean populate value\n return subPopulate === true ? { ...acc, [key]: true } : acc;\n }\n\n const attribute = attributes[key];\n\n if (!attribute) {\n return acc;\n }\n\n // Allow adding an 'on' strategy to populate queries for morphTo relations and dynamic zones\n const isMorphLikeRelationalAttribute =\n isDynamicZoneAttribute(attribute) || isMorphToRelationalAttribute(attribute);\n\n if (isMorphLikeRelationalAttribute) {\n const hasInvalidProperties = Object.keys(subPopulate).some(\n (key) => !['populate', 'on', 'count'].includes(key)\n );\n\n if (hasInvalidProperties) {\n throw new ValidationError(\n `Invalid nested populate for ${schema.info?.singularName}.${key} (${schema.uid}). Expected a fragment (\"on\") or \"count\" but found ${JSON.stringify(subPopulate)}`\n );\n }\n\n /**\n * Validate nested population queries in the context of a polymorphic attribute (dynamic zone, morph relation).\n *\n * If 'populate' exists in subPopulate, its value should be constrained to a wildcard ('*').\n */\n if ('populate' in subPopulate && subPopulate.populate !== '*') {\n throw new ValidationError(\n `Invalid nested population query detected. When using 'populate' within polymorphic structures, ` +\n `its value must be '*' to indicate all second level links. Specific field targeting is not supported here. ` +\n `Consider using the fragment API for more granular population control.`\n );\n }\n\n // TODO: Remove the possibility to have multiple properties at the same time (on/count/populate)\n const newSubPopulate = {};\n\n // case: { populate: '*' }\n if ('populate' in subPopulate) {\n Object.assign(newSubPopulate, { populate: true });\n }\n\n // case: { on: { <clauses> } }\n if (hasPopulateFragmentDefined(subPopulate)) {\n // If the fragment API is used, it applies the transformation to every\n // sub-populate, then assign the result to the new sub-populate\n Object.assign(newSubPopulate, {\n on: Object.entries(subPopulate.on).reduce(\n (acc, [type, typeSubPopulate]) => ({\n ...acc,\n [type]: convertNestedPopulate(typeSubPopulate, getModel(type)),\n }),\n {}\n ),\n });\n }\n\n // case: { count: true | false }\n if (hasCountDefined(subPopulate)) {\n Object.assign(newSubPopulate, { count: subPopulate.count });\n }\n\n return { ...acc, [key]: newSubPopulate };\n }\n\n // Edge case when trying to use the fragment ('on') on a non-morph like attribute\n if (!isMorphLikeRelationalAttribute && hasPopulateFragmentDefined(subPopulate)) {\n throw new ValidationError(\n `Using fragments is not permitted to populate \"${key}\" in \"${schema.uid}\"`\n );\n }\n\n // NOTE: Retrieve the target schema UID.\n // Only handles basic relations, medias and component since it's not possible\n // to populate with options for a dynamic zone or a polymorphic relation\n let targetSchemaUID;\n\n if (attribute.type === 'relation') {\n targetSchemaUID = attribute.target;\n } else if (attribute.type === 'component') {\n targetSchemaUID = attribute.component;\n } else if (attribute.type === 'media') {\n targetSchemaUID = 'plugin::upload.file';\n } else {\n return acc;\n }\n\n const targetSchema = getModel(targetSchemaUID!);\n\n // ignore the sub-populate for the current key if there is no schema associated\n if (!targetSchema) {\n return acc;\n }\n\n const populateObject = convertNestedPopulate(subPopulate, targetSchema);\n\n if (!populateObject) {\n return acc;\n }\n\n return {\n ...acc,\n [key]: populateObject,\n };\n }, {});\n };\n\n const convertNestedPopulate = (subPopulate: boolean | PopulateObjectParams, schema?: Model) => {\n if (_.isString(subPopulate)) {\n return parseType({ type: 'boolean', value: subPopulate, forceCast: true });\n }\n\n if (_.isBoolean(subPopulate)) {\n return subPopulate;\n }\n\n if (!isPlainObject(subPopulate)) {\n throw new ValidationError(`Invalid nested populate. Expected '*' or an object`);\n }\n\n const { sort, filters, fields, populate, count, ordering, page, pageSize, start, limit } =\n subPopulate as PopulateObjectParams;\n\n const query: Query = {};\n\n if (sort) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (filters) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (fields) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (populate) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n if (count) {\n query.count = convertCountQueryParams(count);\n }\n\n if (ordering) {\n query.ordering = convertOrderingQueryParams(ordering);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return query;\n };\n\n // TODO: ensure field is valid in content types (will probably have to check strapi.contentTypes since it can be a string.path)\n const convertFieldsQueryParams = (\n fields: FieldsParams,\n schema?: Model,\n depth = 0\n ): SelectQuery | undefined => {\n if (depth === 0 && fields === '*') {\n return undefined;\n }\n\n if (typeof fields === 'string') {\n const fieldsValues = fields.split(',').map((value) => _.trim(value));\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n if (isStringArray(fields)) {\n // map convert\n const fieldsValues = fields\n .flatMap((value) => convertFieldsQueryParams(value, schema, depth + 1))\n .filter((v) => !isNil(v)) as string[];\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n throw new ValidationError('Invalid fields parameter. Expected a string or an array of strings');\n };\n\n const isValidSchemaAttribute = (key: string, schema?: Model) => {\n if ([DOC_ID_ATTRIBUTE, ID_ATTRIBUTE].includes(key)) {\n return true;\n }\n\n if (!schema) {\n return false;\n }\n\n return Object.keys(schema.attributes).includes(key);\n };\n\n const convertFiltersQueryParams = (filters: FiltersParams, schema?: Model): WhereQuery => {\n // Filters need to be either an array or an object\n // Here we're only checking for 'object' type since typeof [] => object and typeof {} => object\n if (!isObject(filters)) {\n throw new ValidationError('The filters parameter must be an object or an array');\n }\n\n // Don't mutate the original object\n const filtersCopy = cloneDeep(filters);\n\n return convertAndSanitizeFilters(filtersCopy, schema);\n };\n\n const convertAndSanitizeFilters = (filters: FiltersParams, schema?: Model): WhereQuery => {\n if (Array.isArray(filters)) {\n return (\n filters\n // Sanitize each filter\n .map((filter) => convertAndSanitizeFilters(filter, schema))\n // Filter out empty filters\n .filter((filter) => !isPlainObject(filter) || !isEmpty(filter))\n );\n }\n\n if (!isPlainObject(filters)) {\n return filters as WhereQuery;\n }\n\n const removeOperator = (operator: string) => delete filters[operator];\n\n // Here, `key` can either be an operator or an attribute name\n for (const [key, value] of Object.entries(filters)) {\n const attribute = get(key, schema?.attributes);\n const validKey = isOperator(key) || isValidSchemaAttribute(key, schema);\n\n if (!validKey) {\n removeOperator(key);\n }\n // Handle attributes\n else if (attribute) {\n // Relations\n if (attribute.type === 'relation') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.target!));\n }\n\n // Components\n else if (attribute.type === 'component') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.component));\n }\n\n // Media\n else if (attribute.type === 'media') {\n filters[key] = convertAndSanitizeFilters(value, getModel('plugin::upload.file'));\n }\n\n // Dynamic Zones\n else if (attribute.type === 'dynamiczone') {\n removeOperator(key);\n }\n\n // Password attributes\n else if (attribute.type === 'password') {\n // Always remove password attributes from filters object\n removeOperator(key);\n }\n\n // Scalar attributes\n else {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n }\n\n // Handle operators\n else if (['$null', '$notNull'].includes(key)) {\n filters[key] = parseType({ type: 'boolean', value: filters[key], forceCast: true });\n } else if (isObject(value)) {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n\n // Remove empty objects & arrays\n if (isPlainObject(filters[key]) && isEmpty(filters[key])) {\n removeOperator(key);\n }\n }\n\n return filters;\n };\n\n const convertStatusParams = (status?: 'draft' | 'published', query: Query = {}) => {\n // NOTE: this is the query layer filters not the document/entity service filters\n query.filters = ({ meta }: { meta: Model }) => {\n const contentType = getModel(meta.uid);\n\n // Ignore if target model has disabled DP, as it doesn't make sense to filter by its status\n if (!contentType || !hasDraftAndPublish(contentType)) {\n return {};\n }\n\n return { [PUBLISHED_AT_ATTRIBUTE]: { $null: status === 'draft' } };\n };\n };\n\n const transformQueryParams = (uid: string, params: Params): Query => {\n // NOTE: can be a CT, a Compo or nothing in the case of polymorphism (DZ & morph relations)\n const schema = getModel(uid);\n\n const query: Query = {};\n\n const { _q, sort, filters, fields, populate, page, pageSize, start, limit, status, ...rest } =\n params;\n\n if (!isNil(status)) {\n convertStatusParams(status, query);\n }\n\n if (!isNil(_q)) {\n query._q = _q;\n }\n\n if (!isNil(sort)) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (!isNil(filters)) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (!isNil(fields)) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (!isNil(populate)) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return {\n ...rest,\n ...query,\n };\n };\n\n return {\n private_convertSortQueryParams: convertSortQueryParams,\n private_convertStartQueryParams: convertStartQueryParams,\n private_convertLimitQueryParams: convertLimitQueryParams,\n private_convertPopulateQueryParams: convertPopulateQueryParams,\n private_convertFiltersQueryParams: convertFiltersQueryParams,\n private_convertFieldsQueryParams: convertFieldsQueryParams,\n transformQueryParams,\n };\n};\n\nexport { createTransformer };\n"],"names":["ID_ATTRIBUTE","DOC_ID_ATTRIBUTE","PUBLISHED_AT_ATTRIBUTE","constants","InvalidOrderError","Error","message","InvalidSortError","validateOrder","order","isString","includes","toLocaleLowerCase","convertCountQueryParams","countQuery","parseType","type","value","convertOrderingQueryParams","ordering","isPlainObject","_","isStringArray","isArray","every","createTransformer","getModel","convertSortQueryParams","sortQuery","convertStringSortQueryParam","flatMap","sortValue","Array","map","convertNestedSortQueryParam","split","convertSingleSortQueryParam","field","length","set","transformedSort","Object","keys","convertStartQueryParams","startQuery","startAsANumber","toNumber","isInteger","ValidationError","convertLimitQueryParams","limitQuery","limitAsANumber","undefined","convertPageQueryParams","page","pageVal","PaginationError","convertPageSizeQueryParams","pageSize","_page","pageSizeVal","validatePaginationParams","start","limit","isPagePagination","isNil","isOffsetPagination","InvalidPopulateError","convertPopulateQueryParams","populate","schema","depth","trim","uniq","convertPopulateObject","hasPopulateFragmentDefined","on","hasCountDefined","count","attributes","entries","reduce","acc","key","subPopulate","subPopulateAsBoolean","isBoolean","attribute","isMorphLikeRelationalAttribute","isDynamicZoneAttribute","isMorphToRelationalAttribute","hasInvalidProperties","some","info","singularName","uid","JSON","stringify","newSubPopulate","assign","typeSubPopulate","convertNestedPopulate","targetSchemaUID","target","component","targetSchema","populateObject","forceCast","sort","filters","fields","query","orderBy","where","convertFiltersQueryParams","select","convertFieldsQueryParams","offset","fieldsValues","modelType","filter","v","isValidSchemaAttribute","isObject","filtersCopy","cloneDeep","convertAndSanitizeFilters","isEmpty","removeOperator","operator","get","validKey","isOperator","convertStatusParams","status","meta","contentType","hasDraftAndPublish","$null","transformQueryParams","params","_q","rest","private_convertSortQueryParams","private_convertStartQueryParams","private_convertLimitQueryParams","private_convertPopulateQueryParams","private_convertFiltersQueryParams","private_convertFieldsQueryParams"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"convert-query-params.mjs","sources":["../src/convert-query-params.ts"],"sourcesContent":["/* eslint-disable max-classes-per-file */\n\n/**\n * Converts the standard Strapi REST query params to a more usable format for querying\n * You can read more here: https://docs.strapi.io/developer-docs/latest/developer-resources/database-apis-reference/rest-api.html#filters\n */\n\nimport _ from 'lodash';\nimport {\n cloneDeep,\n get,\n isArray,\n isEmpty,\n isInteger,\n isNil,\n isObject,\n isString,\n toNumber,\n} from 'lodash/fp';\nimport {\n constants,\n hasDraftAndPublish,\n isDynamicZoneAttribute,\n isMorphToRelationalAttribute,\n} from './content-types';\nimport { PaginationError, ValidationError } from './errors';\nimport { isOperator } from './operators';\n\nimport parseType from './parse-type';\nimport { Model } from './types';\n\nconst { ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, PUBLISHED_AT_ATTRIBUTE } = constants;\n\ntype SortOrder = 'asc' | 'desc';\n\nexport interface SortMap {\n [key: string]: SortOrder | SortMap;\n}\n\nexport interface SortParamsObject {\n [key: string]: SortOrder | SortParamsObject;\n}\n\ntype SortParams = string | string[] | SortParamsObject | SortParamsObject[];\ntype FieldsParams = string | string[];\n\ntype FiltersParams = unknown;\n\nexport interface PopulateAttributesParams {\n [key: string]: boolean | PopulateObjectParams;\n}\n\nexport interface PopulateObjectParams {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: string | string[] | PopulateAttributesParams;\n on?: PopulateAttributesParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n}\n\ntype PopulateParams = string | string[] | PopulateAttributesParams;\n\nexport interface Params {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: PopulateParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n status?: 'draft' | 'published';\n /**\n * Filter documents by whether they have a published version.\n * Use with `status: 'draft'` to find documents that have never been published.\n */\n hasPublishedVersion?: boolean | 'true' | 'false';\n}\n\ntype FiltersQuery = (options: { meta: Model }) => WhereQuery | undefined;\ntype OrderByQuery = SortMap | SortMap[];\ntype SelectQuery = string | string[];\n\nexport interface WhereQuery {\n [key: string]: any;\n}\n\ntype PopulateQuery =\n | boolean\n | string[]\n | {\n [key: string]: PopulateQuery;\n };\n\nexport interface Query {\n orderBy?: OrderByQuery;\n select?: SelectQuery;\n where?: WhereQuery;\n // NOTE: those are internal DB filters do not modify\n filters?: FiltersQuery;\n populate?: PopulateQuery;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number;\n offset?: number;\n page?: number;\n pageSize?: number;\n}\n\nclass InvalidOrderError extends Error {\n constructor() {\n super();\n this.message = 'Invalid order. order can only be one of asc|desc|ASC|DESC';\n }\n}\n\nclass InvalidSortError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid sort parameter. Expected a string, an array of strings, a sort object or an array of sort objects';\n }\n}\n\nfunction validateOrder(order: string): asserts order is SortOrder {\n if (!isString(order) || !['asc', 'desc'].includes(order.toLocaleLowerCase())) {\n throw new InvalidOrderError();\n }\n}\n\nconst convertCountQueryParams = (countQuery: unknown): boolean => {\n return parseType({ type: 'boolean', value: countQuery });\n};\n\nconst convertOrderingQueryParams = (ordering: unknown) => {\n return ordering;\n};\n\nconst isPlainObject = (value: unknown): value is Record<string, unknown> => _.isPlainObject(value);\nconst isStringArray = (value: unknown): value is string[] =>\n isArray(value) && value.every(isString);\n\ninterface TransformerOptions {\n getModel: (uid: string) => Model | undefined;\n}\n\nconst createTransformer = ({ getModel }: TransformerOptions) => {\n /**\n * Sort query parser\n */\n const convertSortQueryParams = (sortQuery: SortParams): OrderByQuery => {\n if (typeof sortQuery === 'string') {\n return convertStringSortQueryParam(sortQuery);\n }\n\n if (isStringArray(sortQuery)) {\n return sortQuery.flatMap((sortValue: string) => convertStringSortQueryParam(sortValue));\n }\n\n if (Array.isArray(sortQuery)) {\n return sortQuery.map((sortValue) => convertNestedSortQueryParam(sortValue));\n }\n\n if (isPlainObject(sortQuery)) {\n return convertNestedSortQueryParam(sortQuery);\n }\n\n throw new InvalidSortError();\n };\n\n const convertStringSortQueryParam = (sortQuery: string): SortMap[] => {\n return sortQuery.split(',').map((value) => convertSingleSortQueryParam(value));\n };\n\n const convertSingleSortQueryParam = (sortQuery: string): SortMap => {\n if (!sortQuery) {\n return {};\n }\n\n if (!isString(sortQuery)) {\n throw new Error('Invalid sort query');\n }\n\n // split field and order param with default order to ascending\n const [field, order = 'asc'] = sortQuery.split(':');\n\n if (field.length === 0) {\n throw new Error('Field cannot be empty');\n }\n\n validateOrder(order);\n\n // TODO: field should be a valid path on an object model\n\n return _.set({}, field, order);\n };\n\n const convertNestedSortQueryParam = (sortQuery: SortParamsObject): SortMap => {\n const transformedSort: SortMap = {};\n for (const field of Object.keys(sortQuery)) {\n const order = sortQuery[field];\n\n // this is a deep sort\n if (isPlainObject(order)) {\n transformedSort[field] = convertNestedSortQueryParam(order);\n } else if (typeof order === 'string') {\n validateOrder(order);\n transformedSort[field] = order;\n } else {\n throw Error(`Invalid sort type expected object or string got ${typeof order}`);\n }\n }\n\n return transformedSort;\n };\n\n /**\n * Start query parser\n */\n const convertStartQueryParams = (startQuery: unknown): number => {\n const startAsANumber = toNumber(startQuery);\n\n if (!_.isInteger(startAsANumber) || startAsANumber < 0) {\n throw new ValidationError(\n `convertStartQueryParams expected a positive integer got ${startAsANumber}`\n );\n }\n\n return startAsANumber;\n };\n\n /**\n * Limit query parser\n */\n const convertLimitQueryParams = (limitQuery: unknown): number | undefined => {\n const limitAsANumber = toNumber(limitQuery);\n\n if (!_.isInteger(limitAsANumber) || (limitAsANumber !== -1 && limitAsANumber < 0)) {\n throw new ValidationError(\n `convertLimitQueryParams expected a positive integer got ${limitAsANumber}`\n );\n }\n\n if (limitAsANumber === -1) {\n return undefined;\n }\n\n return limitAsANumber;\n };\n\n const convertPageQueryParams = (page: unknown): number => {\n const pageVal = toNumber(page);\n\n if (!isInteger(pageVal) || pageVal <= 0) {\n throw new PaginationError(\n `Invalid 'page' parameter. Expected an integer > 0, received: ${page}`\n );\n }\n\n return pageVal;\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const convertPageSizeQueryParams = (pageSize: unknown, _page: unknown): number => {\n const pageSizeVal = toNumber(pageSize);\n\n if (!isInteger(pageSizeVal) || pageSizeVal <= 0) {\n throw new PaginationError(\n `Invalid 'pageSize' parameter. Expected an integer > 0, received: ${pageSize}`\n );\n }\n\n return pageSizeVal;\n };\n\n const validatePaginationParams = (\n page: unknown,\n pageSize: unknown,\n start: unknown,\n limit: unknown\n ) => {\n const isPagePagination = !isNil(page) || !isNil(pageSize);\n const isOffsetPagination = !isNil(start) || !isNil(limit);\n\n if (isPagePagination && isOffsetPagination) {\n throw new PaginationError(\n 'Invalid pagination attributes. The page parameters are incorrect and must be in the pagination object'\n );\n }\n };\n\n class InvalidPopulateError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid populate parameter. Expected a string, an array of strings, a populate object';\n }\n }\n\n // NOTE: we could support foo.* or foo.bar.* etc later on\n const convertPopulateQueryParams = (\n populate: PopulateParams,\n schema?: Model,\n depth = 0\n ): PopulateQuery => {\n if (depth === 0 && populate === '*') {\n return true;\n }\n\n if (typeof populate === 'string') {\n return populate.split(',').map((value) => _.trim(value));\n }\n\n if (Array.isArray(populate)) {\n // map convert\n return _.uniq(\n populate.flatMap((value) => {\n if (typeof value !== 'string') {\n throw new InvalidPopulateError();\n }\n\n return value.split(',').map((value) => _.trim(value));\n })\n );\n }\n\n if (_.isPlainObject(populate)) {\n return convertPopulateObject(populate, schema);\n }\n\n throw new InvalidPopulateError();\n };\n\n const hasPopulateFragmentDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & Required<Pick<PopulateObjectParams, 'on'>> => {\n return typeof populate === 'object' && 'on' in populate && !isNil(populate.on);\n };\n\n const hasCountDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & { count: boolean } => {\n return (\n typeof populate === 'object' && 'count' in populate && typeof populate.count === 'boolean'\n );\n };\n\n const convertPopulateObject = (populate: PopulateAttributesParams, schema?: Model) => {\n if (!schema) {\n return {};\n }\n\n const { attributes } = schema;\n return Object.entries(populate).reduce((acc, [key, subPopulate]) => {\n // Try converting strings to regular booleans if possible\n if (_.isString(subPopulate)) {\n try {\n const subPopulateAsBoolean = parseType({ type: 'boolean', value: subPopulate });\n // Only true is accepted as a boolean populate value\n return subPopulateAsBoolean ? { ...acc, [key]: true } : acc;\n } catch {\n // ignore\n }\n }\n\n if (_.isBoolean(subPopulate)) {\n // Only true is accepted as a boolean populate value\n return subPopulate === true ? { ...acc, [key]: true } : acc;\n }\n\n const attribute = attributes[key];\n\n if (!attribute) {\n return acc;\n }\n\n // Allow adding an 'on' strategy to populate queries for morphTo relations and dynamic zones\n const isMorphLikeRelationalAttribute =\n isDynamicZoneAttribute(attribute) || isMorphToRelationalAttribute(attribute);\n\n if (isMorphLikeRelationalAttribute) {\n const hasInvalidProperties = Object.keys(subPopulate).some(\n (key) => !['populate', 'on', 'count'].includes(key)\n );\n\n if (hasInvalidProperties) {\n throw new ValidationError(\n `Invalid nested populate for ${schema.info?.singularName}.${key} (${schema.uid}). Expected a fragment (\"on\") or \"count\" but found ${JSON.stringify(subPopulate)}`\n );\n }\n\n /**\n * Validate nested population queries in the context of a polymorphic attribute (dynamic zone, morph relation).\n *\n * If 'populate' exists in subPopulate, its value should be constrained to a wildcard ('*').\n */\n if ('populate' in subPopulate && subPopulate.populate !== '*') {\n throw new ValidationError(\n `Invalid nested population query detected. When using 'populate' within polymorphic structures, ` +\n `its value must be '*' to indicate all second level links. Specific field targeting is not supported here. ` +\n `Consider using the fragment API for more granular population control.`\n );\n }\n\n // TODO: Remove the possibility to have multiple properties at the same time (on/count/populate)\n const newSubPopulate = {};\n\n // case: { populate: '*' }\n if ('populate' in subPopulate) {\n Object.assign(newSubPopulate, { populate: true });\n }\n\n // case: { on: { <clauses> } }\n if (hasPopulateFragmentDefined(subPopulate)) {\n // If the fragment API is used, it applies the transformation to every\n // sub-populate, then assign the result to the new sub-populate\n Object.assign(newSubPopulate, {\n on: Object.entries(subPopulate.on).reduce(\n (acc, [type, typeSubPopulate]) => ({\n ...acc,\n [type]: convertNestedPopulate(typeSubPopulate, getModel(type)),\n }),\n {}\n ),\n });\n }\n\n // case: { count: true | false }\n if (hasCountDefined(subPopulate)) {\n Object.assign(newSubPopulate, { count: subPopulate.count });\n }\n\n return { ...acc, [key]: newSubPopulate };\n }\n\n // Edge case when trying to use the fragment ('on') on a non-morph like attribute\n if (!isMorphLikeRelationalAttribute && hasPopulateFragmentDefined(subPopulate)) {\n throw new ValidationError(\n `Using fragments is not permitted to populate \"${key}\" in \"${schema.uid}\"`\n );\n }\n\n // NOTE: Retrieve the target schema UID.\n // Only handles basic relations, medias and component since it's not possible\n // to populate with options for a dynamic zone or a polymorphic relation\n let targetSchemaUID;\n\n if (attribute.type === 'relation') {\n targetSchemaUID = attribute.target;\n } else if (attribute.type === 'component') {\n targetSchemaUID = attribute.component;\n } else if (attribute.type === 'media') {\n targetSchemaUID = 'plugin::upload.file';\n } else {\n return acc;\n }\n\n const targetSchema = getModel(targetSchemaUID!);\n\n // ignore the sub-populate for the current key if there is no schema associated\n if (!targetSchema) {\n return acc;\n }\n\n const populateObject = convertNestedPopulate(subPopulate, targetSchema);\n\n if (!populateObject) {\n return acc;\n }\n\n return {\n ...acc,\n [key]: populateObject,\n };\n }, {});\n };\n\n const convertNestedPopulate = (subPopulate: boolean | PopulateObjectParams, schema?: Model) => {\n if (_.isString(subPopulate)) {\n return parseType({ type: 'boolean', value: subPopulate, forceCast: true });\n }\n\n if (_.isBoolean(subPopulate)) {\n return subPopulate;\n }\n\n if (!isPlainObject(subPopulate)) {\n throw new ValidationError(`Invalid nested populate. Expected '*' or an object`);\n }\n\n const { sort, filters, fields, populate, count, ordering, page, pageSize, start, limit } =\n subPopulate as PopulateObjectParams;\n\n const query: Query = {};\n\n if (sort) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (filters) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (fields) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (populate) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n if (count) {\n query.count = convertCountQueryParams(count);\n }\n\n if (ordering) {\n query.ordering = convertOrderingQueryParams(ordering);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return query;\n };\n\n // TODO: ensure field is valid in content types (will probably have to check strapi.contentTypes since it can be a string.path)\n const convertFieldsQueryParams = (\n fields: FieldsParams,\n schema?: Model,\n depth = 0\n ): SelectQuery | undefined => {\n if (depth === 0 && fields === '*') {\n return undefined;\n }\n\n if (typeof fields === 'string') {\n const fieldsValues = fields.split(',').map((value) => _.trim(value));\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n if (isStringArray(fields)) {\n // map convert\n const fieldsValues = fields\n .flatMap((value) => convertFieldsQueryParams(value, schema, depth + 1))\n .filter((v) => !isNil(v)) as string[];\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n throw new ValidationError('Invalid fields parameter. Expected a string or an array of strings');\n };\n\n const isValidSchemaAttribute = (key: string, schema?: Model) => {\n if ([DOC_ID_ATTRIBUTE, ID_ATTRIBUTE].includes(key)) {\n return true;\n }\n\n if (!schema) {\n return false;\n }\n\n return Object.keys(schema.attributes).includes(key);\n };\n\n const convertFiltersQueryParams = (filters: FiltersParams, schema?: Model): WhereQuery => {\n // Filters need to be either an array or an object\n // Here we're only checking for 'object' type since typeof [] => object and typeof {} => object\n if (!isObject(filters)) {\n throw new ValidationError('The filters parameter must be an object or an array');\n }\n\n // Don't mutate the original object\n const filtersCopy = cloneDeep(filters);\n\n return convertAndSanitizeFilters(filtersCopy, schema);\n };\n\n const convertAndSanitizeFilters = (filters: FiltersParams, schema?: Model): WhereQuery => {\n if (Array.isArray(filters)) {\n return (\n filters\n // Sanitize each filter\n .map((filter) => convertAndSanitizeFilters(filter, schema))\n // Filter out empty filters\n .filter((filter) => !isPlainObject(filter) || !isEmpty(filter))\n );\n }\n\n if (!isPlainObject(filters)) {\n return filters as WhereQuery;\n }\n\n const removeOperator = (operator: string) => delete filters[operator];\n\n // Here, `key` can either be an operator or an attribute name\n for (const [key, value] of Object.entries(filters)) {\n const attribute = get(key, schema?.attributes);\n const validKey = isOperator(key) || isValidSchemaAttribute(key, schema);\n\n if (!validKey) {\n removeOperator(key);\n }\n // Handle attributes\n else if (attribute) {\n // Relations\n if (attribute.type === 'relation') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.target!));\n }\n\n // Components\n else if (attribute.type === 'component') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.component));\n }\n\n // Media\n else if (attribute.type === 'media') {\n filters[key] = convertAndSanitizeFilters(value, getModel('plugin::upload.file'));\n }\n\n // Dynamic Zones\n else if (attribute.type === 'dynamiczone') {\n removeOperator(key);\n }\n\n // Password attributes\n else if (attribute.type === 'password') {\n // Always remove password attributes from filters object\n removeOperator(key);\n }\n\n // Scalar attributes\n else {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n }\n\n // Handle operators\n else if (['$null', '$notNull'].includes(key)) {\n filters[key] = parseType({ type: 'boolean', value: filters[key], forceCast: true });\n } else if (isObject(value)) {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n\n // Remove empty objects & arrays\n if (isPlainObject(filters[key]) && isEmpty(filters[key])) {\n removeOperator(key);\n }\n }\n\n return filters;\n };\n\n const convertStatusParams = (status?: 'draft' | 'published', query: Query = {}) => {\n // NOTE: this is the query layer filters not the document/entity service filters\n query.filters = ({ meta }: { meta: Model }) => {\n const contentType = getModel(meta.uid);\n\n // Ignore if target model has disabled DP, as it doesn't make sense to filter by its status\n if (!contentType || !hasDraftAndPublish(contentType)) {\n return {};\n }\n\n return { [PUBLISHED_AT_ATTRIBUTE]: { $null: status === 'draft' } };\n };\n };\n\n const transformQueryParams = (uid: string, params: Params): Query => {\n // NOTE: can be a CT, a Compo or nothing in the case of polymorphism (DZ & morph relations)\n const schema = getModel(uid);\n\n const query: Query = {};\n\n const { _q, sort, filters, fields, populate, page, pageSize, start, limit, status, ...rest } =\n params;\n\n if (!isNil(status)) {\n convertStatusParams(status, query);\n }\n\n if (!isNil(_q)) {\n query._q = _q;\n }\n\n if (!isNil(sort)) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (!isNil(filters)) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (!isNil(fields)) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (!isNil(populate)) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return {\n ...rest,\n ...query,\n };\n };\n\n return {\n private_convertSortQueryParams: convertSortQueryParams,\n private_convertStartQueryParams: convertStartQueryParams,\n private_convertLimitQueryParams: convertLimitQueryParams,\n private_convertPopulateQueryParams: convertPopulateQueryParams,\n private_convertFiltersQueryParams: convertFiltersQueryParams,\n private_convertFieldsQueryParams: convertFieldsQueryParams,\n transformQueryParams,\n };\n};\n\nexport { createTransformer };\n"],"names":["ID_ATTRIBUTE","DOC_ID_ATTRIBUTE","PUBLISHED_AT_ATTRIBUTE","constants","InvalidOrderError","Error","message","InvalidSortError","validateOrder","order","isString","includes","toLocaleLowerCase","convertCountQueryParams","countQuery","parseType","type","value","convertOrderingQueryParams","ordering","isPlainObject","_","isStringArray","isArray","every","createTransformer","getModel","convertSortQueryParams","sortQuery","convertStringSortQueryParam","flatMap","sortValue","Array","map","convertNestedSortQueryParam","split","convertSingleSortQueryParam","field","length","set","transformedSort","Object","keys","convertStartQueryParams","startQuery","startAsANumber","toNumber","isInteger","ValidationError","convertLimitQueryParams","limitQuery","limitAsANumber","undefined","convertPageQueryParams","page","pageVal","PaginationError","convertPageSizeQueryParams","pageSize","_page","pageSizeVal","validatePaginationParams","start","limit","isPagePagination","isNil","isOffsetPagination","InvalidPopulateError","convertPopulateQueryParams","populate","schema","depth","trim","uniq","convertPopulateObject","hasPopulateFragmentDefined","on","hasCountDefined","count","attributes","entries","reduce","acc","key","subPopulate","subPopulateAsBoolean","isBoolean","attribute","isMorphLikeRelationalAttribute","isDynamicZoneAttribute","isMorphToRelationalAttribute","hasInvalidProperties","some","info","singularName","uid","JSON","stringify","newSubPopulate","assign","typeSubPopulate","convertNestedPopulate","targetSchemaUID","target","component","targetSchema","populateObject","forceCast","sort","filters","fields","query","orderBy","where","convertFiltersQueryParams","select","convertFieldsQueryParams","offset","fieldsValues","modelType","filter","v","isValidSchemaAttribute","isObject","filtersCopy","cloneDeep","convertAndSanitizeFilters","isEmpty","removeOperator","operator","get","validKey","isOperator","convertStatusParams","status","meta","contentType","hasDraftAndPublish","$null","transformQueryParams","params","_q","rest","private_convertSortQueryParams","private_convertStartQueryParams","private_convertLimitQueryParams","private_convertPopulateQueryParams","private_convertFiltersQueryParams","private_convertFieldsQueryParams"],"mappings":"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"}
1
+ {"version":3,"file":"convert-query-params.mjs","sources":["../src/convert-query-params.ts"],"sourcesContent":["/* eslint-disable max-classes-per-file */\n\n/**\n * Converts the standard Strapi REST query params to a more usable format for querying\n * You can read more here: https://docs.strapi.io/developer-docs/latest/developer-resources/database-apis-reference/rest-api.html#filters\n */\n\nimport _ from 'lodash';\nimport {\n cloneDeep,\n get,\n isArray,\n isEmpty,\n isInteger,\n isNil,\n isObject,\n isString,\n toNumber,\n} from 'lodash/fp';\nimport {\n constants,\n hasDraftAndPublish,\n isDynamicZoneAttribute,\n isMorphToRelationalAttribute,\n} from './content-types';\nimport { PaginationError, ValidationError } from './errors';\nimport { isOperator } from './operators';\n\nimport parseType from './parse-type';\nimport type { PublicationFilterMode } from './publication-filter';\nimport { Model } from './types';\n\nconst { ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, PUBLISHED_AT_ATTRIBUTE } = constants;\n\ntype SortOrder = 'asc' | 'desc';\n\nexport interface SortMap {\n [key: string]: SortOrder | SortMap;\n}\n\nexport interface SortParamsObject {\n [key: string]: SortOrder | SortParamsObject;\n}\n\ntype SortParams = string | string[] | SortParamsObject | SortParamsObject[];\ntype FieldsParams = string | string[];\n\ntype FiltersParams = unknown;\n\nexport interface PopulateAttributesParams {\n [key: string]: boolean | PopulateObjectParams;\n}\n\nexport interface PopulateObjectParams {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: string | string[] | PopulateAttributesParams;\n on?: PopulateAttributesParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n}\n\ntype PopulateParams = string | string[] | PopulateAttributesParams;\n\nexport interface Params {\n sort?: SortParams;\n fields?: FieldsParams;\n filters?: FiltersParams;\n populate?: PopulateParams;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number | string;\n start?: number | string;\n page?: number | string;\n pageSize?: number | string;\n status?: 'draft' | 'published';\n publicationFilter?: PublicationFilterMode;\n /**\n * @deprecated Replaced by `publicationFilter` (`never-published`, `has-published-version`, …).\n * Retained for backward compatibility with existing REST and GraphQL clients.\n */\n hasPublishedVersion?: boolean | 'true' | 'false';\n}\n\ntype FiltersQuery = (options: { meta: Model }) => WhereQuery | undefined;\ntype OrderByQuery = SortMap | SortMap[];\ntype SelectQuery = string | string[];\n\nexport interface WhereQuery {\n [key: string]: any;\n}\n\ntype PopulateQuery =\n | boolean\n | string[]\n | {\n [key: string]: PopulateQuery;\n };\n\nexport interface Query {\n orderBy?: OrderByQuery;\n select?: SelectQuery;\n where?: WhereQuery;\n // NOTE: those are internal DB filters do not modify\n filters?: FiltersQuery;\n populate?: PopulateQuery;\n count?: boolean;\n ordering?: unknown;\n _q?: string;\n limit?: number;\n offset?: number;\n page?: number;\n pageSize?: number;\n}\n\nclass InvalidOrderError extends Error {\n constructor() {\n super();\n this.message = 'Invalid order. order can only be one of asc|desc|ASC|DESC';\n }\n}\n\nclass InvalidSortError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid sort parameter. Expected a string, an array of strings, a sort object or an array of sort objects';\n }\n}\n\nfunction validateOrder(order: string): asserts order is SortOrder {\n if (!isString(order) || !['asc', 'desc'].includes(order.toLocaleLowerCase())) {\n throw new InvalidOrderError();\n }\n}\n\nconst convertCountQueryParams = (countQuery: unknown): boolean => {\n return parseType({ type: 'boolean', value: countQuery });\n};\n\nconst convertOrderingQueryParams = (ordering: unknown) => {\n return ordering;\n};\n\nconst isPlainObject = (value: unknown): value is Record<string, unknown> => _.isPlainObject(value);\nconst isStringArray = (value: unknown): value is string[] =>\n isArray(value) && value.every(isString);\n\ninterface TransformerOptions {\n getModel: (uid: string) => Model | undefined;\n}\n\nconst createTransformer = ({ getModel }: TransformerOptions) => {\n /**\n * Sort query parser\n */\n const convertSortQueryParams = (sortQuery: SortParams): OrderByQuery => {\n if (typeof sortQuery === 'string') {\n return convertStringSortQueryParam(sortQuery);\n }\n\n if (isStringArray(sortQuery)) {\n return sortQuery.flatMap((sortValue: string) => convertStringSortQueryParam(sortValue));\n }\n\n if (Array.isArray(sortQuery)) {\n return sortQuery.map((sortValue) => convertNestedSortQueryParam(sortValue));\n }\n\n if (isPlainObject(sortQuery)) {\n return convertNestedSortQueryParam(sortQuery);\n }\n\n throw new InvalidSortError();\n };\n\n const convertStringSortQueryParam = (sortQuery: string): SortMap[] => {\n return sortQuery.split(',').map((value) => convertSingleSortQueryParam(value));\n };\n\n const convertSingleSortQueryParam = (sortQuery: string): SortMap => {\n if (!sortQuery) {\n return {};\n }\n\n if (!isString(sortQuery)) {\n throw new Error('Invalid sort query');\n }\n\n // split field and order param with default order to ascending\n const [field, order = 'asc'] = sortQuery.split(':');\n\n if (field.length === 0) {\n throw new Error('Field cannot be empty');\n }\n\n validateOrder(order);\n\n // TODO: field should be a valid path on an object model\n\n return _.set({}, field, order);\n };\n\n const convertNestedSortQueryParam = (sortQuery: SortParamsObject): SortMap => {\n const transformedSort: SortMap = {};\n for (const field of Object.keys(sortQuery)) {\n const order = sortQuery[field];\n\n // this is a deep sort\n if (isPlainObject(order)) {\n transformedSort[field] = convertNestedSortQueryParam(order);\n } else if (typeof order === 'string') {\n validateOrder(order);\n transformedSort[field] = order;\n } else {\n throw Error(`Invalid sort type expected object or string got ${typeof order}`);\n }\n }\n\n return transformedSort;\n };\n\n /**\n * Start query parser\n */\n const convertStartQueryParams = (startQuery: unknown): number => {\n const startAsANumber = toNumber(startQuery);\n\n if (!_.isInteger(startAsANumber) || startAsANumber < 0) {\n throw new ValidationError(\n `convertStartQueryParams expected a positive integer got ${startAsANumber}`\n );\n }\n\n return startAsANumber;\n };\n\n /**\n * Limit query parser\n */\n const convertLimitQueryParams = (limitQuery: unknown): number | undefined => {\n const limitAsANumber = toNumber(limitQuery);\n\n if (!_.isInteger(limitAsANumber) || (limitAsANumber !== -1 && limitAsANumber < 0)) {\n throw new ValidationError(\n `convertLimitQueryParams expected a positive integer got ${limitAsANumber}`\n );\n }\n\n if (limitAsANumber === -1) {\n return undefined;\n }\n\n return limitAsANumber;\n };\n\n const convertPageQueryParams = (page: unknown): number => {\n const pageVal = toNumber(page);\n\n if (!isInteger(pageVal) || pageVal <= 0) {\n throw new PaginationError(\n `Invalid 'page' parameter. Expected an integer > 0, received: ${page}`\n );\n }\n\n return pageVal;\n };\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const convertPageSizeQueryParams = (pageSize: unknown, _page: unknown): number => {\n const pageSizeVal = toNumber(pageSize);\n\n if (!isInteger(pageSizeVal) || pageSizeVal <= 0) {\n throw new PaginationError(\n `Invalid 'pageSize' parameter. Expected an integer > 0, received: ${pageSize}`\n );\n }\n\n return pageSizeVal;\n };\n\n const validatePaginationParams = (\n page: unknown,\n pageSize: unknown,\n start: unknown,\n limit: unknown\n ) => {\n const isPagePagination = !isNil(page) || !isNil(pageSize);\n const isOffsetPagination = !isNil(start) || !isNil(limit);\n\n if (isPagePagination && isOffsetPagination) {\n throw new PaginationError(\n 'Invalid pagination attributes. The page parameters are incorrect and must be in the pagination object'\n );\n }\n };\n\n class InvalidPopulateError extends Error {\n constructor() {\n super();\n this.message =\n 'Invalid populate parameter. Expected a string, an array of strings, a populate object';\n }\n }\n\n // NOTE: we could support foo.* or foo.bar.* etc later on\n const convertPopulateQueryParams = (\n populate: PopulateParams,\n schema?: Model,\n depth = 0\n ): PopulateQuery => {\n if (depth === 0 && populate === '*') {\n return true;\n }\n\n if (typeof populate === 'string') {\n return populate.split(',').map((value) => _.trim(value));\n }\n\n if (Array.isArray(populate)) {\n // map convert\n return _.uniq(\n populate.flatMap((value) => {\n if (typeof value !== 'string') {\n throw new InvalidPopulateError();\n }\n\n return value.split(',').map((value) => _.trim(value));\n })\n );\n }\n\n if (_.isPlainObject(populate)) {\n return convertPopulateObject(populate, schema);\n }\n\n throw new InvalidPopulateError();\n };\n\n const hasPopulateFragmentDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & Required<Pick<PopulateObjectParams, 'on'>> => {\n return typeof populate === 'object' && 'on' in populate && !isNil(populate.on);\n };\n\n const hasCountDefined = (\n populate: PopulateObjectParams\n ): populate is PopulateObjectParams & { count: boolean } => {\n return (\n typeof populate === 'object' && 'count' in populate && typeof populate.count === 'boolean'\n );\n };\n\n const convertPopulateObject = (populate: PopulateAttributesParams, schema?: Model) => {\n if (!schema) {\n return {};\n }\n\n const { attributes } = schema;\n return Object.entries(populate).reduce((acc, [key, subPopulate]) => {\n // Try converting strings to regular booleans if possible\n if (_.isString(subPopulate)) {\n try {\n const subPopulateAsBoolean = parseType({ type: 'boolean', value: subPopulate });\n // Only true is accepted as a boolean populate value\n return subPopulateAsBoolean ? { ...acc, [key]: true } : acc;\n } catch {\n // ignore\n }\n }\n\n if (_.isBoolean(subPopulate)) {\n // Only true is accepted as a boolean populate value\n return subPopulate === true ? { ...acc, [key]: true } : acc;\n }\n\n const attribute = attributes[key];\n\n if (!attribute) {\n return acc;\n }\n\n // Allow adding an 'on' strategy to populate queries for morphTo relations and dynamic zones\n const isMorphLikeRelationalAttribute =\n isDynamicZoneAttribute(attribute) || isMorphToRelationalAttribute(attribute);\n\n if (isMorphLikeRelationalAttribute) {\n const hasInvalidProperties = Object.keys(subPopulate).some(\n (key) => !['populate', 'on', 'count'].includes(key)\n );\n\n if (hasInvalidProperties) {\n throw new ValidationError(\n `Invalid nested populate for ${schema.info?.singularName}.${key} (${schema.uid}). Expected a fragment (\"on\") or \"count\" but found ${JSON.stringify(subPopulate)}`\n );\n }\n\n /**\n * Validate nested population queries in the context of a polymorphic attribute (dynamic zone, morph relation).\n *\n * If 'populate' exists in subPopulate, its value should be constrained to a wildcard ('*').\n */\n if ('populate' in subPopulate && subPopulate.populate !== '*') {\n throw new ValidationError(\n `Invalid nested population query detected. When using 'populate' within polymorphic structures, ` +\n `its value must be '*' to indicate all second level links. Specific field targeting is not supported here. ` +\n `Consider using the fragment API for more granular population control.`\n );\n }\n\n // TODO: Remove the possibility to have multiple properties at the same time (on/count/populate)\n const newSubPopulate = {};\n\n // case: { populate: '*' }\n if ('populate' in subPopulate) {\n Object.assign(newSubPopulate, { populate: true });\n }\n\n // case: { on: { <clauses> } }\n if (hasPopulateFragmentDefined(subPopulate)) {\n // If the fragment API is used, it applies the transformation to every\n // sub-populate, then assign the result to the new sub-populate\n Object.assign(newSubPopulate, {\n on: Object.entries(subPopulate.on).reduce(\n (acc, [type, typeSubPopulate]) => ({\n ...acc,\n [type]: convertNestedPopulate(typeSubPopulate, getModel(type)),\n }),\n {}\n ),\n });\n }\n\n // case: { count: true | false }\n if (hasCountDefined(subPopulate)) {\n Object.assign(newSubPopulate, { count: subPopulate.count });\n }\n\n return { ...acc, [key]: newSubPopulate };\n }\n\n // Edge case when trying to use the fragment ('on') on a non-morph like attribute\n if (!isMorphLikeRelationalAttribute && hasPopulateFragmentDefined(subPopulate)) {\n throw new ValidationError(\n `Using fragments is not permitted to populate \"${key}\" in \"${schema.uid}\"`\n );\n }\n\n // NOTE: Retrieve the target schema UID.\n // Only handles basic relations, medias and component since it's not possible\n // to populate with options for a dynamic zone or a polymorphic relation\n let targetSchemaUID;\n\n if (attribute.type === 'relation') {\n targetSchemaUID = attribute.target;\n } else if (attribute.type === 'component') {\n targetSchemaUID = attribute.component;\n } else if (attribute.type === 'media') {\n targetSchemaUID = 'plugin::upload.file';\n } else {\n return acc;\n }\n\n const targetSchema = getModel(targetSchemaUID!);\n\n // ignore the sub-populate for the current key if there is no schema associated\n if (!targetSchema) {\n return acc;\n }\n\n const populateObject = convertNestedPopulate(subPopulate, targetSchema);\n\n if (!populateObject) {\n return acc;\n }\n\n return {\n ...acc,\n [key]: populateObject,\n };\n }, {});\n };\n\n const convertNestedPopulate = (subPopulate: boolean | PopulateObjectParams, schema?: Model) => {\n if (_.isString(subPopulate)) {\n return parseType({ type: 'boolean', value: subPopulate, forceCast: true });\n }\n\n if (_.isBoolean(subPopulate)) {\n return subPopulate;\n }\n\n if (!isPlainObject(subPopulate)) {\n throw new ValidationError(`Invalid nested populate. Expected '*' or an object`);\n }\n\n const { sort, filters, fields, populate, count, ordering, page, pageSize, start, limit } =\n subPopulate as PopulateObjectParams;\n\n const query: Query = {};\n\n if (sort) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (filters) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (fields) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (populate) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n if (count) {\n query.count = convertCountQueryParams(count);\n }\n\n if (ordering) {\n query.ordering = convertOrderingQueryParams(ordering);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return query;\n };\n\n // TODO: ensure field is valid in content types (will probably have to check strapi.contentTypes since it can be a string.path)\n const convertFieldsQueryParams = (\n fields: FieldsParams,\n schema?: Model,\n depth = 0\n ): SelectQuery | undefined => {\n if (depth === 0 && fields === '*') {\n return undefined;\n }\n\n if (typeof fields === 'string') {\n const fieldsValues = fields.split(',').map((value) => _.trim(value));\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n if (isStringArray(fields)) {\n // map convert\n const fieldsValues = fields\n .flatMap((value) => convertFieldsQueryParams(value, schema, depth + 1))\n .filter((v) => !isNil(v)) as string[];\n\n // NOTE: Only include the doc id if it's a content type\n if (schema?.modelType === 'contentType') {\n return _.uniq([ID_ATTRIBUTE, DOC_ID_ATTRIBUTE, ...fieldsValues]);\n }\n return _.uniq([ID_ATTRIBUTE, ...fieldsValues]);\n }\n\n throw new ValidationError('Invalid fields parameter. Expected a string or an array of strings');\n };\n\n const isValidSchemaAttribute = (key: string, schema?: Model) => {\n if ([DOC_ID_ATTRIBUTE, ID_ATTRIBUTE].includes(key)) {\n return true;\n }\n\n if (!schema) {\n return false;\n }\n\n return Object.keys(schema.attributes).includes(key);\n };\n\n const convertFiltersQueryParams = (filters: FiltersParams, schema?: Model): WhereQuery => {\n // Filters need to be either an array or an object\n // Here we're only checking for 'object' type since typeof [] => object and typeof {} => object\n if (!isObject(filters)) {\n throw new ValidationError('The filters parameter must be an object or an array');\n }\n\n // Don't mutate the original object\n const filtersCopy = cloneDeep(filters);\n\n return convertAndSanitizeFilters(filtersCopy, schema);\n };\n\n const convertAndSanitizeFilters = (filters: FiltersParams, schema?: Model): WhereQuery => {\n if (Array.isArray(filters)) {\n return (\n filters\n // Sanitize each filter\n .map((filter) => convertAndSanitizeFilters(filter, schema))\n // Filter out empty filters\n .filter((filter) => !isPlainObject(filter) || !isEmpty(filter))\n );\n }\n\n if (!isPlainObject(filters)) {\n return filters as WhereQuery;\n }\n\n const removeOperator = (operator: string) => delete filters[operator];\n\n // Here, `key` can either be an operator or an attribute name\n for (const [key, value] of Object.entries(filters)) {\n const attribute = get(key, schema?.attributes);\n const validKey = isOperator(key) || isValidSchemaAttribute(key, schema);\n\n if (!validKey) {\n removeOperator(key);\n }\n // Handle attributes\n else if (attribute) {\n // Relations\n if (attribute.type === 'relation') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.target!));\n }\n\n // Components\n else if (attribute.type === 'component') {\n filters[key] = convertAndSanitizeFilters(value, getModel(attribute.component));\n }\n\n // Media\n else if (attribute.type === 'media') {\n filters[key] = convertAndSanitizeFilters(value, getModel('plugin::upload.file'));\n }\n\n // Dynamic Zones\n else if (attribute.type === 'dynamiczone') {\n removeOperator(key);\n }\n\n // Password attributes\n else if (attribute.type === 'password') {\n // Always remove password attributes from filters object\n removeOperator(key);\n }\n\n // Scalar attributes\n else {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n }\n\n // Handle operators\n else if (['$null', '$notNull'].includes(key)) {\n filters[key] = parseType({ type: 'boolean', value: filters[key], forceCast: true });\n } else if (isObject(value)) {\n filters[key] = convertAndSanitizeFilters(value, schema);\n }\n\n // Remove empty objects & arrays\n if (isPlainObject(filters[key]) && isEmpty(filters[key])) {\n removeOperator(key);\n }\n }\n\n return filters;\n };\n\n const convertStatusParams = (status?: 'draft' | 'published', query: Query = {}) => {\n // NOTE: this is the query layer filters not the document/entity service filters\n query.filters = ({ meta }: { meta: Model }) => {\n const contentType = getModel(meta.uid);\n\n // Ignore if target model has disabled DP, as it doesn't make sense to filter by its status\n if (!contentType || !hasDraftAndPublish(contentType)) {\n return {};\n }\n\n return { [PUBLISHED_AT_ATTRIBUTE]: { $null: status === 'draft' } };\n };\n };\n\n const transformQueryParams = (uid: string, params: Params): Query => {\n // NOTE: can be a CT, a Compo or nothing in the case of polymorphism (DZ & morph relations)\n const schema = getModel(uid);\n\n const query: Query = {};\n\n const { _q, sort, filters, fields, populate, page, pageSize, start, limit, status, ...rest } =\n params;\n\n if (!isNil(status)) {\n convertStatusParams(status, query);\n }\n\n if (!isNil(_q)) {\n query._q = _q;\n }\n\n if (!isNil(sort)) {\n query.orderBy = convertSortQueryParams(sort);\n }\n\n if (!isNil(filters)) {\n query.where = convertFiltersQueryParams(filters, schema);\n }\n\n if (!isNil(fields)) {\n query.select = convertFieldsQueryParams(fields, schema);\n }\n\n if (!isNil(populate)) {\n query.populate = convertPopulateQueryParams(populate, schema);\n }\n\n validatePaginationParams(page, pageSize, start, limit);\n\n if (!isNil(page)) {\n query.page = convertPageQueryParams(page);\n }\n\n if (!isNil(pageSize)) {\n query.pageSize = convertPageSizeQueryParams(pageSize, page);\n }\n\n if (!isNil(start)) {\n query.offset = convertStartQueryParams(start);\n }\n\n if (!isNil(limit)) {\n query.limit = convertLimitQueryParams(limit);\n }\n\n return {\n ...rest,\n ...query,\n };\n };\n\n return {\n private_convertSortQueryParams: convertSortQueryParams,\n private_convertStartQueryParams: convertStartQueryParams,\n private_convertLimitQueryParams: convertLimitQueryParams,\n private_convertPopulateQueryParams: convertPopulateQueryParams,\n private_convertFiltersQueryParams: convertFiltersQueryParams,\n private_convertFieldsQueryParams: convertFieldsQueryParams,\n transformQueryParams,\n };\n};\n\nexport { createTransformer };\n"],"names":["ID_ATTRIBUTE","DOC_ID_ATTRIBUTE","PUBLISHED_AT_ATTRIBUTE","constants","InvalidOrderError","Error","message","InvalidSortError","validateOrder","order","isString","includes","toLocaleLowerCase","convertCountQueryParams","countQuery","parseType","type","value","convertOrderingQueryParams","ordering","isPlainObject","_","isStringArray","isArray","every","createTransformer","getModel","convertSortQueryParams","sortQuery","convertStringSortQueryParam","flatMap","sortValue","Array","map","convertNestedSortQueryParam","split","convertSingleSortQueryParam","field","length","set","transformedSort","Object","keys","convertStartQueryParams","startQuery","startAsANumber","toNumber","isInteger","ValidationError","convertLimitQueryParams","limitQuery","limitAsANumber","undefined","convertPageQueryParams","page","pageVal","PaginationError","convertPageSizeQueryParams","pageSize","_page","pageSizeVal","validatePaginationParams","start","limit","isPagePagination","isNil","isOffsetPagination","InvalidPopulateError","convertPopulateQueryParams","populate","schema","depth","trim","uniq","convertPopulateObject","hasPopulateFragmentDefined","on","hasCountDefined","count","attributes","entries","reduce","acc","key","subPopulate","subPopulateAsBoolean","isBoolean","attribute","isMorphLikeRelationalAttribute","isDynamicZoneAttribute","isMorphToRelationalAttribute","hasInvalidProperties","some","info","singularName","uid","JSON","stringify","newSubPopulate","assign","typeSubPopulate","convertNestedPopulate","targetSchemaUID","target","component","targetSchema","populateObject","forceCast","sort","filters","fields","query","orderBy","where","convertFiltersQueryParams","select","convertFieldsQueryParams","offset","fieldsValues","modelType","filter","v","isValidSchemaAttribute","isObject","filtersCopy","cloneDeep","convertAndSanitizeFilters","isEmpty","removeOperator","operator","get","validKey","isOperator","convertStatusParams","status","meta","contentType","hasDraftAndPublish","$null","transformQueryParams","params","_q","rest","private_convertSortQueryParams","private_convertStartQueryParams","private_convertLimitQueryParams","private_convertPopulateQueryParams","private_convertFiltersQueryParams","private_convertFieldsQueryParams"],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type { PublicationFilterMode } from './publication-filter';
2
+ /**
3
+ * Parses the deprecated `hasPublishedVersion` query param (REST boolean or "true"/"false" strings).
4
+ * @deprecated Prefer `publicationFilter` with document-scoped modes.
5
+ */
6
+ export declare const parseHasPublishedVersionQueryParam: (value: unknown) => boolean | undefined;
7
+ /** Maps legacy boolean to the document-scoped `publicationFilter` cohorts (same semantics as the old subquery). */
8
+ export declare const hasPublishedVersionBooleanToPublicationFilterMode: (value: boolean) => Extract<PublicationFilterMode, 'never-published-document' | 'has-published-version-document'>;
9
+ //# sourceMappingURL=has-published-version-param.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"has-published-version-param.d.ts","sourceRoot":"","sources":["../src/has-published-version-param.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAElE;;;GAGG;AACH,eAAO,MAAM,kCAAkC,UAAW,OAAO,KAAG,OAAO,GAAG,SAgB7E,CAAC;AAEF,mHAAmH;AACnH,eAAO,MAAM,iDAAiD,UACrD,OAAO,KACb,QAAQ,qBAAqB,EAAE,0BAA0B,GAAG,gCAAgC,CACxB,CAAC"}
@@ -0,0 +1,24 @@
1
+ 'use strict';
2
+
3
+ var errors = require('./errors.js');
4
+
5
+ /**
6
+ * Parses the deprecated `hasPublishedVersion` query param (REST boolean or "true"/"false" strings).
7
+ * @deprecated Prefer `publicationFilter` with document-scoped modes.
8
+ */ const parseHasPublishedVersionQueryParam = (value)=>{
9
+ if (value === undefined || value === null) {
10
+ return undefined;
11
+ }
12
+ if (value === true || value === 'true') {
13
+ return true;
14
+ }
15
+ if (value === false || value === 'false') {
16
+ return false;
17
+ }
18
+ throw new errors.ValidationError("Invalid value for 'hasPublishedVersion'. Expected boolean or 'true'/'false' string.");
19
+ };
20
+ /** Maps legacy boolean to the document-scoped `publicationFilter` cohorts (same semantics as the old subquery). */ const hasPublishedVersionBooleanToPublicationFilterMode = (value)=>value ? 'has-published-version-document' : 'never-published-document';
21
+
22
+ exports.hasPublishedVersionBooleanToPublicationFilterMode = hasPublishedVersionBooleanToPublicationFilterMode;
23
+ exports.parseHasPublishedVersionQueryParam = parseHasPublishedVersionQueryParam;
24
+ //# sourceMappingURL=has-published-version-param.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"has-published-version-param.js","sources":["../src/has-published-version-param.ts"],"sourcesContent":["import { ValidationError } from './errors';\nimport type { PublicationFilterMode } from './publication-filter';\n\n/**\n * Parses the deprecated `hasPublishedVersion` query param (REST boolean or \"true\"/\"false\" strings).\n * @deprecated Prefer `publicationFilter` with document-scoped modes.\n */\nexport const parseHasPublishedVersionQueryParam = (value: unknown): boolean | undefined => {\n if (value === undefined || value === null) {\n return undefined;\n }\n\n if (value === true || value === 'true') {\n return true;\n }\n\n if (value === false || value === 'false') {\n return false;\n }\n\n throw new ValidationError(\n \"Invalid value for 'hasPublishedVersion'. Expected boolean or 'true'/'false' string.\"\n );\n};\n\n/** Maps legacy boolean to the document-scoped `publicationFilter` cohorts (same semantics as the old subquery). */\nexport const hasPublishedVersionBooleanToPublicationFilterMode = (\n value: boolean\n): Extract<PublicationFilterMode, 'never-published-document' | 'has-published-version-document'> =>\n value ? 'has-published-version-document' : 'never-published-document';\n"],"names":["parseHasPublishedVersionQueryParam","value","undefined","ValidationError","hasPublishedVersionBooleanToPublicationFilterMode"],"mappings":";;;;AAGA;;;IAIO,MAAMA,kCAAAA,GAAqC,CAACC,KAAAA,GAAAA;IACjD,IAAIA,KAAAA,KAAUC,SAAAA,IAAaD,KAAAA,KAAU,IAAA,EAAM;QACzC,OAAOC,SAAAA;AACT,IAAA;IAEA,IAAID,KAAAA,KAAU,IAAA,IAAQA,KAAAA,KAAU,MAAA,EAAQ;QACtC,OAAO,IAAA;AACT,IAAA;IAEA,IAAIA,KAAAA,KAAU,KAAA,IAASA,KAAAA,KAAU,OAAA,EAAS;QACxC,OAAO,KAAA;AACT,IAAA;AAEA,IAAA,MAAM,IAAIE,sBAAAA,CACR,qFAAA,CAAA;AAEJ;AAEA,oHACO,MAAMC,iDAAAA,GAAoD,CAC/DH,KAAAA,GAEAA,KAAAA,GAAQ,mCAAmC;;;;;"}