6

我正在使用适用于快递的护照本地策略:

passport.use(localStrategy);
passport.serializeUser((user, done) => done(null, JSON.stringify(user)));
passport.deserializeUser((obj, done) => done(null, JSON.parse(obj)));
app.use(passport.initialize());
app.use(passport.session());

这个 localStrategy 正在执行 Mongoose 调用以根据用户的 pubKey 获取用户,我猜 request.user 是通过这种方式填充的。

我像这样设置我的graphql端点:

app.use('/graphql', bodyParser.json(), graphqlExpress(request => ({
  debug: true,
  schema,
  context: {
    user: request.user,
    req: request,
  },
  formatError: (e) => {
    console.log(JSON.stringify(e, null, 2));
    return e;
  },
})));

我的订阅是这样的:

const ws = createServer(app);

// Run the server
ws.listen(settings.APP_PORT, () => {
  console.log(`App listening on port ${settings.APP_PORT}!`);
  // Set up the WebSocket for handling GraphQL subscriptions
  new SubscriptionServer({
    execute,
    subscribe,
    schema,
    onConnect: (connectionParams, webSocket) => {
      console.log(webSocket.upgradeReq);
      return { user: connectionParams };
    },
  }, {
    server: ws,
    path: '/subscriptions',
  });
});

我的会话在 graphql 查询和突变方面运行良好。但不是我的订阅。

我的目标是在我的订阅解析器上下文中访问我的用户会话。我可能需要访问 onConnect 中的 request.user 之类的东西来填充上下文,但我不知道该怎么做。

4

2 回答 2

3

因此,经过一番修补后,我发现您需要做的基本上是通过重新运行中间件来运行passport为套接字重新创建的所有内容:upgradeReq

// Start with storing the middleware in constants
const passportInit = passport.initialize();
const passportSession = passport.session();
app.use(passportInit);
app.use(passportSession);

...
// Now populate the request with the upgradeReq using those constants
onConnect: (connectionParams, webSocket) => new Promise((resolve) => {
  passportInit(webSocket.upgradeReq, {}, () => {
    passportSession(webSocket.upgradeReq, {}, () => {
      resolve(webSocket.upgradeReq);
    });
  });
}),

如果您使用的是,则express-session需要将其添加到上面。

于 2018-11-07T23:57:12.397 回答
0

看看graphql-passport。它基本上与 Max 在他的回答中提到的相同,但在一个简化的包中。

请注意,这目前适用于subscriptions-transport-ws,现在被认为已弃用。到目前为止,在使用更新的替代品graphql-ws时,我还没有找到解决方案,因为它的工作方式与传统套接字系统不同,并且似乎无法访问任何类型的request对象。

于 2022-02-28T19:50:17.910 回答