You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
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.
The text was updated successfully, but these errors were encountered:
Use the iron library to decrypt the nuxt-session in the cookie.
exp:
importironfrom'@hapi/iron';exportdefaultdefineWebSocketHandler({asyncopen(peer){constcookie=peer.request?.headers?.get('cookie');// get nuxt-session from the cookieconstnuxtSession=cookie?.match(/nuxt-session=(.*?)(?:;|$)/)?.[1]||'';console.log({ nuxtSession });// Decrypt tokens using Ironconstunsealed=awaitiron.unseal(nuxtSession,process.env.NUXT_SESSION_PASSWORD,iron.defaults);console.log('Parsed session data:',unsealed);},asyncmessage(peer,message){},close(peer){},});
As a developer, I need to authenticate users inside a websocket session. In nuxt (h3),
defineWebSocketHandler
provides the API which doesn't pass the originatingH3Event
, only raw URL and headers.I assumed there would be a low-level function such as
getUserSessionFromHeaders({ ... })
orgetUserSessionFromCookie("....")
but I didn't manage to find one.getUserSession
seems to be simply callingh3.useSession
and the whole machinery seems to expect the full blownH3Event
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 rawnuxt-session
cookie content.The text was updated successfully, but these errors were encountered: