@strapi/plugin-graphql 5.12.0 → 5.12.2
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 @@
|
|
|
1
|
+
{"version":3,"file":"collection-type.mjs","sources":["../../../../../server/src/services/builders/mutations/collection-type.ts"],"sourcesContent":["import { extendType, nonNull, idArg } 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 { args } = getService('internals');\n\n const {\n getCreateMutationTypeName,\n getUpdateMutationTypeName,\n getDeleteMutationTypeName,\n getContentTypeInputName,\n getTypeName,\n } = naming;\n\n const addCreateMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.CollectionTypeSchema\n ) => {\n const { uid } = contentType;\n\n const createMutationName = getCreateMutationTypeName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(createMutationName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {\n // Create payload\n status: args.PublicationStatusArg,\n data: nonNull(getContentTypeInputName(contentType)),\n },\n\n async resolve(parent, args, context) {\n const { auth } = context.state;\n\n // Sanitize input data\n const sanitizedInputData = await strapi.contentAPI.sanitize.input(args.data, contentType, {\n auth,\n });\n\n return strapi.documents!(uid).create({\n ...args,\n data: sanitizedInputData,\n });\n },\n });\n };\n\n const addUpdateMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.CollectionTypeSchema\n ) => {\n const { uid } = contentType;\n\n const updateMutationName = getUpdateMutationTypeName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(updateMutationName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {\n documentId: nonNull(idArg()),\n status: args.PublicationStatusArg,\n data: nonNull(getContentTypeInputName(contentType)),\n },\n\n async resolve(parent, args, context) {\n const { auth } = context.state;\n\n const { data, ...restParams } = args;\n\n // Sanitize input data\n const sanitizedInputData = await strapi.contentAPI.sanitize.input(data, contentType, {\n auth,\n });\n\n return strapi.documents!(uid).update({\n ...restParams,\n data: sanitizedInputData,\n });\n },\n });\n };\n\n const addDeleteMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.CollectionTypeSchema\n ) => {\n const { uid } = contentType;\n\n const deleteMutationName = getDeleteMutationTypeName(contentType);\n\n const { DELETE_MUTATION_RESPONSE_TYPE_NAME } = strapi.plugin('graphql').service('constants');\n\n t.field(deleteMutationName, {\n type: DELETE_MUTATION_RESPONSE_TYPE_NAME,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {\n documentId: nonNull(idArg()),\n },\n\n async resolve(parent, args) {\n const { documentId } = args;\n\n await strapi.documents!(uid).delete({ documentId });\n\n return { documentId };\n },\n });\n };\n\n return {\n buildCollectionTypeMutations(contentType: Struct.CollectionTypeSchema) {\n const createMutationName = `Mutation.${getCreateMutationTypeName(contentType)}`;\n const updateMutationName = `Mutation.${getUpdateMutationTypeName(contentType)}`;\n const deleteMutationName = `Mutation.${getDeleteMutationTypeName(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 isCreateEnabled = isActionEnabled('create');\n const isUpdateEnabled = isActionEnabled('update');\n const isDeleteEnabled = isActionEnabled('delete');\n\n if (isCreateEnabled) {\n registerAuthConfig(createMutationName, { scope: [`${contentType.uid}.create`] });\n }\n\n if (isUpdateEnabled) {\n registerAuthConfig(updateMutationName, { scope: [`${contentType.uid}.update`] });\n }\n\n if (isDeleteEnabled) {\n registerAuthConfig(deleteMutationName, { scope: [`${contentType.uid}.delete`] });\n }\n\n return extendType({\n type: 'Mutation',\n\n definition(t) {\n if (isCreateEnabled) {\n addCreateMutation(t, contentType);\n }\n\n if (isUpdateEnabled) {\n addUpdateMutation(t, contentType);\n }\n\n if (isDeleteEnabled) {\n addDeleteMutation(t, contentType);\n }\n },\n });\n },\n };\n};\n"],"names":["strapi","service","getService","plugin","naming","args","getCreateMutationTypeName","getUpdateMutationTypeName","getDeleteMutationTypeName","getContentTypeInputName","getTypeName","addCreateMutation","t","contentType","uid","createMutationName","typeName","field","type","extensions","status","PublicationStatusArg","data","nonNull","resolve","parent","context","auth","state","sanitizedInputData","contentAPI","sanitize","input","documents","create","addUpdateMutation","updateMutationName","documentId","idArg","restParams","update","addDeleteMutation","deleteMutationName","DELETE_MUTATION_RESPONSE_TYPE_NAME","delete","buildCollectionTypeMutations","extension","registerAuthConfig","action","use","resolversConfig","isActionEnabled","shadowCRUD","isCreateEnabled","isUpdateEnabled","isDeleteEnabled","scope","extendType","definition"],"mappings":"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"}
|
|
@@ -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 mutations = ((context)=>({
|
|
7
|
+
...collectionType(context),
|
|
8
|
+
...singleType(context)
|
|
9
|
+
}));
|
|
10
|
+
|
|
11
|
+
module.exports = mutations;
|
|
12
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../../../../../server/src/services/builders/mutations/index.ts"],"sourcesContent":["import createCollectionTypeMutationsBuilder from './collection-type';\nimport createSingleTypeMutationsBuilder from './single-type';\nimport type { Context } from '../../types';\n\nexport default (context: Context) => ({\n ...createCollectionTypeMutationsBuilder(context),\n ...createSingleTypeMutationsBuilder(context),\n});\n"],"names":["context","createCollectionTypeMutationsBuilder","createSingleTypeMutationsBuilder"],"mappings":";;;;;AAIA,gBAAe,CAAA,CAACA,OAAAA,IAAsB;AACpC,QAAA,GAAGC,eAAqCD,OAAQ,CAAA;AAChD,QAAA,GAAGE,WAAiCF,OAAQ;AAC9C,KAAA,CAAC;;;;"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import createCollectionTypeMutationsBuilder from './collection-type.mjs';
|
|
2
|
+
import createSingleTypeMutationsBuilder from './single-type.mjs';
|
|
3
|
+
|
|
4
|
+
var mutations = ((context)=>({
|
|
5
|
+
...createCollectionTypeMutationsBuilder(context),
|
|
6
|
+
...createSingleTypeMutationsBuilder(context)
|
|
7
|
+
}));
|
|
8
|
+
|
|
9
|
+
export { mutations as default };
|
|
10
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../../../server/src/services/builders/mutations/index.ts"],"sourcesContent":["import createCollectionTypeMutationsBuilder from './collection-type';\nimport createSingleTypeMutationsBuilder from './single-type';\nimport type { Context } from '../../types';\n\nexport default (context: Context) => ({\n ...createCollectionTypeMutationsBuilder(context),\n ...createSingleTypeMutationsBuilder(context),\n});\n"],"names":["context","createCollectionTypeMutationsBuilder","createSingleTypeMutationsBuilder"],"mappings":";;;AAIA,gBAAe,CAAA,CAACA,OAAAA,IAAsB;AACpC,QAAA,GAAGC,qCAAqCD,OAAQ,CAAA;AAChD,QAAA,GAAGE,iCAAiCF,OAAQ;AAC9C,KAAA,CAAC;;;;"}
|
|
@@ -0,0 +1,123 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var nexus = require('nexus');
|
|
4
|
+
var utils = require('@strapi/utils');
|
|
5
|
+
|
|
6
|
+
const { NotFoundError } = utils.errors;
|
|
7
|
+
var createSingleTypeMutationsBuilder = (({ strapi })=>{
|
|
8
|
+
const { service: getService } = strapi.plugin('graphql');
|
|
9
|
+
const { naming } = getService('utils');
|
|
10
|
+
const { args } = getService('internals');
|
|
11
|
+
const { getUpdateMutationTypeName, getTypeName, getContentTypeInputName, getDeleteMutationTypeName } = naming;
|
|
12
|
+
const addUpdateMutation = (t, contentType)=>{
|
|
13
|
+
const { uid } = contentType;
|
|
14
|
+
const updateMutationName = getUpdateMutationTypeName(contentType);
|
|
15
|
+
const typeName = getTypeName(contentType);
|
|
16
|
+
t.field(updateMutationName, {
|
|
17
|
+
type: typeName,
|
|
18
|
+
extensions: {
|
|
19
|
+
strapi: {
|
|
20
|
+
contentType
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
args: {
|
|
24
|
+
// Update payload
|
|
25
|
+
status: args.PublicationStatusArg,
|
|
26
|
+
data: nexus.nonNull(getContentTypeInputName(contentType))
|
|
27
|
+
},
|
|
28
|
+
async resolve (parent, args, context) {
|
|
29
|
+
const { auth } = context.state;
|
|
30
|
+
// Sanitize input data
|
|
31
|
+
const sanitizedInputData = await strapi.contentAPI.sanitize.input(args.data, contentType, {
|
|
32
|
+
auth
|
|
33
|
+
});
|
|
34
|
+
const document = await strapi.db?.query(uid).findOne();
|
|
35
|
+
if (document) {
|
|
36
|
+
return strapi.documents(uid).update({
|
|
37
|
+
...args,
|
|
38
|
+
documentId: document.documentId,
|
|
39
|
+
data: sanitizedInputData
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
return strapi.documents(uid).create({
|
|
43
|
+
...args,
|
|
44
|
+
data: sanitizedInputData
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
});
|
|
48
|
+
};
|
|
49
|
+
const addDeleteMutation = (t, contentType)=>{
|
|
50
|
+
const { uid } = contentType;
|
|
51
|
+
const deleteMutationName = getDeleteMutationTypeName(contentType);
|
|
52
|
+
const { DELETE_MUTATION_RESPONSE_TYPE_NAME } = strapi.plugin('graphql').service('constants');
|
|
53
|
+
t.field(deleteMutationName, {
|
|
54
|
+
type: DELETE_MUTATION_RESPONSE_TYPE_NAME,
|
|
55
|
+
extensions: {
|
|
56
|
+
strapi: {
|
|
57
|
+
contentType
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
args: {},
|
|
61
|
+
async resolve (parent, args) {
|
|
62
|
+
const document = await strapi.db?.query(uid).findOne();
|
|
63
|
+
if (!document) {
|
|
64
|
+
throw new NotFoundError('Document not found');
|
|
65
|
+
}
|
|
66
|
+
await strapi.documents(uid).delete({
|
|
67
|
+
...args,
|
|
68
|
+
documentId: document.documentId
|
|
69
|
+
});
|
|
70
|
+
return document;
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
};
|
|
74
|
+
return {
|
|
75
|
+
buildSingleTypeMutations (contentType) {
|
|
76
|
+
const updateMutationName = `Mutation.${getUpdateMutationTypeName(contentType)}`;
|
|
77
|
+
const deleteMutationName = `Mutation.${getDeleteMutationTypeName(contentType)}`;
|
|
78
|
+
const extension = getService('extension');
|
|
79
|
+
const registerAuthConfig = (action, auth)=>{
|
|
80
|
+
return extension.use({
|
|
81
|
+
resolversConfig: {
|
|
82
|
+
[action]: {
|
|
83
|
+
auth
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
});
|
|
87
|
+
};
|
|
88
|
+
const isActionEnabled = (action)=>{
|
|
89
|
+
return extension.shadowCRUD(contentType.uid).isActionEnabled(action);
|
|
90
|
+
};
|
|
91
|
+
const isUpdateEnabled = isActionEnabled('update');
|
|
92
|
+
const isDeleteEnabled = isActionEnabled('delete');
|
|
93
|
+
if (isUpdateEnabled) {
|
|
94
|
+
registerAuthConfig(updateMutationName, {
|
|
95
|
+
scope: [
|
|
96
|
+
`${contentType.uid}.update`
|
|
97
|
+
]
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
if (isDeleteEnabled) {
|
|
101
|
+
registerAuthConfig(deleteMutationName, {
|
|
102
|
+
scope: [
|
|
103
|
+
`${contentType.uid}.delete`
|
|
104
|
+
]
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
return nexus.extendType({
|
|
108
|
+
type: 'Mutation',
|
|
109
|
+
definition (t) {
|
|
110
|
+
if (isUpdateEnabled) {
|
|
111
|
+
addUpdateMutation(t, contentType);
|
|
112
|
+
}
|
|
113
|
+
if (isDeleteEnabled) {
|
|
114
|
+
addDeleteMutation(t, contentType);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
module.exports = createSingleTypeMutationsBuilder;
|
|
123
|
+
//# sourceMappingURL=single-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"single-type.js","sources":["../../../../../server/src/services/builders/mutations/single-type.ts"],"sourcesContent":["import { extendType, nonNull } from 'nexus';\nimport { errors } from '@strapi/utils';\nimport type * as Nexus from 'nexus';\nimport type { Struct } from '@strapi/types';\nimport type { Context } from '../../types';\n\nconst { NotFoundError } = errors;\n\nexport default ({ strapi }: Context) => {\n const { service: getService } = strapi.plugin('graphql');\n\n const { naming } = getService('utils');\n const { args } = getService('internals');\n\n const {\n getUpdateMutationTypeName,\n getTypeName,\n getContentTypeInputName,\n getDeleteMutationTypeName,\n } = naming;\n\n const addUpdateMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.SingleTypeSchema\n ) => {\n const { uid } = contentType;\n\n const updateMutationName = getUpdateMutationTypeName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(updateMutationName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {\n // Update payload\n status: args.PublicationStatusArg,\n data: nonNull(getContentTypeInputName(contentType)),\n },\n\n async resolve(parent, args, context) {\n const { auth } = context.state;\n\n // Sanitize input data\n const sanitizedInputData = await strapi.contentAPI.sanitize.input(args.data, contentType, {\n auth,\n });\n\n const document = await strapi.db?.query(uid).findOne();\n\n if (document) {\n return strapi.documents!(uid).update({\n ...args,\n documentId: document.documentId,\n data: sanitizedInputData,\n });\n }\n\n return strapi.documents!(uid).create({\n ...args,\n data: sanitizedInputData,\n });\n },\n });\n };\n\n const addDeleteMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.SingleTypeSchema\n ) => {\n const { uid } = contentType;\n\n const deleteMutationName = getDeleteMutationTypeName(contentType);\n const { DELETE_MUTATION_RESPONSE_TYPE_NAME } = strapi.plugin('graphql').service('constants');\n\n t.field(deleteMutationName, {\n type: DELETE_MUTATION_RESPONSE_TYPE_NAME,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {},\n\n async resolve(parent, args) {\n const document = await strapi.db?.query(uid).findOne();\n\n if (!document) {\n throw new NotFoundError('Document not found');\n }\n\n await strapi.documents!(uid).delete({ ...args, documentId: document.documentId });\n\n return document;\n },\n });\n };\n\n return {\n buildSingleTypeMutations(contentType: Struct.SingleTypeSchema) {\n const updateMutationName = `Mutation.${getUpdateMutationTypeName(contentType)}`;\n const deleteMutationName = `Mutation.${getDeleteMutationTypeName(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 isUpdateEnabled = isActionEnabled('update');\n const isDeleteEnabled = isActionEnabled('delete');\n\n if (isUpdateEnabled) {\n registerAuthConfig(updateMutationName, { scope: [`${contentType.uid}.update`] });\n }\n\n if (isDeleteEnabled) {\n registerAuthConfig(deleteMutationName, { scope: [`${contentType.uid}.delete`] });\n }\n\n return extendType({\n type: 'Mutation',\n\n definition(t) {\n if (isUpdateEnabled) {\n addUpdateMutation(t, contentType);\n }\n\n if (isDeleteEnabled) {\n addDeleteMutation(t, contentType);\n }\n },\n });\n },\n };\n};\n"],"names":["NotFoundError","errors","strapi","service","getService","plugin","naming","args","getUpdateMutationTypeName","getTypeName","getContentTypeInputName","getDeleteMutationTypeName","addUpdateMutation","t","contentType","uid","updateMutationName","typeName","field","type","extensions","status","PublicationStatusArg","data","nonNull","resolve","parent","context","auth","state","sanitizedInputData","contentAPI","sanitize","input","document","db","query","findOne","documents","update","documentId","create","addDeleteMutation","deleteMutationName","DELETE_MUTATION_RESPONSE_TYPE_NAME","delete","buildSingleTypeMutations","extension","registerAuthConfig","action","use","resolversConfig","isActionEnabled","shadowCRUD","isUpdateEnabled","isDeleteEnabled","scope","extendType","definition"],"mappings":"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"}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import { extendType, nonNull } from 'nexus';
|
|
2
|
+
import { errors } from '@strapi/utils';
|
|
3
|
+
|
|
4
|
+
const { NotFoundError } = errors;
|
|
5
|
+
var createSingleTypeMutationsBuilder = (({ strapi })=>{
|
|
6
|
+
const { service: getService } = strapi.plugin('graphql');
|
|
7
|
+
const { naming } = getService('utils');
|
|
8
|
+
const { args } = getService('internals');
|
|
9
|
+
const { getUpdateMutationTypeName, getTypeName, getContentTypeInputName, getDeleteMutationTypeName } = naming;
|
|
10
|
+
const addUpdateMutation = (t, contentType)=>{
|
|
11
|
+
const { uid } = contentType;
|
|
12
|
+
const updateMutationName = getUpdateMutationTypeName(contentType);
|
|
13
|
+
const typeName = getTypeName(contentType);
|
|
14
|
+
t.field(updateMutationName, {
|
|
15
|
+
type: typeName,
|
|
16
|
+
extensions: {
|
|
17
|
+
strapi: {
|
|
18
|
+
contentType
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
args: {
|
|
22
|
+
// Update payload
|
|
23
|
+
status: args.PublicationStatusArg,
|
|
24
|
+
data: nonNull(getContentTypeInputName(contentType))
|
|
25
|
+
},
|
|
26
|
+
async resolve (parent, args, context) {
|
|
27
|
+
const { auth } = context.state;
|
|
28
|
+
// Sanitize input data
|
|
29
|
+
const sanitizedInputData = await strapi.contentAPI.sanitize.input(args.data, contentType, {
|
|
30
|
+
auth
|
|
31
|
+
});
|
|
32
|
+
const document = await strapi.db?.query(uid).findOne();
|
|
33
|
+
if (document) {
|
|
34
|
+
return strapi.documents(uid).update({
|
|
35
|
+
...args,
|
|
36
|
+
documentId: document.documentId,
|
|
37
|
+
data: sanitizedInputData
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
return strapi.documents(uid).create({
|
|
41
|
+
...args,
|
|
42
|
+
data: sanitizedInputData
|
|
43
|
+
});
|
|
44
|
+
}
|
|
45
|
+
});
|
|
46
|
+
};
|
|
47
|
+
const addDeleteMutation = (t, contentType)=>{
|
|
48
|
+
const { uid } = contentType;
|
|
49
|
+
const deleteMutationName = getDeleteMutationTypeName(contentType);
|
|
50
|
+
const { DELETE_MUTATION_RESPONSE_TYPE_NAME } = strapi.plugin('graphql').service('constants');
|
|
51
|
+
t.field(deleteMutationName, {
|
|
52
|
+
type: DELETE_MUTATION_RESPONSE_TYPE_NAME,
|
|
53
|
+
extensions: {
|
|
54
|
+
strapi: {
|
|
55
|
+
contentType
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
args: {},
|
|
59
|
+
async resolve (parent, args) {
|
|
60
|
+
const document = await strapi.db?.query(uid).findOne();
|
|
61
|
+
if (!document) {
|
|
62
|
+
throw new NotFoundError('Document not found');
|
|
63
|
+
}
|
|
64
|
+
await strapi.documents(uid).delete({
|
|
65
|
+
...args,
|
|
66
|
+
documentId: document.documentId
|
|
67
|
+
});
|
|
68
|
+
return document;
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
};
|
|
72
|
+
return {
|
|
73
|
+
buildSingleTypeMutations (contentType) {
|
|
74
|
+
const updateMutationName = `Mutation.${getUpdateMutationTypeName(contentType)}`;
|
|
75
|
+
const deleteMutationName = `Mutation.${getDeleteMutationTypeName(contentType)}`;
|
|
76
|
+
const extension = getService('extension');
|
|
77
|
+
const registerAuthConfig = (action, auth)=>{
|
|
78
|
+
return extension.use({
|
|
79
|
+
resolversConfig: {
|
|
80
|
+
[action]: {
|
|
81
|
+
auth
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
});
|
|
85
|
+
};
|
|
86
|
+
const isActionEnabled = (action)=>{
|
|
87
|
+
return extension.shadowCRUD(contentType.uid).isActionEnabled(action);
|
|
88
|
+
};
|
|
89
|
+
const isUpdateEnabled = isActionEnabled('update');
|
|
90
|
+
const isDeleteEnabled = isActionEnabled('delete');
|
|
91
|
+
if (isUpdateEnabled) {
|
|
92
|
+
registerAuthConfig(updateMutationName, {
|
|
93
|
+
scope: [
|
|
94
|
+
`${contentType.uid}.update`
|
|
95
|
+
]
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
if (isDeleteEnabled) {
|
|
99
|
+
registerAuthConfig(deleteMutationName, {
|
|
100
|
+
scope: [
|
|
101
|
+
`${contentType.uid}.delete`
|
|
102
|
+
]
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
return extendType({
|
|
106
|
+
type: 'Mutation',
|
|
107
|
+
definition (t) {
|
|
108
|
+
if (isUpdateEnabled) {
|
|
109
|
+
addUpdateMutation(t, contentType);
|
|
110
|
+
}
|
|
111
|
+
if (isDeleteEnabled) {
|
|
112
|
+
addDeleteMutation(t, contentType);
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
}
|
|
117
|
+
};
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
export { createSingleTypeMutationsBuilder as default };
|
|
121
|
+
//# sourceMappingURL=single-type.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"single-type.mjs","sources":["../../../../../server/src/services/builders/mutations/single-type.ts"],"sourcesContent":["import { extendType, nonNull } from 'nexus';\nimport { errors } from '@strapi/utils';\nimport type * as Nexus from 'nexus';\nimport type { Struct } from '@strapi/types';\nimport type { Context } from '../../types';\n\nconst { NotFoundError } = errors;\n\nexport default ({ strapi }: Context) => {\n const { service: getService } = strapi.plugin('graphql');\n\n const { naming } = getService('utils');\n const { args } = getService('internals');\n\n const {\n getUpdateMutationTypeName,\n getTypeName,\n getContentTypeInputName,\n getDeleteMutationTypeName,\n } = naming;\n\n const addUpdateMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.SingleTypeSchema\n ) => {\n const { uid } = contentType;\n\n const updateMutationName = getUpdateMutationTypeName(contentType);\n const typeName = getTypeName(contentType);\n\n t.field(updateMutationName, {\n type: typeName,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {\n // Update payload\n status: args.PublicationStatusArg,\n data: nonNull(getContentTypeInputName(contentType)),\n },\n\n async resolve(parent, args, context) {\n const { auth } = context.state;\n\n // Sanitize input data\n const sanitizedInputData = await strapi.contentAPI.sanitize.input(args.data, contentType, {\n auth,\n });\n\n const document = await strapi.db?.query(uid).findOne();\n\n if (document) {\n return strapi.documents!(uid).update({\n ...args,\n documentId: document.documentId,\n data: sanitizedInputData,\n });\n }\n\n return strapi.documents!(uid).create({\n ...args,\n data: sanitizedInputData,\n });\n },\n });\n };\n\n const addDeleteMutation = (\n t: Nexus.blocks.ObjectDefinitionBlock<'Mutation'>,\n contentType: Struct.SingleTypeSchema\n ) => {\n const { uid } = contentType;\n\n const deleteMutationName = getDeleteMutationTypeName(contentType);\n const { DELETE_MUTATION_RESPONSE_TYPE_NAME } = strapi.plugin('graphql').service('constants');\n\n t.field(deleteMutationName, {\n type: DELETE_MUTATION_RESPONSE_TYPE_NAME,\n\n extensions: {\n strapi: {\n contentType,\n },\n },\n\n args: {},\n\n async resolve(parent, args) {\n const document = await strapi.db?.query(uid).findOne();\n\n if (!document) {\n throw new NotFoundError('Document not found');\n }\n\n await strapi.documents!(uid).delete({ ...args, documentId: document.documentId });\n\n return document;\n },\n });\n };\n\n return {\n buildSingleTypeMutations(contentType: Struct.SingleTypeSchema) {\n const updateMutationName = `Mutation.${getUpdateMutationTypeName(contentType)}`;\n const deleteMutationName = `Mutation.${getDeleteMutationTypeName(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 isUpdateEnabled = isActionEnabled('update');\n const isDeleteEnabled = isActionEnabled('delete');\n\n if (isUpdateEnabled) {\n registerAuthConfig(updateMutationName, { scope: [`${contentType.uid}.update`] });\n }\n\n if (isDeleteEnabled) {\n registerAuthConfig(deleteMutationName, { scope: [`${contentType.uid}.delete`] });\n }\n\n return extendType({\n type: 'Mutation',\n\n definition(t) {\n if (isUpdateEnabled) {\n addUpdateMutation(t, contentType);\n }\n\n if (isDeleteEnabled) {\n addDeleteMutation(t, contentType);\n }\n },\n });\n },\n };\n};\n"],"names":["NotFoundError","errors","strapi","service","getService","plugin","naming","args","getUpdateMutationTypeName","getTypeName","getContentTypeInputName","getDeleteMutationTypeName","addUpdateMutation","t","contentType","uid","updateMutationName","typeName","field","type","extensions","status","PublicationStatusArg","data","nonNull","resolve","parent","context","auth","state","sanitizedInputData","contentAPI","sanitize","input","document","db","query","findOne","documents","update","documentId","create","addDeleteMutation","deleteMutationName","DELETE_MUTATION_RESPONSE_TYPE_NAME","delete","buildSingleTypeMutations","extension","registerAuthConfig","action","use","resolversConfig","isActionEnabled","shadowCRUD","isUpdateEnabled","isDeleteEnabled","scope","extendType","definition"],"mappings":"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"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var nexus = require('nexus');
|
|
4
|
+
|
|
5
|
+
var createCollectionTypeQueriesBuilder = (({ strapi })=>{
|
|
6
|
+
const { service: getService } = strapi.plugin('graphql');
|
|
7
|
+
const { naming } = getService('utils');
|
|
8
|
+
const { transformArgs, getContentTypeArgs } = getService('builders').utils;
|
|
9
|
+
const { toEntityResponseCollection } = getService('format').returnTypes;
|
|
10
|
+
const { getFindOneQueryName, getTypeName, getFindQueryName, getFindConnectionQueryName, getEntityResponseCollectionName } = naming;
|
|
11
|
+
const buildCollectionTypeQueries = (contentType)=>{
|
|
12
|
+
const findOneQueryName = `Query.${getFindOneQueryName(contentType)}`;
|
|
13
|
+
const findQueryName = `Query.${getFindQueryName(contentType)}`;
|
|
14
|
+
const findConnectionQueryName = `Query.${getFindConnectionQueryName(contentType)}`;
|
|
15
|
+
const extension = getService('extension');
|
|
16
|
+
const registerAuthConfig = (action, auth)=>{
|
|
17
|
+
return extension.use({
|
|
18
|
+
resolversConfig: {
|
|
19
|
+
[action]: {
|
|
20
|
+
auth
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
});
|
|
24
|
+
};
|
|
25
|
+
const isActionEnabled = (action)=>{
|
|
26
|
+
return extension.shadowCRUD(contentType.uid).isActionEnabled(action);
|
|
27
|
+
};
|
|
28
|
+
const isFindOneEnabled = isActionEnabled('findOne');
|
|
29
|
+
const isFindEnabled = isActionEnabled('find');
|
|
30
|
+
if (isFindOneEnabled) {
|
|
31
|
+
registerAuthConfig(findOneQueryName, {
|
|
32
|
+
scope: [
|
|
33
|
+
`${contentType.uid}.findOne`
|
|
34
|
+
]
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
if (isFindEnabled) {
|
|
38
|
+
registerAuthConfig(findQueryName, {
|
|
39
|
+
scope: [
|
|
40
|
+
`${contentType.uid}.find`
|
|
41
|
+
]
|
|
42
|
+
});
|
|
43
|
+
registerAuthConfig(findConnectionQueryName, {
|
|
44
|
+
scope: [
|
|
45
|
+
`${contentType.uid}.find`
|
|
46
|
+
]
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
return nexus.extendType({
|
|
50
|
+
type: 'Query',
|
|
51
|
+
definition (t) {
|
|
52
|
+
if (isFindOneEnabled) {
|
|
53
|
+
addFindOneQuery(t, contentType);
|
|
54
|
+
}
|
|
55
|
+
if (isFindEnabled) {
|
|
56
|
+
addFindConnectionQuery(t, contentType);
|
|
57
|
+
addFindQuery(t, contentType);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Register a "find one" query field to the nexus type definition
|
|
64
|
+
*/ const addFindOneQuery = (t, contentType)=>{
|
|
65
|
+
const findOneQueryName = getFindOneQueryName(contentType);
|
|
66
|
+
const typeName = getTypeName(contentType);
|
|
67
|
+
t.field(findOneQueryName, {
|
|
68
|
+
type: typeName,
|
|
69
|
+
extensions: {
|
|
70
|
+
strapi: {
|
|
71
|
+
contentType
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
args: getContentTypeArgs(contentType, {
|
|
75
|
+
multiple: false
|
|
76
|
+
}),
|
|
77
|
+
async resolve (parent, args, ctx) {
|
|
78
|
+
const transformedArgs = transformArgs(args, {
|
|
79
|
+
contentType
|
|
80
|
+
});
|
|
81
|
+
const { findOne } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
82
|
+
contentType
|
|
83
|
+
});
|
|
84
|
+
// queryResolvers will sanitize params
|
|
85
|
+
return findOne(parent, transformedArgs, ctx);
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
};
|
|
89
|
+
/**
|
|
90
|
+
* Register a "find" query field to the nexus type definition
|
|
91
|
+
*/ const addFindQuery = (t, contentType)=>{
|
|
92
|
+
const findQueryName = getFindQueryName(contentType);
|
|
93
|
+
const typeName = getTypeName(contentType);
|
|
94
|
+
t.field(findQueryName, {
|
|
95
|
+
type: nexus.nonNull(nexus.list(typeName)),
|
|
96
|
+
extensions: {
|
|
97
|
+
strapi: {
|
|
98
|
+
contentType
|
|
99
|
+
}
|
|
100
|
+
},
|
|
101
|
+
args: getContentTypeArgs(contentType),
|
|
102
|
+
async resolve (parent, args, ctx) {
|
|
103
|
+
const transformedArgs = transformArgs(args, {
|
|
104
|
+
contentType,
|
|
105
|
+
usePagination: true
|
|
106
|
+
});
|
|
107
|
+
const { findMany } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
108
|
+
contentType
|
|
109
|
+
});
|
|
110
|
+
// queryResolvers will sanitize params
|
|
111
|
+
return findMany(parent, transformedArgs, ctx);
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
};
|
|
115
|
+
/**
|
|
116
|
+
* Register a "find" query field to the nexus type definition
|
|
117
|
+
*/ const addFindConnectionQuery = (t, contentType)=>{
|
|
118
|
+
const { uid } = contentType;
|
|
119
|
+
const queryName = getFindConnectionQueryName(contentType);
|
|
120
|
+
const responseCollectionTypeName = getEntityResponseCollectionName(contentType);
|
|
121
|
+
t.field(queryName, {
|
|
122
|
+
type: responseCollectionTypeName,
|
|
123
|
+
extensions: {
|
|
124
|
+
strapi: {
|
|
125
|
+
contentType
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
args: getContentTypeArgs(contentType),
|
|
129
|
+
async resolve (parent, args, ctx) {
|
|
130
|
+
const transformedArgs = transformArgs(args, {
|
|
131
|
+
contentType,
|
|
132
|
+
usePagination: true
|
|
133
|
+
});
|
|
134
|
+
const { findMany } = getService('builders').get('content-api').buildQueriesResolvers({
|
|
135
|
+
contentType
|
|
136
|
+
});
|
|
137
|
+
// queryResolvers will sanitize params
|
|
138
|
+
const nodes = await findMany(parent, transformedArgs, ctx);
|
|
139
|
+
return toEntityResponseCollection(nodes, {
|
|
140
|
+
args: transformedArgs,
|
|
141
|
+
resourceUID: uid
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
};
|
|
146
|
+
return {
|
|
147
|
+
buildCollectionTypeQueries
|
|
148
|
+
};
|
|
149
|
+
});
|
|
150
|
+
|
|
151
|
+
module.exports = createCollectionTypeQueriesBuilder;
|
|
152
|
+
//# sourceMappingURL=collection-type.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collection-type.js","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":"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"}
|