[Fix] SSE client to support MCP server mounted under a base path on a different ASGI server #524
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
What does this PR do?
/messages
endpoint URL in the SSE client when the FastAPI app is mounted under a base path (e.g.,/mcp
).server_mount_path
to ensure correct endpoint resolution.Motivation and Context
Problem
/messages?session_id=...
,urljoin(base_url, relative_path)
/mcp/sse
), this strips the subpath and constructs an invalid endpoint (e.g.,http://host/messages?session_id=...
instead ofhttp://host/mcp/messages?session_id=...
).Fix
This PR:
How Has This Been Tested?
server:
client:
This test should pass now.
Breaking Changes
None identified, backward compatible
Types of changes
Checklist
Additional context
NA