Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Decompose session decrypt / support websockets #268

Open
IlyaSemenov opened this issue Nov 4, 2024 · 2 comments
Open

Decompose session decrypt / support websockets #268

IlyaSemenov opened this issue Nov 4, 2024 · 2 comments

Comments

@IlyaSemenov
Copy link

As a developer, I need to authenticate users inside a websocket session. In nuxt (h3), defineWebSocketHandler provides the API which doesn't pass the originating H3Event, only raw URL and headers.

I assumed there would be a low-level function such as getUserSessionFromHeaders({ ... }) or getUserSessionFromCookie("....") but I didn't manage to find one. getUserSession seems to be simply calling h3.useSession and the whole machinery seems to expect the full blown H3Event even though in fact it only needs a string.

I believe the documentation should include a recommended recipe for websocket users / other non-h3event authentication needs.

In the meanwhile, I ended up with a quite awkward approach where I have a GET API handler that encrypts the result of requireUserSession, then call it on the client side and push the encrypted session to websocket, which then decrypts it (and also handles expiration to prevent replay attacks). This is a lot of redundant code and an extra HTTP request per connection, and definitely could be improved if there were a way to directly decode the raw nuxt-session cookie content.

@atinux
Copy link
Owner

atinux commented Nov 4, 2024

Hey @IlyaSemenov

I believe this issue should be opened on H3 side actually on how to handle session with the websocket handler.

@aqz236
Copy link

aqz236 commented Jan 18, 2025

  1. Get the cookie from the peer's header.
  2. Use the iron library to decrypt the nuxt-session in the cookie.

exp:

import iron from '@hapi/iron';

export default defineWebSocketHandler({
  async open(peer) {
    const cookie = peer.request?.headers?.get('cookie');
    // get nuxt-session from the cookie
    const nuxtSession = cookie?.match(/nuxt-session=(.*?)(?:;|$)/)?.[1] || '';
    console.log({ nuxtSession });
    // Decrypt tokens using Iron
    const unsealed = await iron.unseal(
      nuxtSession,
      process.env.NUXT_SESSION_PASSWORD,
      iron.defaults
    );
    console.log('Parsed session data:', unsealed);

  },

  async message(peer, message) {

  },


  close(peer) {

  },
});

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants