如何解决处理 GraphQL 和 REST 的 NestJS AuthGuard
根据文档,为了使用 AuthGuard 进行 GraphQL 解析器的身份验证,我们必须像这样覆盖 getRequest
方法:
getRequest(context: ExecutionContext) {
const ctx = GqlExecutionContext.create(context);
return ctx.getContext().req;
}
我的大部分 API 使用 GraphQL,但其他 API 使用 REST 端点来处理文件上传。 (我提到了 this)现在,我使用了两个 AuthGuard。一个是针对 GraphQL,我像上面那样覆盖了 getRequest
。另一个是针对REST,除了getRequest
(这次我没有覆盖它)以及调用user
后从请求中提取canActivate
对象的方式之外,其代码完全相同。
GraphQL:
// getRequest is overridden
const user: User = this.getRequest(context).user;
休息:
// getRequest is NOT overridden
const { user } = context.switchToHttp().getRequest();
有什么方法可以尝试将这两个 AuthGuard 合二为一?
解决方法
为什么不为 getRequest
方法提供类似的东西:
getRequest(context: ExecutionContext) {
if (context.getType<ContextType | 'graphql'>() === 'graphql') {
return GqlExecutionContext.create(context).getContext().req;
}
return context.switchToHttp().getRequest();
}
现在你只需要一个守卫。无论使用 GraphQL 还是 REST
,req.user
都将填充相同的内容
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。