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

Chore(feature)/add request and session logs #532 #727

Merged

Conversation

leoseg
Copy link
Contributor

@leoseg leoseg commented Dec 9, 2024

Resolves #532

What changes did you make and why did you make them?

Implemented Cls for request-id logging (request id generated by uuid4) and session logging. For session logging a hash is generated from the firebase user id and the login time which should be unique and also coupling the session id to firebase.

Did you run tests? Share screenshot of results:

Run tests with npm run tests -> All passed .

How did you find us? (GitHub, Google search, social media, etc.):

GitHub

@leoseg leoseg force-pushed the chore(feature)/addRequestAndSessionLogs-#532 branch from 83d4e5d to e380a9f Compare December 29, 2024 15:04
@leoseg
Copy link
Contributor Author

leoseg commented Dec 29, 2024

Hi i did E2E testing with cypress all test run trough except the reset password tests as the mail doesn't arrive at Mailslurp, manual password reset with my Protonmail works without a problem (also done over the password reset button) , do I have to set a specific setting for the Mailslurp? There was another test that failed which was in the inital-exploration test because it expected the "Healing from sexual trauma" to be displayed in the "welcome/bumble" page which was not there (but still is available for the user under courses manually checked it with a bumble user). I think this could be more of a Frontend issue. What do you think @kyleecodes ?

@kyleecodes
Copy link
Member

kyleecodes commented Jan 6, 2025

@leoseg yes these are frontend issues, not related to the logging upgrades in this PR. You may disregard these.

As for MailSlurp, there is no additional option to set for MailSlurp, only need to follow the instructions in the frontend docs.

Thank you for letting us know!

Copy link
Member

@kyleecodes kyleecodes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@leoseg This is great! Almost done, just for sessionId, it's best to ensure when users logout that the sessionId is cleared from the CLS to avoid retaining an old session. This enables the sessionId to be functional in a testing environment where many users are often linked to one auth token.

Thanks for your patience. Will merge this ASAP. 👍

@leoseg
Copy link
Contributor Author

leoseg commented Jan 9, 2025

@kyleecodes Hi thanks for the Review! :) As far as I understand there is no logout API in the backend as the whole session management is managed by the firebase auth guard over token validation and if a user has logged out the token gets deleted in the frontend without a corresponding logout call to the backend (but maybe I am overlooking something here?). Also the CLS context and its session Id is only available in the same request and gets new created for each request. The only problem I see here if are test users using the exactly the same token with same user id AND also the same authTime, if the AuthTime is different the sessionId should be too. If the auth token is exactly the same we need a different solution. I think in cypress the login with password API of firebase is used so there it shouldn't be a problem. What do you think?

@kyleecodes
Copy link
Member

Hi @leoseg, great observations. I see your point about firebase managing authentication client-side, and authTime for differentiating tokens. It may be because test data users are linked to the same firebase auth tokens, however, they do have unique user IDs. This makes me wonder if there is an issue with the sessionIDs persisting across user logins, even if logouts are managed on the frontend? Can you verify that the CLS session context is explicitly tied to the authenticated user's token, and resets when user changes? Meanwhile, I'll also be looking into this myself. Once this is verified, it's ready to merge! requestID is all good. Thanks for your help!

@leoseg
Copy link
Contributor Author

leoseg commented Jan 10, 2025

Hi @kyleecodes , I did take a look at the logs and made screenshots: here in the first screenshot the first logs are from one user and the other ones from another, they have different session ids:
Screenshot from 2025-01-10 14-00-47
here in the second one its the same user as in the first screenshot (with requestUserId: 59f0df47-1ad3-4017-bb70-b6bc06258ad7) but after logging out and logging in again now having a different session id as before:
Screenshot from 2025-01-10 14-02-52
So the session id is attached to the specific session of the user and changes after logout :)

Copy link
Member

@kyleecodes kyleecodes left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM!

Thank you @leoseg for your detailed discussion. 🥇

@kyleecodes kyleecodes merged commit 7a391af into chaynHQ:develop Jan 13, 2025
1 check passed
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

Successfully merging this pull request may close these issues.

Add requestId and sessionId to logs
2 participants