Strapi:GraphQL ctx.state未定义

Strapi:GraphQL ctx.state未定义,graphql,strapi,Graphql,Strapi,我有一个自定义控制器来替换名为“groupedOrders”的默认查询 但是当我尝试测试查询时,响应是 “消息”:“无法读取未定义的属性‘user’, api/grouped order/controllers/grouped-order.js中的代码是: module.exports = { byUser: async ctx => { const user = ctx.state.user const resTypeUser = await st

我有一个自定义控制器来替换名为“groupedOrders”的默认查询 但是当我尝试测试查询时,响应是

“消息”:“无法读取未定义的属性‘user’,

api/grouped order/controllers/grouped-order.js中的代码是:

module.exports = {
    byUser: async ctx => {
        const user = ctx.state.user
        const resTypeUser = await strapi.query('tipo-usuario').find({ _id: user.tipo_usuario })
        var resGroupedOrder = { error: true }
        if (resTypeUser[0].super_admin) {
            resGroupedOrder = await strapi.query('grouped-order').find()
        } else if (resTypeUser[0].cliente) {
            resGroupedOrder = await strapi.query('grouped-order').find({ users_permissions_user: user._id })
        }

        return resGroupedOrder
    }
};
api/grouped order/config/schema.graphql.js中的代码是:

module.exports = {
  definition: ``,
  query: ``,
  type: {},
  resolver: {
    Query: {
      groupedOrders: {
        description: "Retornar todos los pedidos dependiendo el tipo de usuario",
        resolverOf: "application::grouped-order.grouped-order.byUser",
        policies: [
            'plugins::users-permissions.permissions',
        ],
        resolver: async (obj, options, ctx) => {
          return await strapi.controllers["grouped-order"].byUser(ctx);
        }
      }
    },
  },
}
我尝试运行的测试http://localhost:1337/graphql 是:

以及HTTP标头:

{ 
  "Authorization": "Bearer TOKENJWT"
}

已解决,我只需在控制器上添加以下代码:

if (!ctx.state && ctx.request && ctx.request.header && ctx.request.header.authorization) {
            const { id } = await strapi.plugins["users-permissions"].services.jwt.getToken(ctx);
            ctx.state.user = await strapi.plugins['users-permissions'].services.user.fetchAuthenticatedUser(id);
        }
我们可以全局添加代码,如下所示:

if (!ctx.state && ctx.request && ctx.request.header && ctx.request.header.authorization) {
            const { id } = await strapi.plugins["users-permissions"].services.jwt.getToken(ctx);
            ctx.state.user = await strapi.plugins['users-permissions'].services.user.fetchAuthenticatedUser(id);
        }