首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Graphql屏蔽返回未授权允许的突变

Graphql屏蔽返回未授权允许的突变
EN

Stack Overflow用户
提问于 2021-08-31 19:57:18
回答 1查看 999关注 0票数 3

我正在尝试使用阿波罗服务器快车实现GraphQL API。我想通过graphql-屏蔽中间件来管理权限,但我在允许执行突变方面有问题。我的目标是基于JWT的身份验证,但允许对未经身份验证的用户执行一些查询/突变,这是注册/登录突变所必需的。因为我使用的是默认的allow规则。但是当我尝试运行登录突变时,我会收到未授权!错误。我不知道为什么。该规则适用于查询。

谢谢你的回答。

服务器

代码语言:javascript
复制
import express from "express";
import cors from "cors";
import { ApolloServer, makeExecutableSchema } from "apollo-server-express";
import config from "./config";
import mockResolver from "./resolvers/mockResolver";
import typeDefs from "./graphql/typeDefs";
import { applyMiddleware } from "graphql-middleware";
import permissions from "./graphql/permissions";

const app = express();
app.use(cors());

const server = new ApolloServer({
  schema: applyMiddleware(
    makeExecutableSchema({ typeDefs, resolvers: mockResolver }),
    permissions
  ),
  playground: true,
  introspection: true,
});

server.applyMiddleware({ app, path: "/graphql" });
app.listen(config.PORT, () =>
  console.log("Server listening at http://localhost:%s", config.PORT)
);

TypeDefs

代码语言:javascript
复制
import { gql } from "apollo-server";

const typeDefs = gql`
  type User {
    id: Int!
    email: String!
    password: String!
  }

  type LoginResponse {
    id: String
    email: String
    token: String
  }

  type Query {
    user(id: Int!): User
    users: [User]
  }

  type Mutation {
    login(email: String!, password: String!): LoginResponse
  }
`;

权限

代码语言:javascript
复制
import { shield, allow } from "graphql-shield";

const permissions = shield({
  Query: {
    users: allow,
  },
  Mutation: {
    login: allow,
  },
});

export default permissions;
EN

回答 1

Stack Overflow用户

发布于 2021-10-30 21:29:55

代码语言:javascript
复制
const permissions = shield({
  Query: {
    users: allow,
  },
  Mutation: {
    login: allow,
  },
});    

代码语言:javascript
复制
const permissions = shield({
  Query: {
    users: allow,
  },
  Mutation: {
    login: allow,
  },
},
{
  debug: true
});

并追踪错误信息。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69004669

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档