Skip to content

Conversation

@enrico-kaack-comp
Copy link
Contributor

@enrico-kaack-comp enrico-kaack-comp commented Jun 24, 2025

What this PR does / why we need it:
This PR switches the request.session storage to use request.encryptedSession that is introduced in the encrypted-session.js.
Doing so will use a combination of secure-session (cookie that stores a user side encryption key) and fastify-session (where the users session data is stored with an encryption per user).
Decision documented here openmcp-project/backlog#151 (comment)

Which issue(s) this PR fixes:
Fixes #

Additional notes:
all data is stored into the underlying session as one encrypted object. We might want to store it as encrypted key/values in the session maybe with expiration date to be able to invalidate items after a max-age.

The original request.session.destroy is changed to request.encryptedSession.clear. It will clear the map used in memory to store the data and in the onSend hook, the original session data is overwritten with a newly encrypted (in this case empty) json encryption of the map.

@enrico-kaack-comp enrico-kaack-comp changed the title Add encryptedSession to MCP token handling Add encryptedSession for separate auth tokens for Onboarding API and MCPs Jun 24, 2025
Copy link
Member

@n3rdc4ptn n3rdc4ptn left a comment

Choose a reason for hiding this comment

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

Typo needs to be fixed but lgtm

As discussed,
We should do a follow up to check if we can improve the API further by using a custom store or already existing methods in the fastify session library.

Copy link
Member

@n3rdc4ptn n3rdc4ptn left a comment

Choose a reason for hiding this comment

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

Typo needs to be fixed but lgtm

As discussed,
We should do a follow up to check if we can improve the API further by using a custom store or already existing methods in the fastify session library.

@n3rdc4ptn n3rdc4ptn requested a review from Copilot June 25, 2025 12:05
Copy link
Contributor

Copilot AI left a comment

Choose a reason for hiding this comment

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

Pull Request Overview

This PR replaces the legacy request.session storage with a new request.encryptedSession plugin, providing per-user encrypted session handling for both Onboarding and MCP authentication flows.

  • Swapped all session reads/writes in routes and plugins to use encryptedSession
  • Removed the old session.js plugin and introduced encrypted-session.js
  • Updated configuration and dependencies to support secure-session and session encryption

Reviewed Changes

Copilot reviewed 10 out of 11 changed files in this pull request and generated 3 comments.

Show a summary per file
File Description
server/routes/auth-onboarding.js Switched session storage to encryptedSession for onboarding tokens
server/routes/auth-mcp.js Switched session storage to encryptedSession for MCP tokens
server/plugins/session.js Removed legacy Fastify session plugin
server/plugins/http-proxy.js Updated token retrieval and refresh logic to use encryptedSession
server/plugins/auth-utils.js Updated OAuth state and code verifier storage to use encryptedSession
server/encrypted-session.js Added new encrypted session plugin for secure per-user session encryption
server/config/env.js Added SESSION_SECRET environment variable requirement
server/app.js Registered the encryptedSession plugin
package.json Added @fastify/secure-session dependency
.env.template Added placeholder for SESSION_SECRET
Comments suppressed due to low confidence (2)

server/encrypted-session.js:157

  • [nitpick] Function name encryptSymetric is misspelled; consider renaming to encryptSymmetric for clarity and consistency.
function encryptSymetric(plaintext, key) {

server/encrypted-session.js:20

  • [nitpick] Consider adding unit tests for the encryptedSession plugin to cover encryption/decryption flows and session persistence.
async function encryptedSession(fastify) {

@andreaskienle andreaskienle merged commit 0335f98 into mcp-auth Jun 26, 2025
2 checks passed
@andreaskienle andreaskienle deleted the feat/encrypted-session branch June 26, 2025 12:28
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.

3 participants