@strapi/plugin-graphql 5.12.1 → 5.12.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/admin/index.js +18 -143
- package/dist/admin/index.js.map +1 -1
- package/dist/admin/index.mjs +14 -141
- package/dist/admin/index.mjs.map +1 -1
- package/dist/admin/package.json.js +143 -0
- package/dist/admin/package.json.js.map +1 -0
- package/dist/admin/package.json.mjs +124 -0
- package/dist/admin/package.json.mjs.map +1 -0
- package/dist/admin/pluginId.js +6 -0
- package/dist/admin/pluginId.js.map +1 -0
- package/dist/admin/pluginId.mjs +4 -0
- package/dist/admin/pluginId.mjs.map +1 -0
- package/dist/admin/{chunks/dk-D3k_Atlh.js → translations/dk.json.js} +2 -2
- package/dist/admin/translations/dk.json.js.map +1 -0
- package/dist/admin/{chunks/dk-Bji21OvY.mjs → translations/dk.json.mjs} +1 -1
- package/dist/admin/translations/dk.json.mjs.map +1 -0
- package/dist/admin/{chunks/en-DzY_FEd6.js → translations/en.json.js} +2 -2
- package/dist/admin/translations/en.json.js.map +1 -0
- package/dist/admin/{chunks/en-COko3s6d.mjs → translations/en.json.mjs} +1 -1
- package/dist/admin/translations/en.json.mjs.map +1 -0
- package/dist/admin/{chunks/es-D02rvX4A.js → translations/es.json.js} +2 -2
- package/dist/admin/translations/es.json.js.map +1 -0
- package/dist/admin/{chunks/es-BoUVfXlb.mjs → translations/es.json.mjs} +1 -1
- package/dist/admin/translations/es.json.mjs.map +1 -0
- package/dist/admin/{chunks/fr-D9dcL-gU.js → translations/fr.json.js} +2 -2
- package/dist/admin/translations/fr.json.js.map +1 -0
- package/dist/admin/{chunks/fr-DFbQQgkK.mjs → translations/fr.json.mjs} +1 -1
- package/dist/admin/translations/fr.json.mjs.map +1 -0
- package/dist/admin/{chunks/pl-DRSWvr2y.js → translations/pl.json.js} +2 -2
- package/dist/admin/translations/pl.json.js.map +1 -0
- package/dist/admin/{chunks/pl-Bih5cA3Y.mjs → translations/pl.json.mjs} +1 -1
- package/dist/admin/translations/pl.json.mjs.map +1 -0
- package/dist/admin/{chunks/ru-zDn7cu6t.js → translations/ru.json.js} +2 -2
- package/dist/admin/translations/ru.json.js.map +1 -0
- package/dist/admin/{chunks/ru-Bxi2fB6E.mjs → translations/ru.json.mjs} +1 -1
- package/dist/admin/translations/ru.json.mjs.map +1 -0
- package/dist/admin/{chunks/sv-Dq2aVH0_.js → translations/sv.json.js} +2 -2
- package/dist/admin/translations/sv.json.js.map +1 -0
- package/dist/admin/{chunks/sv-B2uIJv_a.mjs → translations/sv.json.mjs} +1 -1
- package/dist/admin/translations/sv.json.mjs.map +1 -0
- package/dist/admin/{chunks/tr-B0yEuVnS.js → translations/tr.json.js} +2 -2
- package/dist/admin/translations/tr.json.js.map +1 -0
- package/dist/admin/{chunks/tr-DwO6hyQD.mjs → translations/tr.json.mjs} +1 -1
- package/dist/admin/translations/tr.json.mjs.map +1 -0
- package/dist/admin/{chunks/uk-DJGNjXWk.js → translations/uk.json.js} +2 -2
- package/dist/admin/translations/uk.json.js.map +1 -0
- package/dist/admin/{chunks/uk-_25RY9BK.mjs → translations/uk.json.mjs} +1 -1
- package/dist/admin/translations/uk.json.mjs.map +1 -0
- package/dist/admin/{chunks/zh-Hans-DxlDvlSo.js → translations/zh-Hans.json.js} +2 -2
- package/dist/admin/translations/zh-Hans.json.js.map +1 -0
- package/dist/admin/{chunks/zh-Hans-DUab611K.mjs → translations/zh-Hans.json.mjs} +1 -1
- package/dist/admin/translations/zh-Hans.json.mjs.map +1 -0
- package/dist/admin/{chunks/zh-BkiTjJnf.js → translations/zh.json.js} +2 -2
- package/dist/admin/translations/zh.json.js.map +1 -0
- package/dist/admin/{chunks/zh-DVvz1qsT.mjs → translations/zh.json.mjs} +1 -1
- package/dist/admin/translations/zh.json.mjs.map +1 -0
- package/dist/admin/utils/prefixPluginTranslations.js +11 -0
- package/dist/admin/utils/prefixPluginTranslations.js.map +1 -0
- package/dist/admin/utils/prefixPluginTranslations.mjs +9 -0
- package/dist/admin/utils/prefixPluginTranslations.mjs.map +1 -0
- package/dist/server/bootstrap.js +180 -0
- package/dist/server/bootstrap.js.map +1 -0
- package/dist/server/bootstrap.mjs +177 -0
- package/dist/server/bootstrap.mjs.map +1 -0
- package/dist/server/config/default-config.js +13 -0
- package/dist/server/config/default-config.js.map +1 -0
- package/dist/server/config/default-config.mjs +11 -0
- package/dist/server/config/default-config.mjs.map +1 -0
- package/dist/server/config/index.js +10 -0
- package/dist/server/config/index.js.map +1 -0
- package/dist/server/config/index.mjs +8 -0
- package/dist/server/config/index.mjs.map +1 -0
- package/dist/server/format-graphql-error.js +60 -0
- package/dist/server/format-graphql-error.js.map +1 -0
- package/dist/server/format-graphql-error.mjs +58 -0
- package/dist/server/format-graphql-error.mjs.map +1 -0
- package/dist/server/index.js +6 -3719
- package/dist/server/index.js.map +1 -1
- package/dist/server/index.mjs +3 -3698
- package/dist/server/index.mjs.map +1 -1
- package/dist/server/services/builders/dynamic-zones.js +75 -0
- package/dist/server/services/builders/dynamic-zones.js.map +1 -0
- package/dist/server/services/builders/dynamic-zones.mjs +73 -0
- package/dist/server/services/builders/dynamic-zones.mjs.map +1 -0
- package/dist/server/services/builders/entity.js +38 -0
- package/dist/server/services/builders/entity.js.map +1 -0
- package/dist/server/services/builders/entity.mjs +36 -0
- package/dist/server/services/builders/entity.mjs.map +1 -0
- package/dist/server/services/builders/enums.js +24 -0
- package/dist/server/services/builders/enums.js.map +1 -0
- package/dist/server/services/builders/enums.mjs +22 -0
- package/dist/server/services/builders/enums.mjs.map +1 -0
- package/dist/server/services/builders/filters/content-type.js +94 -0
- package/dist/server/services/builders/filters/content-type.js.map +1 -0
- package/dist/server/services/builders/filters/content-type.mjs +92 -0
- package/dist/server/services/builders/filters/content-type.mjs.map +1 -0
- package/dist/server/services/builders/filters/index.js +10 -0
- package/dist/server/services/builders/filters/index.js.map +1 -0
- package/dist/server/services/builders/filters/index.mjs +8 -0
- package/dist/server/services/builders/filters/index.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/and.js +17 -0
- package/dist/server/services/builders/filters/operators/and.js.map +1 -0
- package/dist/server/services/builders/filters/operators/and.mjs +15 -0
- package/dist/server/services/builders/filters/operators/and.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/between.js +17 -0
- package/dist/server/services/builders/filters/operators/between.js.map +1 -0
- package/dist/server/services/builders/filters/operators/between.mjs +15 -0
- package/dist/server/services/builders/filters/operators/between.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/contains.js +15 -0
- package/dist/server/services/builders/filters/operators/contains.js.map +1 -0
- package/dist/server/services/builders/filters/operators/contains.mjs +13 -0
- package/dist/server/services/builders/filters/operators/contains.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/containsi.js +15 -0
- package/dist/server/services/builders/filters/operators/containsi.js.map +1 -0
- package/dist/server/services/builders/filters/operators/containsi.mjs +13 -0
- package/dist/server/services/builders/filters/operators/containsi.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/ends-with.js +15 -0
- package/dist/server/services/builders/filters/operators/ends-with.js.map +1 -0
- package/dist/server/services/builders/filters/operators/ends-with.mjs +13 -0
- package/dist/server/services/builders/filters/operators/ends-with.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/eq.js +22 -0
- package/dist/server/services/builders/filters/operators/eq.js.map +1 -0
- package/dist/server/services/builders/filters/operators/eq.mjs +20 -0
- package/dist/server/services/builders/filters/operators/eq.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/eqi.js +15 -0
- package/dist/server/services/builders/filters/operators/eqi.js.map +1 -0
- package/dist/server/services/builders/filters/operators/eqi.mjs +13 -0
- package/dist/server/services/builders/filters/operators/eqi.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/gt.js +15 -0
- package/dist/server/services/builders/filters/operators/gt.js.map +1 -0
- package/dist/server/services/builders/filters/operators/gt.mjs +13 -0
- package/dist/server/services/builders/filters/operators/gt.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/gte.js +15 -0
- package/dist/server/services/builders/filters/operators/gte.js.map +1 -0
- package/dist/server/services/builders/filters/operators/gte.mjs +13 -0
- package/dist/server/services/builders/filters/operators/gte.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/in.js +17 -0
- package/dist/server/services/builders/filters/operators/in.js.map +1 -0
- package/dist/server/services/builders/filters/operators/in.mjs +15 -0
- package/dist/server/services/builders/filters/operators/in.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/index.js +57 -0
- package/dist/server/services/builders/filters/operators/index.js.map +1 -0
- package/dist/server/services/builders/filters/operators/index.mjs +55 -0
- package/dist/server/services/builders/filters/operators/index.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/lt.js +15 -0
- package/dist/server/services/builders/filters/operators/lt.js.map +1 -0
- package/dist/server/services/builders/filters/operators/lt.mjs +13 -0
- package/dist/server/services/builders/filters/operators/lt.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/lte.js +15 -0
- package/dist/server/services/builders/filters/operators/lte.js.map +1 -0
- package/dist/server/services/builders/filters/operators/lte.mjs +13 -0
- package/dist/server/services/builders/filters/operators/lte.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/ne.js +15 -0
- package/dist/server/services/builders/filters/operators/ne.js.map +1 -0
- package/dist/server/services/builders/filters/operators/ne.mjs +13 -0
- package/dist/server/services/builders/filters/operators/ne.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/nei.js +15 -0
- package/dist/server/services/builders/filters/operators/nei.js.map +1 -0
- package/dist/server/services/builders/filters/operators/nei.mjs +13 -0
- package/dist/server/services/builders/filters/operators/nei.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/not-contains.js +15 -0
- package/dist/server/services/builders/filters/operators/not-contains.js.map +1 -0
- package/dist/server/services/builders/filters/operators/not-contains.mjs +13 -0
- package/dist/server/services/builders/filters/operators/not-contains.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/not-containsi.js +15 -0
- package/dist/server/services/builders/filters/operators/not-containsi.js.map +1 -0
- package/dist/server/services/builders/filters/operators/not-containsi.mjs +13 -0
- package/dist/server/services/builders/filters/operators/not-containsi.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/not-in.js +17 -0
- package/dist/server/services/builders/filters/operators/not-in.js.map +1 -0
- package/dist/server/services/builders/filters/operators/not-in.mjs +15 -0
- package/dist/server/services/builders/filters/operators/not-in.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/not-null.js +13 -0
- package/dist/server/services/builders/filters/operators/not-null.js.map +1 -0
- package/dist/server/services/builders/filters/operators/not-null.mjs +11 -0
- package/dist/server/services/builders/filters/operators/not-null.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/not.js +24 -0
- package/dist/server/services/builders/filters/operators/not.js.map +1 -0
- package/dist/server/services/builders/filters/operators/not.mjs +22 -0
- package/dist/server/services/builders/filters/operators/not.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/null.js +13 -0
- package/dist/server/services/builders/filters/operators/null.js.map +1 -0
- package/dist/server/services/builders/filters/operators/null.mjs +11 -0
- package/dist/server/services/builders/filters/operators/null.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/or.js +17 -0
- package/dist/server/services/builders/filters/operators/or.js.map +1 -0
- package/dist/server/services/builders/filters/operators/or.mjs +15 -0
- package/dist/server/services/builders/filters/operators/or.mjs.map +1 -0
- package/dist/server/services/builders/filters/operators/starts-with.js +15 -0
- package/dist/server/services/builders/filters/operators/starts-with.js.map +1 -0
- package/dist/server/services/builders/filters/operators/starts-with.mjs +13 -0
- package/dist/server/services/builders/filters/operators/starts-with.mjs.map +1 -0
- package/dist/server/services/builders/generic-morph.js +38 -0
- package/dist/server/services/builders/generic-morph.js.map +1 -0
- package/dist/server/services/builders/generic-morph.mjs +36 -0
- package/dist/server/services/builders/generic-morph.mjs.map +1 -0
- package/dist/server/services/builders/index.js +75 -0
- package/dist/server/services/builders/index.js.map +1 -0
- package/dist/server/services/builders/index.mjs +73 -0
- package/dist/server/services/builders/index.mjs.map +1 -0
- package/dist/server/services/builders/input.js +89 -0
- package/dist/server/services/builders/input.js.map +1 -0
- package/dist/server/services/builders/input.mjs +87 -0
- package/dist/server/services/builders/input.mjs.map +1 -0
- package/dist/server/services/builders/mutations/collection-type.js +155 -0
- package/dist/server/services/builders/mutations/collection-type.js.map +1 -0
- package/dist/server/services/builders/mutations/collection-type.mjs +153 -0
- package/dist/server/services/builders/mutations/collection-type.mjs.map +1 -0
- package/dist/server/services/builders/mutations/index.js +12 -0
- package/dist/server/services/builders/mutations/index.js.map +1 -0
- package/dist/server/services/builders/mutations/index.mjs +10 -0
- package/dist/server/services/builders/mutations/index.mjs.map +1 -0
- package/dist/server/services/builders/mutations/single-type.js +123 -0
- package/dist/server/services/builders/mutations/single-type.js.map +1 -0
- package/dist/server/services/builders/mutations/single-type.mjs +121 -0
- package/dist/server/services/builders/mutations/single-type.mjs.map +1 -0
- package/dist/server/services/builders/queries/collection-type.js +152 -0
- package/dist/server/services/builders/queries/collection-type.js.map +1 -0
- package/dist/server/services/builders/queries/collection-type.mjs +150 -0
- package/dist/server/services/builders/queries/collection-type.mjs.map +1 -0
- package/dist/server/services/builders/queries/index.js +12 -0
- package/dist/server/services/builders/queries/index.js.map +1 -0
- package/dist/server/services/builders/queries/index.mjs +10 -0
- package/dist/server/services/builders/queries/index.mjs.map +1 -0
- package/dist/server/services/builders/queries/single-type.js +70 -0
- package/dist/server/services/builders/queries/single-type.js.map +1 -0
- package/dist/server/services/builders/queries/single-type.mjs +68 -0
- package/dist/server/services/builders/queries/single-type.mjs.map +1 -0
- package/dist/server/services/builders/relation-response-collection.js +35 -0
- package/dist/server/services/builders/relation-response-collection.js.map +1 -0
- package/dist/server/services/builders/relation-response-collection.mjs +33 -0
- package/dist/server/services/builders/relation-response-collection.mjs.map +1 -0
- package/dist/server/services/builders/resolvers/association.js +74 -0
- package/dist/server/services/builders/resolvers/association.js.map +1 -0
- package/dist/server/services/builders/resolvers/association.mjs +72 -0
- package/dist/server/services/builders/resolvers/association.mjs.map +1 -0
- package/dist/server/services/builders/resolvers/component.js +27 -0
- package/dist/server/services/builders/resolvers/component.js.map +1 -0
- package/dist/server/services/builders/resolvers/component.mjs +25 -0
- package/dist/server/services/builders/resolvers/component.mjs.map +1 -0
- package/dist/server/services/builders/resolvers/dynamic-zone.js +12 -0
- package/dist/server/services/builders/resolvers/dynamic-zone.js.map +1 -0
- package/dist/server/services/builders/resolvers/dynamic-zone.mjs +10 -0
- package/dist/server/services/builders/resolvers/dynamic-zone.mjs.map +1 -0
- package/dist/server/services/builders/resolvers/index.js +20 -0
- package/dist/server/services/builders/resolvers/index.js.map +1 -0
- package/dist/server/services/builders/resolvers/index.mjs +18 -0
- package/dist/server/services/builders/resolvers/index.mjs.map +1 -0
- package/dist/server/services/builders/resolvers/pagination.js +29 -0
- package/dist/server/services/builders/resolvers/pagination.js.map +1 -0
- package/dist/server/services/builders/resolvers/pagination.mjs +27 -0
- package/dist/server/services/builders/resolvers/pagination.mjs.map +1 -0
- package/dist/server/services/builders/resolvers/query.js +55 -0
- package/dist/server/services/builders/resolvers/query.js.map +1 -0
- package/dist/server/services/builders/resolvers/query.mjs +53 -0
- package/dist/server/services/builders/resolvers/query.mjs.map +1 -0
- package/dist/server/services/builders/response-collection.js +50 -0
- package/dist/server/services/builders/response-collection.js.map +1 -0
- package/dist/server/services/builders/response-collection.mjs +48 -0
- package/dist/server/services/builders/response-collection.mjs.map +1 -0
- package/dist/server/services/builders/response.js +28 -0
- package/dist/server/services/builders/response.js.map +1 -0
- package/dist/server/services/builders/response.mjs +26 -0
- package/dist/server/services/builders/response.mjs.map +1 -0
- package/dist/server/services/builders/type.js +347 -0
- package/dist/server/services/builders/type.js.map +1 -0
- package/dist/server/services/builders/type.mjs +345 -0
- package/dist/server/services/builders/type.mjs.map +1 -0
- package/dist/server/services/builders/utils.js +113 -0
- package/dist/server/services/builders/utils.js.map +1 -0
- package/dist/server/services/builders/utils.mjs +111 -0
- package/dist/server/services/builders/utils.mjs.map +1 -0
- package/dist/server/services/constants.js +139 -0
- package/dist/server/services/constants.js.map +1 -0
- package/dist/server/services/constants.mjs +137 -0
- package/dist/server/services/constants.mjs.map +1 -0
- package/dist/server/services/content-api/index.js +184 -0
- package/dist/server/services/content-api/index.js.map +1 -0
- package/dist/server/services/content-api/index.mjs +182 -0
- package/dist/server/services/content-api/index.mjs.map +1 -0
- package/dist/server/services/content-api/policy.js +54 -0
- package/dist/server/services/content-api/policy.js.map +1 -0
- package/dist/server/services/content-api/policy.mjs +52 -0
- package/dist/server/services/content-api/policy.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/collection-type.js +41 -0
- package/dist/server/services/content-api/register-functions/collection-type.js.map +1 -0
- package/dist/server/services/content-api/register-functions/collection-type.mjs +39 -0
- package/dist/server/services/content-api/register-functions/collection-type.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/component.js +16 -0
- package/dist/server/services/content-api/register-functions/component.js.map +1 -0
- package/dist/server/services/content-api/register-functions/component.mjs +14 -0
- package/dist/server/services/content-api/register-functions/component.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/dynamic-zones.js +31 -0
- package/dist/server/services/content-api/register-functions/dynamic-zones.js.map +1 -0
- package/dist/server/services/content-api/register-functions/dynamic-zones.mjs +29 -0
- package/dist/server/services/content-api/register-functions/dynamic-zones.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/enums.js +23 -0
- package/dist/server/services/content-api/register-functions/enums.js.map +1 -0
- package/dist/server/services/content-api/register-functions/enums.mjs +21 -0
- package/dist/server/services/content-api/register-functions/enums.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/filters.js +16 -0
- package/dist/server/services/content-api/register-functions/filters.js.map +1 -0
- package/dist/server/services/content-api/register-functions/filters.mjs +14 -0
- package/dist/server/services/content-api/register-functions/filters.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/inputs.js +17 -0
- package/dist/server/services/content-api/register-functions/inputs.js.map +1 -0
- package/dist/server/services/content-api/register-functions/inputs.mjs +15 -0
- package/dist/server/services/content-api/register-functions/inputs.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/internals.js +16 -0
- package/dist/server/services/content-api/register-functions/internals.js.map +1 -0
- package/dist/server/services/content-api/register-functions/internals.mjs +14 -0
- package/dist/server/services/content-api/register-functions/internals.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/polymorphic.js +49 -0
- package/dist/server/services/content-api/register-functions/polymorphic.js.map +1 -0
- package/dist/server/services/content-api/register-functions/polymorphic.mjs +47 -0
- package/dist/server/services/content-api/register-functions/polymorphic.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/scalars.js +15 -0
- package/dist/server/services/content-api/register-functions/scalars.js.map +1 -0
- package/dist/server/services/content-api/register-functions/scalars.mjs +13 -0
- package/dist/server/services/content-api/register-functions/scalars.mjs.map +1 -0
- package/dist/server/services/content-api/register-functions/single-type.js +41 -0
- package/dist/server/services/content-api/register-functions/single-type.js.map +1 -0
- package/dist/server/services/content-api/register-functions/single-type.mjs +39 -0
- package/dist/server/services/content-api/register-functions/single-type.mjs.map +1 -0
- package/dist/server/services/content-api/wrap-resolvers.js +119 -0
- package/dist/server/services/content-api/wrap-resolvers.js.map +1 -0
- package/dist/server/services/content-api/wrap-resolvers.mjs +117 -0
- package/dist/server/services/content-api/wrap-resolvers.mjs.map +1 -0
- package/dist/server/services/extension/extension.js +84 -0
- package/dist/server/services/extension/extension.js.map +1 -0
- package/dist/server/services/extension/extension.mjs +63 -0
- package/dist/server/services/extension/extension.mjs.map +1 -0
- package/dist/server/services/extension/index.js +8 -0
- package/dist/server/services/extension/index.js.map +1 -0
- package/dist/server/services/extension/index.mjs +6 -0
- package/dist/server/services/extension/index.mjs.map +1 -0
- package/dist/server/services/extension/shadow-crud-manager.js +121 -0
- package/dist/server/services/extension/shadow-crud-manager.js.map +1 -0
- package/dist/server/services/extension/shadow-crud-manager.mjs +119 -0
- package/dist/server/services/extension/shadow-crud-manager.mjs.map +1 -0
- package/dist/server/services/format/index.js +10 -0
- package/dist/server/services/format/index.js.map +1 -0
- package/dist/server/services/format/index.mjs +8 -0
- package/dist/server/services/format/index.mjs.map +1 -0
- package/dist/server/services/format/return-types.js +27 -0
- package/dist/server/services/format/return-types.js.map +1 -0
- package/dist/server/services/format/return-types.mjs +25 -0
- package/dist/server/services/format/return-types.mjs.map +1 -0
- package/dist/server/services/index.js +24 -0
- package/dist/server/services/index.js.map +1 -0
- package/dist/server/services/index.mjs +22 -0
- package/dist/server/services/index.mjs.map +1 -0
- package/dist/server/services/internals/args/index.js +14 -0
- package/dist/server/services/internals/args/index.js.map +1 -0
- package/dist/server/services/internals/args/index.mjs +12 -0
- package/dist/server/services/internals/args/index.mjs.map +1 -0
- package/dist/server/services/internals/args/pagination.js +20 -0
- package/dist/server/services/internals/args/pagination.js.map +1 -0
- package/dist/server/services/internals/args/pagination.mjs +18 -0
- package/dist/server/services/internals/args/pagination.mjs.map +1 -0
- package/dist/server/services/internals/args/publication-status.js +14 -0
- package/dist/server/services/internals/args/publication-status.js.map +1 -0
- package/dist/server/services/internals/args/publication-status.mjs +12 -0
- package/dist/server/services/internals/args/publication-status.mjs.map +1 -0
- package/dist/server/services/internals/args/sort.js +11 -0
- package/dist/server/services/internals/args/sort.js.map +1 -0
- package/dist/server/services/internals/args/sort.mjs +9 -0
- package/dist/server/services/internals/args/sort.mjs.map +1 -0
- package/dist/server/services/internals/helpers/get-enabled-scalars.js +13 -0
- package/dist/server/services/internals/helpers/get-enabled-scalars.js.map +1 -0
- package/dist/server/services/internals/helpers/get-enabled-scalars.mjs +11 -0
- package/dist/server/services/internals/helpers/get-enabled-scalars.mjs.map +1 -0
- package/dist/server/services/internals/helpers/index.js +10 -0
- package/dist/server/services/internals/helpers/index.js.map +1 -0
- package/dist/server/services/internals/helpers/index.mjs +8 -0
- package/dist/server/services/internals/helpers/index.mjs.map +1 -0
- package/dist/server/services/internals/index.js +16 -0
- package/dist/server/services/internals/index.js.map +1 -0
- package/dist/server/services/internals/index.mjs +14 -0
- package/dist/server/services/internals/index.mjs.map +1 -0
- package/dist/server/services/internals/scalars/date.js +18 -0
- package/dist/server/services/internals/scalars/date.js.map +1 -0
- package/dist/server/services/internals/scalars/date.mjs +15 -0
- package/dist/server/services/internals/scalars/date.mjs.map +1 -0
- package/dist/server/services/internals/scalars/index.js +17 -0
- package/dist/server/services/internals/scalars/index.js.map +1 -0
- package/dist/server/services/internals/scalars/index.mjs +15 -0
- package/dist/server/services/internals/scalars/index.mjs.map +1 -0
- package/dist/server/services/internals/scalars/time.js +38 -0
- package/dist/server/services/internals/scalars/time.js.map +1 -0
- package/dist/server/services/internals/scalars/time.mjs +36 -0
- package/dist/server/services/internals/scalars/time.mjs.map +1 -0
- package/dist/server/services/internals/types/delete-mutation-response.js +18 -0
- package/dist/server/services/internals/types/delete-mutation-response.js.map +1 -0
- package/dist/server/services/internals/types/delete-mutation-response.mjs +16 -0
- package/dist/server/services/internals/types/delete-mutation-response.mjs.map +1 -0
- package/dist/server/services/internals/types/error.js +32 -0
- package/dist/server/services/internals/types/error.js.map +1 -0
- package/dist/server/services/internals/types/error.mjs +30 -0
- package/dist/server/services/internals/types/error.mjs.map +1 -0
- package/dist/server/services/internals/types/filters.js +35 -0
- package/dist/server/services/internals/types/filters.js.map +1 -0
- package/dist/server/services/internals/types/filters.mjs +33 -0
- package/dist/server/services/internals/types/filters.mjs.map +1 -0
- package/dist/server/services/internals/types/index.js +30 -0
- package/dist/server/services/internals/types/index.js.map +1 -0
- package/dist/server/services/internals/types/index.mjs +28 -0
- package/dist/server/services/internals/types/index.mjs.map +1 -0
- package/dist/server/services/internals/types/pagination.js +24 -0
- package/dist/server/services/internals/types/pagination.js.map +1 -0
- package/dist/server/services/internals/types/pagination.mjs +22 -0
- package/dist/server/services/internals/types/pagination.mjs.map +1 -0
- package/dist/server/services/internals/types/publication-status.js +22 -0
- package/dist/server/services/internals/types/publication-status.js.map +1 -0
- package/dist/server/services/internals/types/publication-status.mjs +20 -0
- package/dist/server/services/internals/types/publication-status.mjs.map +1 -0
- package/dist/server/services/internals/types/response-collection-meta.js +27 -0
- package/dist/server/services/internals/types/response-collection-meta.js.map +1 -0
- package/dist/server/services/internals/types/response-collection-meta.mjs +25 -0
- package/dist/server/services/internals/types/response-collection-meta.mjs.map +1 -0
- package/dist/server/services/type-registry.js +81 -0
- package/dist/server/services/type-registry.js.map +1 -0
- package/dist/server/services/type-registry.mjs +79 -0
- package/dist/server/services/type-registry.mjs.map +1 -0
- package/dist/server/services/utils/attributes.js +65 -0
- package/dist/server/services/utils/attributes.js.map +1 -0
- package/dist/server/services/utils/attributes.mjs +63 -0
- package/dist/server/services/utils/attributes.mjs.map +1 -0
- package/dist/server/services/utils/index.js +16 -0
- package/dist/server/services/utils/index.js.map +1 -0
- package/dist/server/services/utils/index.mjs +14 -0
- package/dist/server/services/utils/index.mjs.map +1 -0
- package/dist/server/services/utils/mappers/entity-to-response-entity.js +16 -0
- package/dist/server/services/utils/mappers/entity-to-response-entity.js.map +1 -0
- package/dist/server/services/utils/mappers/entity-to-response-entity.mjs +14 -0
- package/dist/server/services/utils/mappers/entity-to-response-entity.mjs.map +1 -0
- package/dist/server/services/utils/mappers/graphql-filters-to-strapi-query.js +95 -0
- package/dist/server/services/utils/mappers/graphql-filters-to-strapi-query.js.map +1 -0
- package/dist/server/services/utils/mappers/graphql-filters-to-strapi-query.mjs +93 -0
- package/dist/server/services/utils/mappers/graphql-filters-to-strapi-query.mjs.map +1 -0
- package/dist/server/services/utils/mappers/graphql-scalar-to-operators.js +15 -0
- package/dist/server/services/utils/mappers/graphql-scalar-to-operators.js.map +1 -0
- package/dist/server/services/utils/mappers/graphql-scalar-to-operators.mjs +13 -0
- package/dist/server/services/utils/mappers/graphql-scalar-to-operators.mjs.map +1 -0
- package/dist/server/services/utils/mappers/index.js +16 -0
- package/dist/server/services/utils/mappers/index.js.map +1 -0
- package/dist/server/services/utils/mappers/index.mjs +14 -0
- package/dist/server/services/utils/mappers/index.mjs.map +1 -0
- package/dist/server/services/utils/mappers/strapi-scalar-to-graphql-scalar.js +23 -0
- package/dist/server/services/utils/mappers/strapi-scalar-to-graphql-scalar.js.map +1 -0
- package/dist/server/services/utils/mappers/strapi-scalar-to-graphql-scalar.mjs +21 -0
- package/dist/server/services/utils/mappers/strapi-scalar-to-graphql-scalar.mjs.map +1 -0
- package/dist/server/services/utils/naming.js +187 -0
- package/dist/server/services/utils/naming.js.map +1 -0
- package/dist/server/services/utils/naming.mjs +185 -0
- package/dist/server/services/utils/naming.mjs.map +1 -0
- package/dist/server/services/utils/playground.js +19 -0
- package/dist/server/services/utils/playground.js.map +1 -0
- package/dist/server/services/utils/playground.mjs +17 -0
- package/dist/server/services/utils/playground.mjs.map +1 -0
- package/package.json +6 -6
- package/dist/admin/chunks/dk-Bji21OvY.mjs.map +0 -1
- package/dist/admin/chunks/dk-D3k_Atlh.js.map +0 -1
- package/dist/admin/chunks/en-COko3s6d.mjs.map +0 -1
- package/dist/admin/chunks/en-DzY_FEd6.js.map +0 -1
- package/dist/admin/chunks/es-BoUVfXlb.mjs.map +0 -1
- package/dist/admin/chunks/es-D02rvX4A.js.map +0 -1
- package/dist/admin/chunks/fr-D9dcL-gU.js.map +0 -1
- package/dist/admin/chunks/fr-DFbQQgkK.mjs.map +0 -1
- package/dist/admin/chunks/pl-Bih5cA3Y.mjs.map +0 -1
- package/dist/admin/chunks/pl-DRSWvr2y.js.map +0 -1
- package/dist/admin/chunks/ru-Bxi2fB6E.mjs.map +0 -1
- package/dist/admin/chunks/ru-zDn7cu6t.js.map +0 -1
- package/dist/admin/chunks/sv-B2uIJv_a.mjs.map +0 -1
- package/dist/admin/chunks/sv-Dq2aVH0_.js.map +0 -1
- package/dist/admin/chunks/tr-B0yEuVnS.js.map +0 -1
- package/dist/admin/chunks/tr-DwO6hyQD.mjs.map +0 -1
- package/dist/admin/chunks/uk-DJGNjXWk.js.map +0 -1
- package/dist/admin/chunks/uk-_25RY9BK.mjs.map +0 -1
- package/dist/admin/chunks/zh-BkiTjJnf.js.map +0 -1
- package/dist/admin/chunks/zh-DVvz1qsT.mjs.map +0 -1
- package/dist/admin/chunks/zh-Hans-DUab611K.mjs.map +0 -1
- package/dist/admin/chunks/zh-Hans-DxlDvlSo.js.map +0 -1
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
import { extendType, nonNull, list } from 'nexus';
|
|
2
|
+
|
|
3
|
+
var createCollectionTypeQueriesBuilder = (({ strapi })=>{
|
|
4
|
+
const { service: getService } = strapi.plugin('graphql');
|
|
5
|
+
const { naming } = getService('utils');
|
|
6
|
+
const { transformArgs, getContentTypeArgs } = getService('builders').utils;
|
|
7
|
+
const { toEntityResponseCollection } = getService('format').returnTypes;
|
|
8
|
+
const { getFindOneQueryName, getTypeName, getFindQueryName, getFindConnectionQueryName, getEntityResponseCollectionName } = naming;
|
|
9
|
+
const buildCollectionTypeQueries = (contentType)=>{
|
|
10
|
+
const findOneQueryName = `Query.${getFindOneQueryName(contentType)}`;
|
|
11
|
+
const findQueryName = `Query.${getFindQueryName(contentType)}`;
|
|
12
|
+
const findConnectionQueryName = `Query.${getFindConnectionQueryName(contentType)}`;
|
|
13
|
+
const extension = getService('extension');
|
|
14
|
+
const registerAuthConfig = (action, auth)=>{
|
|
15
|
+
return extension.use({
|
|
16
|
+
resolversConfig: {
|
|
17
|
+
[action]: {
|
|
18
|
+
auth
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
});
|
|
22
|
+
};
|
|
23
|
+
const isActionEnabled = (action)=>{
|
|
24
|
+
return extension.shadowCRUD(contentType.uid).isActionEnabled(action);
|
|
25
|
+
};
|
|
26
|
+
const isFindOneEnabled = isActionEnabled('findOne');
|
|
27
|
+
const isFindEnabled = isActionEnabled('find');
|
|
28
|
+
if (isFindOneEnabled) {
|
|
29
|
+
registerAuthConfig(findOneQueryName, {
|
|
30
|
+
scope: [
|
|
31
|
+
`${contentType.uid}.findOne`
|
|
32
|
+
]
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
if (isFindEnabled) {
|
|
36
|
+
registerAuthConfig(findQueryName, {
|
|
37
|
+
scope: [
|
|
38
|
+
`${contentType.uid}.find`
|
|
39
|
+
]
|
|
40
|
+
});
|
|
41
|
+
registerAuthConfig(findConnectionQueryName, {
|
|
42
|
+
scope: [
|
|
43
|
+
`${contentType.uid}.find`
|
|
44
|
+
]
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
return extendType({
|
|
48
|
+
type: 'Query',
|
|
49
|
+
definition (t) {
|
|
50
|
+
if (isFindOneEnabled) {
|
|
51
|
+
addFindOneQuery(t, contentType);
|
|
52
|
+
}
|
|
53
|
+
if (isFindEnabled) {
|
|
54
|
+
addFindConnectionQuery(t, contentType);
|
|
55
|
+
addFindQuery(t, contentType);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
};
|
|
60
|
+
/**
|
|
61
|
+
* Register a "find one" query field to the nexus type definition
|
|
62
|
+
*/ const addFindOneQuery = (t, contentType)=>{
|
|
63
|
+
const findOneQueryName = getFindOneQueryName(contentType);
|
|
64
|
+
const typeName = getTypeName(contentType);
|
|
65
|
+
t.field(findOneQueryName, {
|
|
66
|
+
type: typeName,
|
|
67
|
+
extensions: {
|
|
68
|
+
strapi: {
|
|
69
|
+
contentType
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
args: getContentTypeArgs(contentType, {
|
|
73
|
+
multiple: false
|
|
74
|
+
}),
|
|
75
|
+
async resolve (parent, args, ctx) {
|
|
76
|
+
const transformedArgs = transformArgs(args, {
|
|
77
|
+
contentType
|
|
78
|
+
});
|
|
79
|
+
const { findOne } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
80
|
+
contentType
|
|
81
|
+
});
|
|
82
|
+
// queryResolvers will sanitize params
|
|
83
|
+
return findOne(parent, transformedArgs, ctx);
|
|
84
|
+
}
|
|
85
|
+
});
|
|
86
|
+
};
|
|
87
|
+
/**
|
|
88
|
+
* Register a "find" query field to the nexus type definition
|
|
89
|
+
*/ const addFindQuery = (t, contentType)=>{
|
|
90
|
+
const findQueryName = getFindQueryName(contentType);
|
|
91
|
+
const typeName = getTypeName(contentType);
|
|
92
|
+
t.field(findQueryName, {
|
|
93
|
+
type: nonNull(list(typeName)),
|
|
94
|
+
extensions: {
|
|
95
|
+
strapi: {
|
|
96
|
+
contentType
|
|
97
|
+
}
|
|
98
|
+
},
|
|
99
|
+
args: getContentTypeArgs(contentType),
|
|
100
|
+
async resolve (parent, args, ctx) {
|
|
101
|
+
const transformedArgs = transformArgs(args, {
|
|
102
|
+
contentType,
|
|
103
|
+
usePagination: true
|
|
104
|
+
});
|
|
105
|
+
const { findMany } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
106
|
+
contentType
|
|
107
|
+
});
|
|
108
|
+
// queryResolvers will sanitize params
|
|
109
|
+
return findMany(parent, transformedArgs, ctx);
|
|
110
|
+
}
|
|
111
|
+
});
|
|
112
|
+
};
|
|
113
|
+
/**
|
|
114
|
+
* Register a "find" query field to the nexus type definition
|
|
115
|
+
*/ const addFindConnectionQuery = (t, contentType)=>{
|
|
116
|
+
const { uid } = contentType;
|
|
117
|
+
const queryName = getFindConnectionQueryName(contentType);
|
|
118
|
+
const responseCollectionTypeName = getEntityResponseCollectionName(contentType);
|
|
119
|
+
t.field(queryName, {
|
|
120
|
+
type: responseCollectionTypeName,
|
|
121
|
+
extensions: {
|
|
122
|
+
strapi: {
|
|
123
|
+
contentType
|
|
124
|
+
}
|
|
125
|
+
},
|
|
126
|
+
args: getContentTypeArgs(contentType),
|
|
127
|
+
async resolve (parent, args, ctx) {
|
|
128
|
+
const transformedArgs = transformArgs(args, {
|
|
129
|
+
contentType,
|
|
130
|
+
usePagination: true
|
|
131
|
+
});
|
|
132
|
+
const { findMany } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
133
|
+
contentType
|
|
134
|
+
});
|
|
135
|
+
// queryResolvers will sanitize params
|
|
136
|
+
const nodes = await findMany(parent, transformedArgs, ctx);
|
|
137
|
+
return toEntityResponseCollection(nodes, {
|
|
138
|
+
args: transformedArgs,
|
|
139
|
+
resourceUID: uid
|
|
140
|
+
});
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
};
|
|
144
|
+
return {
|
|
145
|
+
buildCollectionTypeQueries
|
|
146
|
+
};
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
export { createCollectionTypeQueriesBuilder as default };
|
|
150
|
+
//# sourceMappingURL=collection-type.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-type.mjs","sources":["../../../../../server/src/services/builders/queries/collection-type.ts"],"sourcesContent":["import { extendType, nonNull, list } from 'nexus';\nimport type * as Nexus from 'nexus';\nimport type { Struct } from '@strapi/types';\nimport type { Context } from '../../types';\n\nexport default ({ strapi }: Context) => {\n const { service: getService } = strapi.plugin('graphql');\n\n const { naming } = getService('utils');\n const { transformArgs, getContentTypeArgs } = getService('builders').utils;\n const { toEntityResponseCollection } = getService('format').returnTypes;\n\n const {\n getFindOneQueryName,\n getTypeName,\n getFindQueryName,\n getFindConnectionQueryName,\n getEntityResponseCollectionName,\n } = naming;\n\n const buildCollectionTypeQueries = (contentType: Struct.CollectionTypeSchema) => {\n const findOneQueryName = `Query.${getFindOneQueryName(contentType)}`;\n const findQueryName = `Query.${getFindQueryName(contentType)}`;\n const findConnectionQueryName = `Query.${getFindConnectionQueryName(contentType)}`;\n\n const extension = getService('extension');\n\n const registerAuthConfig = (action: string, auth: any) => {\n return extension.use({ resolversConfig: { [action]: { auth } } });\n };\n\n const isActionEnabled = (action: string) => {\n return extension.shadowCRUD(contentType.uid).isActionEnabled(action);\n };\n\n const isFindOneEnabled = isActionEnabled('findOne');\n const isFindEnabled = isActionEnabled('find');\n\n if (isFindOneEnabled) {\n registerAuthConfig(findOneQueryName, { scope: [`${contentType.uid}.findOne`] });\n }\n\n if (isFindEnabled) {\n registerAuthConfig(findQueryName, { scope: [`${contentType.uid}.find`] });\n registerAuthConfig(findConnectionQueryName, { scope: [`${contentType.uid}.find`] });\n }\n\n return extendType({\n type: 'Query',\n\n definition(t) {\n if (isFindOneEnabled) {\n addFindOneQuery(t, contentType);\n }\n\n if (isFindEnabled) {\n addFindConnectionQuery(t, contentType);\n addFindQuery(t, contentType);\n }\n },\n });\n };\n\n /**\n * Register a \"find one\" query field to the nexus type definition\n */\n const addFindOneQuery = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Query'>,\n contentType: Struct.CollectionTypeSchema\n ) => {\n const findOneQueryName = getFindOneQueryName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(findOneQueryName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: getContentTypeArgs(contentType, { multiple: false }),\n\n async resolve(parent, args, ctx) {\n const transformedArgs = transformArgs(args, { contentType });\n\n const { findOne } = getService('builders')\n .get('content-api')\n .buildQueriesResolvers({ contentType });\n\n // queryResolvers will sanitize params\n return findOne(parent, transformedArgs, ctx);\n },\n });\n };\n\n /**\n * Register a \"find\" query field to the nexus type definition\n */\n const addFindQuery = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Query'>,\n contentType: Struct.CollectionTypeSchema\n ) => {\n const findQueryName = getFindQueryName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(findQueryName, {\n type: nonNull(list(typeName)),\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: getContentTypeArgs(contentType),\n\n async resolve(parent, args, ctx) {\n const transformedArgs = transformArgs(args, { contentType, usePagination: true });\n\n const { findMany } = getService('builders')\n .get('content-api')\n .buildQueriesResolvers({ contentType });\n\n // queryResolvers will sanitize params\n return findMany(parent, transformedArgs, ctx);\n },\n });\n };\n\n /**\n * Register a \"find\" query field to the nexus type definition\n */\n const addFindConnectionQuery = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Query'>,\n contentType: Struct.CollectionTypeSchema\n ) => {\n const { uid } = contentType;\n\n const queryName = getFindConnectionQueryName(contentType);\n const responseCollectionTypeName = getEntityResponseCollectionName(contentType);\n\n t.field(queryName, {\n type: responseCollectionTypeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: getContentTypeArgs(contentType),\n\n async resolve(parent, args, ctx) {\n const transformedArgs = transformArgs(args, { contentType, usePagination: true });\n\n const { findMany } = getService('builders')\n .get('content-api')\n .buildQueriesResolvers({ contentType });\n\n // queryResolvers will sanitize params\n const nodes = await findMany(parent, transformedArgs, ctx);\n\n return toEntityResponseCollection(nodes, { args: transformedArgs, resourceUID: uid });\n },\n });\n };\n\n return { buildCollectionTypeQueries };\n};\n"],"names":["strapi","service","getService","plugin","naming","transformArgs","getContentTypeArgs","utils","toEntityResponseCollection","returnTypes","getFindOneQueryName","getTypeName","getFindQueryName","getFindConnectionQueryName","getEntityResponseCollectionName","buildCollectionTypeQueries","contentType","findOneQueryName","findQueryName","findConnectionQueryName","extension","registerAuthConfig","action","auth","use","resolversConfig","isActionEnabled","shadowCRUD","uid","isFindOneEnabled","isFindEnabled","scope","extendType","type","definition","t","addFindOneQuery","addFindConnectionQuery","addFindQuery","typeName","field","extensions","args","multiple","resolve","parent","ctx","transformedArgs","findOne","get","buildQueriesResolvers","nonNull","list","usePagination","findMany","queryName","responseCollectionTypeName","nodes","resourceUID"],"mappings":";;AAKA,yCAAe,CAAA,CAAC,EAAEA,MAAM,EAAW,GAAA;AACjC,IAAA,MAAM,EAAEC,OAASC,EAAAA,UAAU,EAAE,GAAGF,MAAAA,CAAOG,MAAM,CAAC,SAAA,CAAA;AAE9C,IAAA,MAAM,EAAEC,MAAM,EAAE,GAAGF,UAAW,CAAA,OAAA,CAAA;IAC9B,MAAM,EAAEG,aAAa,EAAEC,kBAAkB,EAAE,GAAGJ,UAAAA,CAAW,YAAYK,KAAK;AAC1E,IAAA,MAAM,EAAEC,0BAA0B,EAAE,GAAGN,UAAAA,CAAW,UAAUO,WAAW;IAEvE,MAAM,EACJC,mBAAmB,EACnBC,WAAW,EACXC,gBAAgB,EAChBC,0BAA0B,EAC1BC,+BAA+B,EAChC,GAAGV,MAAAA;AAEJ,IAAA,MAAMW,6BAA6B,CAACC,WAAAA,GAAAA;AAClC,QAAA,MAAMC,mBAAmB,CAAC,MAAM,EAAEP,mBAAAA,CAAoBM,aAAa,CAAC;AACpE,QAAA,MAAME,gBAAgB,CAAC,MAAM,EAAEN,gBAAAA,CAAiBI,aAAa,CAAC;AAC9D,QAAA,MAAMG,0BAA0B,CAAC,MAAM,EAAEN,0BAAAA,CAA2BG,aAAa,CAAC;AAElF,QAAA,MAAMI,YAAYlB,UAAW,CAAA,WAAA,CAAA;QAE7B,MAAMmB,kBAAAA,GAAqB,CAACC,MAAgBC,EAAAA,IAAAA,GAAAA;YAC1C,OAAOH,SAAAA,CAAUI,GAAG,CAAC;gBAAEC,eAAiB,EAAA;AAAE,oBAAA,CAACH,SAAS;AAAEC,wBAAAA;AAAK;AAAE;AAAE,aAAA,CAAA;AACjE,SAAA;AAEA,QAAA,MAAMG,kBAAkB,CAACJ,MAAAA,GAAAA;AACvB,YAAA,OAAOF,UAAUO,UAAU,CAACX,YAAYY,GAAG,CAAA,CAAEF,eAAe,CAACJ,MAAAA,CAAAA;AAC/D,SAAA;AAEA,QAAA,MAAMO,mBAAmBH,eAAgB,CAAA,SAAA,CAAA;AACzC,QAAA,MAAMI,gBAAgBJ,eAAgB,CAAA,MAAA,CAAA;AAEtC,QAAA,IAAIG,gBAAkB,EAAA;AACpBR,YAAAA,kBAAAA,CAAmBJ,gBAAkB,EAAA;gBAAEc,KAAO,EAAA;AAAC,oBAAA,CAAC,EAAEf,WAAAA,CAAYY,GAAG,CAAC,QAAQ;AAAE;AAAC,aAAA,CAAA;AAC/E;AAEA,QAAA,IAAIE,aAAe,EAAA;AACjBT,YAAAA,kBAAAA,CAAmBH,aAAe,EAAA;gBAAEa,KAAO,EAAA;AAAC,oBAAA,CAAC,EAAEf,WAAAA,CAAYY,GAAG,CAAC,KAAK;AAAE;AAAC,aAAA,CAAA;AACvEP,YAAAA,kBAAAA,CAAmBF,uBAAyB,EAAA;gBAAEY,KAAO,EAAA;AAAC,oBAAA,CAAC,EAAEf,WAAAA,CAAYY,GAAG,CAAC,KAAK;AAAE;AAAC,aAAA,CAAA;AACnF;AAEA,QAAA,OAAOI,UAAW,CAAA;YAChBC,IAAM,EAAA,OAAA;AAENC,YAAAA,UAAAA,CAAAA,CAAWC,CAAC,EAAA;AACV,gBAAA,IAAIN,gBAAkB,EAAA;AACpBO,oBAAAA,eAAAA,CAAgBD,CAAGnB,EAAAA,WAAAA,CAAAA;AACrB;AAEA,gBAAA,IAAIc,aAAe,EAAA;AACjBO,oBAAAA,sBAAAA,CAAuBF,CAAGnB,EAAAA,WAAAA,CAAAA;AAC1BsB,oBAAAA,YAAAA,CAAaH,CAAGnB,EAAAA,WAAAA,CAAAA;AAClB;AACF;AACF,SAAA,CAAA;AACF,KAAA;AAEA;;MAGA,MAAMoB,eAAkB,GAAA,CACtBD,CACAnB,EAAAA,WAAAA,GAAAA;AAEA,QAAA,MAAMC,mBAAmBP,mBAAoBM,CAAAA,WAAAA,CAAAA;AAC7C,QAAA,MAAMuB,WAAW5B,WAAYK,CAAAA,WAAAA,CAAAA;QAE7BmB,CAAEK,CAAAA,KAAK,CAACvB,gBAAkB,EAAA;YACxBgB,IAAMM,EAAAA,QAAAA;YAENE,UAAY,EAAA;gBACVzC,MAAQ,EAAA;AACNgB,oBAAAA;AACF;AACF,aAAA;AAEA0B,YAAAA,IAAAA,EAAMpC,mBAAmBU,WAAa,EAAA;gBAAE2B,QAAU,EAAA;AAAM,aAAA,CAAA;AAExD,YAAA,MAAMC,OAAQC,CAAAA,CAAAA,MAAM,EAAEH,IAAI,EAAEI,GAAG,EAAA;gBAC7B,MAAMC,eAAAA,GAAkB1C,cAAcqC,IAAM,EAAA;AAAE1B,oBAAAA;AAAY,iBAAA,CAAA;gBAE1D,MAAM,EAAEgC,OAAO,EAAE,GAAG9C,UAAAA,CAAW,YAC5B+C,GAAG,CAAC,aACJC,CAAAA,CAAAA,qBAAqB,CAAC;AAAElC,oBAAAA;AAAY,iBAAA,CAAA;;gBAGvC,OAAOgC,OAAAA,CAAQH,QAAQE,eAAiBD,EAAAA,GAAAA,CAAAA;AAC1C;AACF,SAAA,CAAA;AACF,KAAA;AAEA;;MAGA,MAAMR,YAAe,GAAA,CACnBH,CACAnB,EAAAA,WAAAA,GAAAA;AAEA,QAAA,MAAME,gBAAgBN,gBAAiBI,CAAAA,WAAAA,CAAAA;AACvC,QAAA,MAAMuB,WAAW5B,WAAYK,CAAAA,WAAAA,CAAAA;QAE7BmB,CAAEK,CAAAA,KAAK,CAACtB,aAAe,EAAA;AACrBe,YAAAA,IAAAA,EAAMkB,QAAQC,IAAKb,CAAAA,QAAAA,CAAAA,CAAAA;YAEnBE,UAAY,EAAA;gBACVzC,MAAQ,EAAA;AACNgB,oBAAAA;AACF;AACF,aAAA;AAEA0B,YAAAA,IAAAA,EAAMpC,kBAAmBU,CAAAA,WAAAA,CAAAA;AAEzB,YAAA,MAAM4B,OAAQC,CAAAA,CAAAA,MAAM,EAAEH,IAAI,EAAEI,GAAG,EAAA;gBAC7B,MAAMC,eAAAA,GAAkB1C,cAAcqC,IAAM,EAAA;AAAE1B,oBAAAA,WAAAA;oBAAaqC,aAAe,EAAA;AAAK,iBAAA,CAAA;gBAE/E,MAAM,EAAEC,QAAQ,EAAE,GAAGpD,UAAAA,CAAW,YAC7B+C,GAAG,CAAC,aACJC,CAAAA,CAAAA,qBAAqB,CAAC;AAAElC,oBAAAA;AAAY,iBAAA,CAAA;;gBAGvC,OAAOsC,QAAAA,CAAST,QAAQE,eAAiBD,EAAAA,GAAAA,CAAAA;AAC3C;AACF,SAAA,CAAA;AACF,KAAA;AAEA;;MAGA,MAAMT,sBAAyB,GAAA,CAC7BF,CACAnB,EAAAA,WAAAA,GAAAA;QAEA,MAAM,EAAEY,GAAG,EAAE,GAAGZ,WAAAA;AAEhB,QAAA,MAAMuC,YAAY1C,0BAA2BG,CAAAA,WAAAA,CAAAA;AAC7C,QAAA,MAAMwC,6BAA6B1C,+BAAgCE,CAAAA,WAAAA,CAAAA;QAEnEmB,CAAEK,CAAAA,KAAK,CAACe,SAAW,EAAA;YACjBtB,IAAMuB,EAAAA,0BAAAA;YAENf,UAAY,EAAA;gBACVzC,MAAQ,EAAA;AACNgB,oBAAAA;AACF;AACF,aAAA;AAEA0B,YAAAA,IAAAA,EAAMpC,kBAAmBU,CAAAA,WAAAA,CAAAA;AAEzB,YAAA,MAAM4B,OAAQC,CAAAA,CAAAA,MAAM,EAAEH,IAAI,EAAEI,GAAG,EAAA;gBAC7B,MAAMC,eAAAA,GAAkB1C,cAAcqC,IAAM,EAAA;AAAE1B,oBAAAA,WAAAA;oBAAaqC,aAAe,EAAA;AAAK,iBAAA,CAAA;gBAE/E,MAAM,EAAEC,QAAQ,EAAE,GAAGpD,UAAAA,CAAW,YAC7B+C,GAAG,CAAC,aACJC,CAAAA,CAAAA,qBAAqB,CAAC;AAAElC,oBAAAA;AAAY,iBAAA,CAAA;;AAGvC,gBAAA,MAAMyC,KAAQ,GAAA,MAAMH,QAAST,CAAAA,MAAAA,EAAQE,eAAiBD,EAAAA,GAAAA,CAAAA;AAEtD,gBAAA,OAAOtC,2BAA2BiD,KAAO,EAAA;oBAAEf,IAAMK,EAAAA,eAAAA;oBAAiBW,WAAa9B,EAAAA;AAAI,iBAAA,CAAA;AACrF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,OAAO;AAAEb,QAAAA;AAA2B,KAAA;AACtC,CAAA;;;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var collectionType = require('./collection-type.js');
|
|
4
|
+
var singleType = require('./single-type.js');
|
|
5
|
+
|
|
6
|
+
var queries = ((context)=>({
|
|
7
|
+
...collectionType(context),
|
|
8
|
+
...singleType(context)
|
|
9
|
+
}));
|
|
10
|
+
|
|
11
|
+
module.exports = queries;
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../server/src/services/builders/queries/index.ts"],"sourcesContent":["import createCollectionTypeQueriesBuilder from './collection-type';\nimport createSingleTypeQueriesBuilder from './single-type';\nimport type { Context } from '../../types';\n\nexport default (context: Context) => ({\n ...createCollectionTypeQueriesBuilder(context),\n ...createSingleTypeQueriesBuilder(context),\n});\n"],"names":["context","createCollectionTypeQueriesBuilder","createSingleTypeQueriesBuilder"],"mappings":";;;;;AAIA,cAAe,CAAA,CAACA,OAAAA,IAAsB;AACpC,QAAA,GAAGC,eAAmCD,OAAQ,CAAA;AAC9C,QAAA,GAAGE,WAA+BF,OAAQ;AAC5C,KAAA,CAAC;;;;"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import createCollectionTypeQueriesBuilder from './collection-type.mjs';
|
|
2
|
+
import createSingleTypeQueriesBuilder from './single-type.mjs';
|
|
3
|
+
|
|
4
|
+
var queries = ((context)=>({
|
|
5
|
+
...createCollectionTypeQueriesBuilder(context),
|
|
6
|
+
...createSingleTypeQueriesBuilder(context)
|
|
7
|
+
}));
|
|
8
|
+
|
|
9
|
+
export { queries as default };
|
|
10
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../server/src/services/builders/queries/index.ts"],"sourcesContent":["import createCollectionTypeQueriesBuilder from './collection-type';\nimport createSingleTypeQueriesBuilder from './single-type';\nimport type { Context } from '../../types';\n\nexport default (context: Context) => ({\n ...createCollectionTypeQueriesBuilder(context),\n ...createSingleTypeQueriesBuilder(context),\n});\n"],"names":["context","createCollectionTypeQueriesBuilder","createSingleTypeQueriesBuilder"],"mappings":";;;AAIA,cAAe,CAAA,CAACA,OAAAA,IAAsB;AACpC,QAAA,GAAGC,mCAAmCD,OAAQ,CAAA;AAC9C,QAAA,GAAGE,+BAA+BF,OAAQ;AAC5C,KAAA,CAAC;;;;"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var nexus = require('nexus');
|
|
4
|
+
|
|
5
|
+
var createSingleTypeQueriesBuilder = (({ strapi })=>{
|
|
6
|
+
const { service: getService } = strapi.plugin('graphql');
|
|
7
|
+
const { naming } = getService('utils');
|
|
8
|
+
const { transformArgs, getContentTypeArgs } = getService('builders').utils;
|
|
9
|
+
const { getFindOneQueryName, getTypeName } = naming;
|
|
10
|
+
const buildSingleTypeQueries = (contentType)=>{
|
|
11
|
+
const findQueryName = `Query.${getFindOneQueryName(contentType)}`;
|
|
12
|
+
const extension = getService('extension');
|
|
13
|
+
const registerAuthConfig = (action, auth)=>{
|
|
14
|
+
return extension.use({
|
|
15
|
+
resolversConfig: {
|
|
16
|
+
[action]: {
|
|
17
|
+
auth
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
});
|
|
21
|
+
};
|
|
22
|
+
const isActionEnabled = (action)=>{
|
|
23
|
+
return extension.shadowCRUD(contentType.uid).isActionEnabled(action);
|
|
24
|
+
};
|
|
25
|
+
const isFindEnabled = isActionEnabled('find');
|
|
26
|
+
if (isFindEnabled) {
|
|
27
|
+
registerAuthConfig(findQueryName, {
|
|
28
|
+
scope: [
|
|
29
|
+
`${contentType.uid}.find`
|
|
30
|
+
]
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
return nexus.extendType({
|
|
34
|
+
type: 'Query',
|
|
35
|
+
definition (t) {
|
|
36
|
+
if (isFindEnabled) {
|
|
37
|
+
addFindQuery(t, contentType);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
});
|
|
41
|
+
};
|
|
42
|
+
const addFindQuery = (t, contentType)=>{
|
|
43
|
+
const findQueryName = getFindOneQueryName(contentType);
|
|
44
|
+
const typeName = getTypeName(contentType);
|
|
45
|
+
t.field(findQueryName, {
|
|
46
|
+
type: typeName,
|
|
47
|
+
extensions: {
|
|
48
|
+
strapi: {
|
|
49
|
+
contentType
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
args: getContentTypeArgs(contentType),
|
|
53
|
+
async resolve (parent, args, ctx) {
|
|
54
|
+
const transformedArgs = transformArgs(args, {
|
|
55
|
+
contentType
|
|
56
|
+
});
|
|
57
|
+
const { findFirst } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
58
|
+
contentType
|
|
59
|
+
});
|
|
60
|
+
return findFirst(parent, transformedArgs, ctx);
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
};
|
|
64
|
+
return {
|
|
65
|
+
buildSingleTypeQueries
|
|
66
|
+
};
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
module.exports = createSingleTypeQueriesBuilder;
|
|
70
|
+
//# sourceMappingURL=single-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"single-type.js","sources":["../../../../../server/src/services/builders/queries/single-type.ts"],"sourcesContent":["import { extendType } from 'nexus';\nimport type * as Nexus from 'nexus';\nimport type { Struct } from '@strapi/types';\nimport type { Context } from '../../types';\n\nexport default ({ strapi }: Context) => {\n const { service: getService } = strapi.plugin('graphql');\n\n const { naming } = getService('utils');\n const { transformArgs, getContentTypeArgs } = getService('builders').utils;\n\n const { getFindOneQueryName, getTypeName } = naming;\n\n const buildSingleTypeQueries = (contentType: Struct.SingleTypeSchema) => {\n const findQueryName = `Query.${getFindOneQueryName(contentType)}`;\n\n const extension = getService('extension');\n\n const registerAuthConfig = (action: string, auth: any) => {\n return extension.use({ resolversConfig: { [action]: { auth } } });\n };\n\n const isActionEnabled = (action: string) => {\n return extension.shadowCRUD(contentType.uid).isActionEnabled(action);\n };\n\n const isFindEnabled = isActionEnabled('find');\n\n if (isFindEnabled) {\n registerAuthConfig(findQueryName, { scope: [`${contentType.uid}.find`] });\n }\n\n return extendType({\n type: 'Query',\n\n definition(t) {\n if (isFindEnabled) {\n addFindQuery(t, contentType);\n }\n },\n });\n };\n\n const addFindQuery = (\n t: Nexus.blocks.ObjectDefinitionBlock<string>,\n contentType: Struct.SingleTypeSchema\n ) => {\n const findQueryName = getFindOneQueryName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(findQueryName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: getContentTypeArgs(contentType),\n\n async resolve(parent, args, ctx) {\n const transformedArgs = transformArgs(args, { contentType });\n\n const { findFirst } = getService('builders')\n .get('content-api')\n .buildQueriesResolvers({ contentType });\n\n return findFirst(parent, transformedArgs, ctx);\n },\n });\n };\n\n return { buildSingleTypeQueries };\n};\n"],"names":["strapi","service","getService","plugin","naming","transformArgs","getContentTypeArgs","utils","getFindOneQueryName","getTypeName","buildSingleTypeQueries","contentType","findQueryName","extension","registerAuthConfig","action","auth","use","resolversConfig","isActionEnabled","shadowCRUD","uid","isFindEnabled","scope","extendType","type","definition","t","addFindQuery","typeName","field","extensions","args","resolve","parent","ctx","transformedArgs","findFirst","get","buildQueriesResolvers"],"mappings":";;;;AAKA,qCAAe,CAAA,CAAC,EAAEA,MAAM,EAAW,GAAA;AACjC,IAAA,MAAM,EAAEC,OAASC,EAAAA,UAAU,EAAE,GAAGF,MAAAA,CAAOG,MAAM,CAAC,SAAA,CAAA;AAE9C,IAAA,MAAM,EAAEC,MAAM,EAAE,GAAGF,UAAW,CAAA,OAAA,CAAA;IAC9B,MAAM,EAAEG,aAAa,EAAEC,kBAAkB,EAAE,GAAGJ,UAAAA,CAAW,YAAYK,KAAK;AAE1E,IAAA,MAAM,EAAEC,mBAAmB,EAAEC,WAAW,EAAE,GAAGL,MAAAA;AAE7C,IAAA,MAAMM,yBAAyB,CAACC,WAAAA,GAAAA;AAC9B,QAAA,MAAMC,gBAAgB,CAAC,MAAM,EAAEJ,mBAAAA,CAAoBG,aAAa,CAAC;AAEjE,QAAA,MAAME,YAAYX,UAAW,CAAA,WAAA,CAAA;QAE7B,MAAMY,kBAAAA,GAAqB,CAACC,MAAgBC,EAAAA,IAAAA,GAAAA;YAC1C,OAAOH,SAAAA,CAAUI,GAAG,CAAC;gBAAEC,eAAiB,EAAA;AAAE,oBAAA,CAACH,SAAS;AAAEC,wBAAAA;AAAK;AAAE;AAAE,aAAA,CAAA;AACjE,SAAA;AAEA,QAAA,MAAMG,kBAAkB,CAACJ,MAAAA,GAAAA;AACvB,YAAA,OAAOF,UAAUO,UAAU,CAACT,YAAYU,GAAG,CAAA,CAAEF,eAAe,CAACJ,MAAAA,CAAAA;AAC/D,SAAA;AAEA,QAAA,MAAMO,gBAAgBH,eAAgB,CAAA,MAAA,CAAA;AAEtC,QAAA,IAAIG,aAAe,EAAA;AACjBR,YAAAA,kBAAAA,CAAmBF,aAAe,EAAA;gBAAEW,KAAO,EAAA;AAAC,oBAAA,CAAC,EAAEZ,WAAAA,CAAYU,GAAG,CAAC,KAAK;AAAE;AAAC,aAAA,CAAA;AACzE;AAEA,QAAA,OAAOG,gBAAW,CAAA;YAChBC,IAAM,EAAA,OAAA;AAENC,YAAAA,UAAAA,CAAAA,CAAWC,CAAC,EAAA;AACV,gBAAA,IAAIL,aAAe,EAAA;AACjBM,oBAAAA,YAAAA,CAAaD,CAAGhB,EAAAA,WAAAA,CAAAA;AAClB;AACF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,MAAMiB,YAAAA,GAAe,CACnBD,CACAhB,EAAAA,WAAAA,GAAAA;AAEA,QAAA,MAAMC,gBAAgBJ,mBAAoBG,CAAAA,WAAAA,CAAAA;AAC1C,QAAA,MAAMkB,WAAWpB,WAAYE,CAAAA,WAAAA,CAAAA;QAE7BgB,CAAEG,CAAAA,KAAK,CAAClB,aAAe,EAAA;YACrBa,IAAMI,EAAAA,QAAAA;YAENE,UAAY,EAAA;gBACV/B,MAAQ,EAAA;AACNW,oBAAAA;AACF;AACF,aAAA;AAEAqB,YAAAA,IAAAA,EAAM1B,kBAAmBK,CAAAA,WAAAA,CAAAA;AAEzB,YAAA,MAAMsB,OAAQC,CAAAA,CAAAA,MAAM,EAAEF,IAAI,EAAEG,GAAG,EAAA;gBAC7B,MAAMC,eAAAA,GAAkB/B,cAAc2B,IAAM,EAAA;AAAErB,oBAAAA;AAAY,iBAAA,CAAA;gBAE1D,MAAM,EAAE0B,SAAS,EAAE,GAAGnC,UAAAA,CAAW,YAC9BoC,GAAG,CAAC,aACJC,CAAAA,CAAAA,qBAAqB,CAAC;AAAE5B,oBAAAA;AAAY,iBAAA,CAAA;gBAEvC,OAAO0B,SAAAA,CAAUH,QAAQE,eAAiBD,EAAAA,GAAAA,CAAAA;AAC5C;AACF,SAAA,CAAA;AACF,KAAA;IAEA,OAAO;AAAEzB,QAAAA;AAAuB,KAAA;AAClC,CAAA;;;;"}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import { extendType } from 'nexus';
|
|
2
|
+
|
|
3
|
+
var createSingleTypeQueriesBuilder = (({ strapi })=>{
|
|
4
|
+
const { service: getService } = strapi.plugin('graphql');
|
|
5
|
+
const { naming } = getService('utils');
|
|
6
|
+
const { transformArgs, getContentTypeArgs } = getService('builders').utils;
|
|
7
|
+
const { getFindOneQueryName, getTypeName } = naming;
|
|
8
|
+
const buildSingleTypeQueries = (contentType)=>{
|
|
9
|
+
const findQueryName = `Query.${getFindOneQueryName(contentType)}`;
|
|
10
|
+
const extension = getService('extension');
|
|
11
|
+
const registerAuthConfig = (action, auth)=>{
|
|
12
|
+
return extension.use({
|
|
13
|
+
resolversConfig: {
|
|
14
|
+
[action]: {
|
|
15
|
+
auth
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
};
|
|
20
|
+
const isActionEnabled = (action)=>{
|
|
21
|
+
return extension.shadowCRUD(contentType.uid).isActionEnabled(action);
|
|
22
|
+
};
|
|
23
|
+
const isFindEnabled = isActionEnabled('find');
|
|
24
|
+
if (isFindEnabled) {
|
|
25
|
+
registerAuthConfig(findQueryName, {
|
|
26
|
+
scope: [
|
|
27
|
+
`${contentType.uid}.find`
|
|
28
|
+
]
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
return extendType({
|
|
32
|
+
type: 'Query',
|
|
33
|
+
definition (t) {
|
|
34
|
+
if (isFindEnabled) {
|
|
35
|
+
addFindQuery(t, contentType);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
};
|
|
40
|
+
const addFindQuery = (t, contentType)=>{
|
|
41
|
+
const findQueryName = getFindOneQueryName(contentType);
|
|
42
|
+
const typeName = getTypeName(contentType);
|
|
43
|
+
t.field(findQueryName, {
|
|
44
|
+
type: typeName,
|
|
45
|
+
extensions: {
|
|
46
|
+
strapi: {
|
|
47
|
+
contentType
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
args: getContentTypeArgs(contentType),
|
|
51
|
+
async resolve (parent, args, ctx) {
|
|
52
|
+
const transformedArgs = transformArgs(args, {
|
|
53
|
+
contentType
|
|
54
|
+
});
|
|
55
|
+
const { findFirst } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
56
|
+
contentType
|
|
57
|
+
});
|
|
58
|
+
return findFirst(parent, transformedArgs, ctx);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
};
|
|
62
|
+
return {
|
|
63
|
+
buildSingleTypeQueries
|
|
64
|
+
};
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
export { createSingleTypeQueriesBuilder as default };
|
|
68
|
+
//# sourceMappingURL=single-type.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"single-type.mjs","sources":["../../../../../server/src/services/builders/queries/single-type.ts"],"sourcesContent":["import { extendType } from 'nexus';\nimport type * as Nexus from 'nexus';\nimport type { Struct } from '@strapi/types';\nimport type { Context } from '../../types';\n\nexport default ({ strapi }: Context) => {\n const { service: getService } = strapi.plugin('graphql');\n\n const { naming } = getService('utils');\n const { transformArgs, getContentTypeArgs } = getService('builders').utils;\n\n const { getFindOneQueryName, getTypeName } = naming;\n\n const buildSingleTypeQueries = (contentType: Struct.SingleTypeSchema) => {\n const findQueryName = `Query.${getFindOneQueryName(contentType)}`;\n\n const extension = getService('extension');\n\n const registerAuthConfig = (action: string, auth: any) => {\n return extension.use({ resolversConfig: { [action]: { auth } } });\n };\n\n const isActionEnabled = (action: string) => {\n return extension.shadowCRUD(contentType.uid).isActionEnabled(action);\n };\n\n const isFindEnabled = isActionEnabled('find');\n\n if (isFindEnabled) {\n registerAuthConfig(findQueryName, { scope: [`${contentType.uid}.find`] });\n }\n\n return extendType({\n type: 'Query',\n\n definition(t) {\n if (isFindEnabled) {\n addFindQuery(t, contentType);\n }\n },\n });\n };\n\n const addFindQuery = (\n t: Nexus.blocks.ObjectDefinitionBlock<string>,\n contentType: Struct.SingleTypeSchema\n ) => {\n const findQueryName = getFindOneQueryName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(findQueryName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: getContentTypeArgs(contentType),\n\n async resolve(parent, args, ctx) {\n const transformedArgs = transformArgs(args, { contentType });\n\n const { findFirst } = getService('builders')\n .get('content-api')\n .buildQueriesResolvers({ contentType });\n\n return findFirst(parent, transformedArgs, ctx);\n },\n });\n };\n\n return { buildSingleTypeQueries };\n};\n"],"names":["strapi","service","getService","plugin","naming","transformArgs","getContentTypeArgs","utils","getFindOneQueryName","getTypeName","buildSingleTypeQueries","contentType","findQueryName","extension","registerAuthConfig","action","auth","use","resolversConfig","isActionEnabled","shadowCRUD","uid","isFindEnabled","scope","extendType","type","definition","t","addFindQuery","typeName","field","extensions","args","resolve","parent","ctx","transformedArgs","findFirst","get","buildQueriesResolvers"],"mappings":";;AAKA,qCAAe,CAAA,CAAC,EAAEA,MAAM,EAAW,GAAA;AACjC,IAAA,MAAM,EAAEC,OAASC,EAAAA,UAAU,EAAE,GAAGF,MAAAA,CAAOG,MAAM,CAAC,SAAA,CAAA;AAE9C,IAAA,MAAM,EAAEC,MAAM,EAAE,GAAGF,UAAW,CAAA,OAAA,CAAA;IAC9B,MAAM,EAAEG,aAAa,EAAEC,kBAAkB,EAAE,GAAGJ,UAAAA,CAAW,YAAYK,KAAK;AAE1E,IAAA,MAAM,EAAEC,mBAAmB,EAAEC,WAAW,EAAE,GAAGL,MAAAA;AAE7C,IAAA,MAAMM,yBAAyB,CAACC,WAAAA,GAAAA;AAC9B,QAAA,MAAMC,gBAAgB,CAAC,MAAM,EAAEJ,mBAAAA,CAAoBG,aAAa,CAAC;AAEjE,QAAA,MAAME,YAAYX,UAAW,CAAA,WAAA,CAAA;QAE7B,MAAMY,kBAAAA,GAAqB,CAACC,MAAgBC,EAAAA,IAAAA,GAAAA;YAC1C,OAAOH,SAAAA,CAAUI,GAAG,CAAC;gBAAEC,eAAiB,EAAA;AAAE,oBAAA,CAACH,SAAS;AAAEC,wBAAAA;AAAK;AAAE;AAAE,aAAA,CAAA;AACjE,SAAA;AAEA,QAAA,MAAMG,kBAAkB,CAACJ,MAAAA,GAAAA;AACvB,YAAA,OAAOF,UAAUO,UAAU,CAACT,YAAYU,GAAG,CAAA,CAAEF,eAAe,CAACJ,MAAAA,CAAAA;AAC/D,SAAA;AAEA,QAAA,MAAMO,gBAAgBH,eAAgB,CAAA,MAAA,CAAA;AAEtC,QAAA,IAAIG,aAAe,EAAA;AACjBR,YAAAA,kBAAAA,CAAmBF,aAAe,EAAA;gBAAEW,KAAO,EAAA;AAAC,oBAAA,CAAC,EAAEZ,WAAAA,CAAYU,GAAG,CAAC,KAAK;AAAE;AAAC,aAAA,CAAA;AACzE;AAEA,QAAA,OAAOG,UAAW,CAAA;YAChBC,IAAM,EAAA,OAAA;AAENC,YAAAA,UAAAA,CAAAA,CAAWC,CAAC,EAAA;AACV,gBAAA,IAAIL,aAAe,EAAA;AACjBM,oBAAAA,YAAAA,CAAaD,CAAGhB,EAAAA,WAAAA,CAAAA;AAClB;AACF;AACF,SAAA,CAAA;AACF,KAAA;IAEA,MAAMiB,YAAAA,GAAe,CACnBD,CACAhB,EAAAA,WAAAA,GAAAA;AAEA,QAAA,MAAMC,gBAAgBJ,mBAAoBG,CAAAA,WAAAA,CAAAA;AAC1C,QAAA,MAAMkB,WAAWpB,WAAYE,CAAAA,WAAAA,CAAAA;QAE7BgB,CAAEG,CAAAA,KAAK,CAAClB,aAAe,EAAA;YACrBa,IAAMI,EAAAA,QAAAA;YAENE,UAAY,EAAA;gBACV/B,MAAQ,EAAA;AACNW,oBAAAA;AACF;AACF,aAAA;AAEAqB,YAAAA,IAAAA,EAAM1B,kBAAmBK,CAAAA,WAAAA,CAAAA;AAEzB,YAAA,MAAMsB,OAAQC,CAAAA,CAAAA,MAAM,EAAEF,IAAI,EAAEG,GAAG,EAAA;gBAC7B,MAAMC,eAAAA,GAAkB/B,cAAc2B,IAAM,EAAA;AAAErB,oBAAAA;AAAY,iBAAA,CAAA;gBAE1D,MAAM,EAAE0B,SAAS,EAAE,GAAGnC,UAAAA,CAAW,YAC9BoC,GAAG,CAAC,aACJC,CAAAA,CAAAA,qBAAqB,CAAC;AAAE5B,oBAAAA;AAAY,iBAAA,CAAA;gBAEvC,OAAO0B,SAAAA,CAAUH,QAAQE,eAAiBD,EAAAA,GAAAA,CAAAA;AAC5C;AACF,SAAA,CAAA;AACF,KAAA;IAEA,OAAO;AAAEzB,QAAAA;AAAuB,KAAA;AAClC,CAAA;;;;"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var nexus = require('nexus');
|
|
4
|
+
var fp = require('lodash/fp');
|
|
5
|
+
|
|
6
|
+
var relationResponseCollection = (({ strapi })=>{
|
|
7
|
+
const { naming } = strapi.plugin('graphql').service('utils');
|
|
8
|
+
return {
|
|
9
|
+
/**
|
|
10
|
+
* Build a type definition for a content API relation's collection response for a given content type
|
|
11
|
+
*/ buildRelationResponseCollectionDefinition (contentType) {
|
|
12
|
+
const name = naming.getRelationResponseCollectionName(contentType);
|
|
13
|
+
const typeName = naming.getTypeName(contentType);
|
|
14
|
+
return nexus.objectType({
|
|
15
|
+
name,
|
|
16
|
+
definition (t) {
|
|
17
|
+
t.nonNull.list.field('nodes', {
|
|
18
|
+
type: nexus.nonNull(typeName),
|
|
19
|
+
resolve: fp.pipe(fp.prop('nodes'), fp.defaultTo([]))
|
|
20
|
+
});
|
|
21
|
+
if (strapi.plugin('graphql').config('v4CompatibilityMode', false)) {
|
|
22
|
+
t.nonNull.list.field('data', {
|
|
23
|
+
deprecation: 'Use `nodes` field instead',
|
|
24
|
+
type: nexus.nonNull(typeName),
|
|
25
|
+
resolve: fp.pipe(fp.prop('nodes'), fp.defaultTo([]))
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
};
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
module.exports = relationResponseCollection;
|
|
35
|
+
//# sourceMappingURL=relation-response-collection.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation-response-collection.js","sources":["../../../../server/src/services/builders/relation-response-collection.ts"],"sourcesContent":["import { objectType, nonNull } from 'nexus';\nimport { defaultTo, prop, pipe } from 'lodash/fp';\nimport type { Schema } from '@strapi/types';\nimport type { Context } from '../types';\n\nexport default ({ strapi }: Context) => {\n const { naming } = strapi.plugin('graphql').service('utils');\n\n return {\n /**\n * Build a type definition for a content API relation's collection response for a given content type\n */\n buildRelationResponseCollectionDefinition(contentType: Schema.ContentType) {\n const name = naming.getRelationResponseCollectionName(contentType);\n const typeName = naming.getTypeName(contentType);\n\n return objectType({\n name,\n\n definition(t) {\n t.nonNull.list.field('nodes', {\n type: nonNull(typeName),\n\n resolve: pipe(prop('nodes'), defaultTo([])),\n });\n\n if (strapi.plugin('graphql').config('v4CompatibilityMode', false)) {\n t.nonNull.list.field('data', {\n deprecation: 'Use `nodes` field instead',\n type: nonNull(typeName),\n resolve: pipe(prop('nodes'), defaultTo([])),\n });\n }\n },\n });\n },\n };\n};\n"],"names":["strapi","naming","plugin","service","buildRelationResponseCollectionDefinition","contentType","name","getRelationResponseCollectionName","typeName","getTypeName","objectType","definition","t","nonNull","list","field","type","resolve","pipe","prop","defaultTo","config","deprecation"],"mappings":";;;;;AAKA,iCAAe,CAAA,CAAC,EAAEA,MAAM,EAAW,GAAA;IACjC,MAAM,EAAEC,MAAM,EAAE,GAAGD,OAAOE,MAAM,CAAC,SAAWC,CAAAA,CAAAA,OAAO,CAAC,OAAA,CAAA;IAEpD,OAAO;AACL;;AAEC,QACDC,2CAA0CC,WAA+B,EAAA;YACvE,MAAMC,IAAAA,GAAOL,MAAOM,CAAAA,iCAAiC,CAACF,WAAAA,CAAAA;YACtD,MAAMG,QAAAA,GAAWP,MAAOQ,CAAAA,WAAW,CAACJ,WAAAA,CAAAA;AAEpC,YAAA,OAAOK,gBAAW,CAAA;AAChBJ,gBAAAA,IAAAA;AAEAK,gBAAAA,UAAAA,CAAAA,CAAWC,CAAC,EAAA;AACVA,oBAAAA,CAAAA,CAAEC,OAAO,CAACC,IAAI,CAACC,KAAK,CAAC,OAAS,EAAA;AAC5BC,wBAAAA,IAAAA,EAAMH,aAAQL,CAAAA,QAAAA,CAAAA;AAEdS,wBAAAA,OAAAA,EAASC,OAAKC,CAAAA,OAAAA,CAAK,OAAUC,CAAAA,EAAAA,YAAAA,CAAU,EAAE,CAAA;AAC3C,qBAAA,CAAA;AAEA,oBAAA,IAAIpB,OAAOE,MAAM,CAAC,WAAWmB,MAAM,CAAC,uBAAuB,KAAQ,CAAA,EAAA;AACjET,wBAAAA,CAAAA,CAAEC,OAAO,CAACC,IAAI,CAACC,KAAK,CAAC,MAAQ,EAAA;4BAC3BO,WAAa,EAAA,2BAAA;AACbN,4BAAAA,IAAAA,EAAMH,aAAQL,CAAAA,QAAAA,CAAAA;AACdS,4BAAAA,OAAAA,EAASC,OAAKC,CAAAA,OAAAA,CAAK,OAAUC,CAAAA,EAAAA,YAAAA,CAAU,EAAE,CAAA;AAC3C,yBAAA,CAAA;AACF;AACF;AACF,aAAA,CAAA;AACF;AACF,KAAA;AACF,CAAA;;;;"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { objectType, nonNull } from 'nexus';
|
|
2
|
+
import { pipe, prop, defaultTo } from 'lodash/fp';
|
|
3
|
+
|
|
4
|
+
var relationResponseCollection = (({ strapi })=>{
|
|
5
|
+
const { naming } = strapi.plugin('graphql').service('utils');
|
|
6
|
+
return {
|
|
7
|
+
/**
|
|
8
|
+
* Build a type definition for a content API relation's collection response for a given content type
|
|
9
|
+
*/ buildRelationResponseCollectionDefinition (contentType) {
|
|
10
|
+
const name = naming.getRelationResponseCollectionName(contentType);
|
|
11
|
+
const typeName = naming.getTypeName(contentType);
|
|
12
|
+
return objectType({
|
|
13
|
+
name,
|
|
14
|
+
definition (t) {
|
|
15
|
+
t.nonNull.list.field('nodes', {
|
|
16
|
+
type: nonNull(typeName),
|
|
17
|
+
resolve: pipe(prop('nodes'), defaultTo([]))
|
|
18
|
+
});
|
|
19
|
+
if (strapi.plugin('graphql').config('v4CompatibilityMode', false)) {
|
|
20
|
+
t.nonNull.list.field('data', {
|
|
21
|
+
deprecation: 'Use `nodes` field instead',
|
|
22
|
+
type: nonNull(typeName),
|
|
23
|
+
resolve: pipe(prop('nodes'), defaultTo([]))
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
export { relationResponseCollection as default };
|
|
33
|
+
//# sourceMappingURL=relation-response-collection.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"relation-response-collection.mjs","sources":["../../../../server/src/services/builders/relation-response-collection.ts"],"sourcesContent":["import { objectType, nonNull } from 'nexus';\nimport { defaultTo, prop, pipe } from 'lodash/fp';\nimport type { Schema } from '@strapi/types';\nimport type { Context } from '../types';\n\nexport default ({ strapi }: Context) => {\n const { naming } = strapi.plugin('graphql').service('utils');\n\n return {\n /**\n * Build a type definition for a content API relation's collection response for a given content type\n */\n buildRelationResponseCollectionDefinition(contentType: Schema.ContentType) {\n const name = naming.getRelationResponseCollectionName(contentType);\n const typeName = naming.getTypeName(contentType);\n\n return objectType({\n name,\n\n definition(t) {\n t.nonNull.list.field('nodes', {\n type: nonNull(typeName),\n\n resolve: pipe(prop('nodes'), defaultTo([])),\n });\n\n if (strapi.plugin('graphql').config('v4CompatibilityMode', false)) {\n t.nonNull.list.field('data', {\n deprecation: 'Use `nodes` field instead',\n type: nonNull(typeName),\n resolve: pipe(prop('nodes'), defaultTo([])),\n });\n }\n },\n });\n },\n };\n};\n"],"names":["strapi","naming","plugin","service","buildRelationResponseCollectionDefinition","contentType","name","getRelationResponseCollectionName","typeName","getTypeName","objectType","definition","t","nonNull","list","field","type","resolve","pipe","prop","defaultTo","config","deprecation"],"mappings":";;;AAKA,iCAAe,CAAA,CAAC,EAAEA,MAAM,EAAW,GAAA;IACjC,MAAM,EAAEC,MAAM,EAAE,GAAGD,OAAOE,MAAM,CAAC,SAAWC,CAAAA,CAAAA,OAAO,CAAC,OAAA,CAAA;IAEpD,OAAO;AACL;;AAEC,QACDC,2CAA0CC,WAA+B,EAAA;YACvE,MAAMC,IAAAA,GAAOL,MAAOM,CAAAA,iCAAiC,CAACF,WAAAA,CAAAA;YACtD,MAAMG,QAAAA,GAAWP,MAAOQ,CAAAA,WAAW,CAACJ,WAAAA,CAAAA;AAEpC,YAAA,OAAOK,UAAW,CAAA;AAChBJ,gBAAAA,IAAAA;AAEAK,gBAAAA,UAAAA,CAAAA,CAAWC,CAAC,EAAA;AACVA,oBAAAA,CAAAA,CAAEC,OAAO,CAACC,IAAI,CAACC,KAAK,CAAC,OAAS,EAAA;AAC5BC,wBAAAA,IAAAA,EAAMH,OAAQL,CAAAA,QAAAA,CAAAA;AAEdS,wBAAAA,OAAAA,EAASC,IAAKC,CAAAA,IAAAA,CAAK,OAAUC,CAAAA,EAAAA,SAAAA,CAAU,EAAE,CAAA;AAC3C,qBAAA,CAAA;AAEA,oBAAA,IAAIpB,OAAOE,MAAM,CAAC,WAAWmB,MAAM,CAAC,uBAAuB,KAAQ,CAAA,EAAA;AACjET,wBAAAA,CAAAA,CAAEC,OAAO,CAACC,IAAI,CAACC,KAAK,CAAC,MAAQ,EAAA;4BAC3BO,WAAa,EAAA,2BAAA;AACbN,4BAAAA,IAAAA,EAAMH,OAAQL,CAAAA,QAAAA,CAAAA;AACdS,4BAAAA,OAAAA,EAASC,IAAKC,CAAAA,IAAAA,CAAK,OAAUC,CAAAA,EAAAA,SAAAA,CAAU,EAAE,CAAA;AAC3C,yBAAA,CAAA;AACF;AACF;AACF,aAAA,CAAA;AACF;AACF,KAAA;AACF,CAAA;;;;"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var fp = require('lodash/fp');
|
|
4
|
+
var utils = require('@strapi/utils');
|
|
5
|
+
|
|
6
|
+
const { ApplicationError } = utils.errors;
|
|
7
|
+
var associationResolvers = (({ strapi })=>{
|
|
8
|
+
const { service: getGraphQLService } = strapi.plugin('graphql');
|
|
9
|
+
const { isMorphRelation, isMedia } = getGraphQLService('utils').attributes;
|
|
10
|
+
const { transformArgs } = getGraphQLService('builders').utils;
|
|
11
|
+
const { toEntityResponse, toEntityResponseCollection } = getGraphQLService('format').returnTypes;
|
|
12
|
+
return {
|
|
13
|
+
buildAssociationResolver ({ contentTypeUID, attributeName }) {
|
|
14
|
+
const contentType = strapi.getModel(contentTypeUID);
|
|
15
|
+
const attribute = contentType.attributes[attributeName];
|
|
16
|
+
if (!attribute) {
|
|
17
|
+
throw new ApplicationError(`Failed to build an association resolver for ${contentTypeUID}::${attributeName}`);
|
|
18
|
+
}
|
|
19
|
+
const isMediaAttribute = isMedia(attribute);
|
|
20
|
+
const isMorphAttribute = isMorphRelation(attribute);
|
|
21
|
+
const targetUID = isMediaAttribute ? 'plugin::upload.file' : attribute.target;
|
|
22
|
+
const isToMany = isMediaAttribute ? attribute.multiple : attribute.relation.endsWith('Many');
|
|
23
|
+
const targetContentType = strapi.getModel(targetUID);
|
|
24
|
+
return async (parent, args = {}, context = {})=>{
|
|
25
|
+
const { auth } = context.state;
|
|
26
|
+
const transformedArgs = transformArgs(args, {
|
|
27
|
+
contentType: targetContentType,
|
|
28
|
+
usePagination: true
|
|
29
|
+
});
|
|
30
|
+
await strapi.contentAPI.validate.query(transformedArgs, targetContentType, {
|
|
31
|
+
auth
|
|
32
|
+
});
|
|
33
|
+
const sanitizedQuery = await strapi.contentAPI.sanitize.query(transformedArgs, targetContentType, {
|
|
34
|
+
auth
|
|
35
|
+
});
|
|
36
|
+
const dbQuery = strapi.get('query-params').transform(targetUID, sanitizedQuery);
|
|
37
|
+
const data = await strapi.db?.query(contentTypeUID).load(parent, attributeName, dbQuery);
|
|
38
|
+
const info = {
|
|
39
|
+
args: sanitizedQuery,
|
|
40
|
+
resourceUID: targetUID
|
|
41
|
+
};
|
|
42
|
+
// If this a polymorphic association, it sanitizes & returns the raw data
|
|
43
|
+
// Note: The value needs to be wrapped in a fake object that represents its parent
|
|
44
|
+
// so that the sanitize util can work properly.
|
|
45
|
+
if (isMorphAttribute) {
|
|
46
|
+
// Helpers used for the data cleanup
|
|
47
|
+
const wrapData = (dataToWrap)=>({
|
|
48
|
+
[attributeName]: dataToWrap
|
|
49
|
+
});
|
|
50
|
+
const sanitizeData = (dataToSanitize)=>{
|
|
51
|
+
return strapi.contentAPI.sanitize.output(dataToSanitize, contentType, {
|
|
52
|
+
auth
|
|
53
|
+
});
|
|
54
|
+
};
|
|
55
|
+
const unwrapData = fp.get(attributeName);
|
|
56
|
+
// Sanitizer definition
|
|
57
|
+
const sanitizeMorphAttribute = utils.async.pipe(wrapData, sanitizeData, unwrapData);
|
|
58
|
+
return sanitizeMorphAttribute(data);
|
|
59
|
+
}
|
|
60
|
+
// If this is a to-many relation, it returns an object that
|
|
61
|
+
// matches what the entity-response-collection's resolvers expect
|
|
62
|
+
if (isToMany) {
|
|
63
|
+
return toEntityResponseCollection(data, info);
|
|
64
|
+
}
|
|
65
|
+
// Else, it returns an object that matches
|
|
66
|
+
// what the entity-response's resolvers expect
|
|
67
|
+
return toEntityResponse(data, info);
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
module.exports = associationResolvers;
|
|
74
|
+
//# sourceMappingURL=association.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"association.js","sources":["../../../../../server/src/services/builders/resolvers/association.ts"],"sourcesContent":["import { get } from 'lodash/fp';\nimport { async, errors } from '@strapi/utils';\nimport type { Internal } from '@strapi/types';\n\nimport type { Context } from '../../types';\n\nconst { ApplicationError } = errors;\n\nexport default ({ strapi }: Context) => {\n const { service: getGraphQLService } = strapi.plugin('graphql');\n\n const { isMorphRelation, isMedia } = getGraphQLService('utils').attributes;\n const { transformArgs } = getGraphQLService('builders').utils;\n const { toEntityResponse, toEntityResponseCollection } = getGraphQLService('format').returnTypes;\n\n return {\n buildAssociationResolver({\n contentTypeUID,\n attributeName,\n }: {\n contentTypeUID: Internal.UID.ContentType;\n attributeName: string;\n }) {\n const contentType = strapi.getModel(contentTypeUID);\n const attribute: any = contentType.attributes[attributeName];\n\n if (!attribute) {\n throw new ApplicationError(\n `Failed to build an association resolver for ${contentTypeUID}::${attributeName}`\n );\n }\n\n const isMediaAttribute = isMedia(attribute);\n const isMorphAttribute = isMorphRelation(attribute);\n\n const targetUID = isMediaAttribute ? 'plugin::upload.file' : attribute.target;\n const isToMany = isMediaAttribute ? attribute.multiple : attribute.relation.endsWith('Many');\n\n const targetContentType = strapi.getModel(targetUID);\n\n return async (parent: any, args: any = {}, context: any = {}) => {\n const { auth } = context.state;\n\n const transformedArgs = transformArgs(args, {\n contentType: targetContentType,\n usePagination: true,\n });\n\n await strapi.contentAPI.validate.query(transformedArgs, targetContentType, {\n auth,\n });\n\n const sanitizedQuery = await strapi.contentAPI.sanitize.query(\n transformedArgs,\n targetContentType,\n {\n auth,\n }\n );\n\n const dbQuery = strapi.get('query-params').transform(targetUID, sanitizedQuery);\n\n const data = await strapi.db?.query(contentTypeUID).load(parent, attributeName, dbQuery);\n\n const info = {\n args: sanitizedQuery,\n resourceUID: targetUID,\n };\n\n // If this a polymorphic association, it sanitizes & returns the raw data\n // Note: The value needs to be wrapped in a fake object that represents its parent\n // so that the sanitize util can work properly.\n if (isMorphAttribute) {\n // Helpers used for the data cleanup\n const wrapData = (dataToWrap: any) => ({ [attributeName]: dataToWrap });\n const sanitizeData = (dataToSanitize: any) => {\n return strapi.contentAPI.sanitize.output(dataToSanitize, contentType, { auth });\n };\n const unwrapData = get(attributeName);\n\n // Sanitizer definition\n const sanitizeMorphAttribute = async.pipe(wrapData, sanitizeData, unwrapData);\n\n return sanitizeMorphAttribute(data);\n }\n\n // If this is a to-many relation, it returns an object that\n // matches what the entity-response-collection's resolvers expect\n if (isToMany) {\n return toEntityResponseCollection(data, info);\n }\n\n // Else, it returns an object that matches\n // what the entity-response's resolvers expect\n return toEntityResponse(data, info);\n };\n },\n };\n};\n"],"names":["ApplicationError","errors","strapi","service","getGraphQLService","plugin","isMorphRelation","isMedia","attributes","transformArgs","utils","toEntityResponse","toEntityResponseCollection","returnTypes","buildAssociationResolver","contentTypeUID","attributeName","contentType","getModel","attribute","isMediaAttribute","isMorphAttribute","targetUID","target","isToMany","multiple","relation","endsWith","targetContentType","parent","args","context","auth","state","transformedArgs","usePagination","contentAPI","validate","query","sanitizedQuery","sanitize","dbQuery","get","transform","data","db","load","info","resourceUID","wrapData","dataToWrap","sanitizeData","dataToSanitize","output","unwrapData","sanitizeMorphAttribute","async","pipe"],"mappings":"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"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import { get } from 'lodash/fp';
|
|
2
|
+
import { async, errors } from '@strapi/utils';
|
|
3
|
+
|
|
4
|
+
const { ApplicationError } = errors;
|
|
5
|
+
var associationResolvers = (({ strapi })=>{
|
|
6
|
+
const { service: getGraphQLService } = strapi.plugin('graphql');
|
|
7
|
+
const { isMorphRelation, isMedia } = getGraphQLService('utils').attributes;
|
|
8
|
+
const { transformArgs } = getGraphQLService('builders').utils;
|
|
9
|
+
const { toEntityResponse, toEntityResponseCollection } = getGraphQLService('format').returnTypes;
|
|
10
|
+
return {
|
|
11
|
+
buildAssociationResolver ({ contentTypeUID, attributeName }) {
|
|
12
|
+
const contentType = strapi.getModel(contentTypeUID);
|
|
13
|
+
const attribute = contentType.attributes[attributeName];
|
|
14
|
+
if (!attribute) {
|
|
15
|
+
throw new ApplicationError(`Failed to build an association resolver for ${contentTypeUID}::${attributeName}`);
|
|
16
|
+
}
|
|
17
|
+
const isMediaAttribute = isMedia(attribute);
|
|
18
|
+
const isMorphAttribute = isMorphRelation(attribute);
|
|
19
|
+
const targetUID = isMediaAttribute ? 'plugin::upload.file' : attribute.target;
|
|
20
|
+
const isToMany = isMediaAttribute ? attribute.multiple : attribute.relation.endsWith('Many');
|
|
21
|
+
const targetContentType = strapi.getModel(targetUID);
|
|
22
|
+
return async (parent, args = {}, context = {})=>{
|
|
23
|
+
const { auth } = context.state;
|
|
24
|
+
const transformedArgs = transformArgs(args, {
|
|
25
|
+
contentType: targetContentType,
|
|
26
|
+
usePagination: true
|
|
27
|
+
});
|
|
28
|
+
await strapi.contentAPI.validate.query(transformedArgs, targetContentType, {
|
|
29
|
+
auth
|
|
30
|
+
});
|
|
31
|
+
const sanitizedQuery = await strapi.contentAPI.sanitize.query(transformedArgs, targetContentType, {
|
|
32
|
+
auth
|
|
33
|
+
});
|
|
34
|
+
const dbQuery = strapi.get('query-params').transform(targetUID, sanitizedQuery);
|
|
35
|
+
const data = await strapi.db?.query(contentTypeUID).load(parent, attributeName, dbQuery);
|
|
36
|
+
const info = {
|
|
37
|
+
args: sanitizedQuery,
|
|
38
|
+
resourceUID: targetUID
|
|
39
|
+
};
|
|
40
|
+
// If this a polymorphic association, it sanitizes & returns the raw data
|
|
41
|
+
// Note: The value needs to be wrapped in a fake object that represents its parent
|
|
42
|
+
// so that the sanitize util can work properly.
|
|
43
|
+
if (isMorphAttribute) {
|
|
44
|
+
// Helpers used for the data cleanup
|
|
45
|
+
const wrapData = (dataToWrap)=>({
|
|
46
|
+
[attributeName]: dataToWrap
|
|
47
|
+
});
|
|
48
|
+
const sanitizeData = (dataToSanitize)=>{
|
|
49
|
+
return strapi.contentAPI.sanitize.output(dataToSanitize, contentType, {
|
|
50
|
+
auth
|
|
51
|
+
});
|
|
52
|
+
};
|
|
53
|
+
const unwrapData = get(attributeName);
|
|
54
|
+
// Sanitizer definition
|
|
55
|
+
const sanitizeMorphAttribute = async.pipe(wrapData, sanitizeData, unwrapData);
|
|
56
|
+
return sanitizeMorphAttribute(data);
|
|
57
|
+
}
|
|
58
|
+
// If this is a to-many relation, it returns an object that
|
|
59
|
+
// matches what the entity-response-collection's resolvers expect
|
|
60
|
+
if (isToMany) {
|
|
61
|
+
return toEntityResponseCollection(data, info);
|
|
62
|
+
}
|
|
63
|
+
// Else, it returns an object that matches
|
|
64
|
+
// what the entity-response's resolvers expect
|
|
65
|
+
return toEntityResponse(data, info);
|
|
66
|
+
};
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
export { associationResolvers as default };
|
|
72
|
+
//# sourceMappingURL=association.mjs.map
|