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

Everything server #151

Merged
merged 51 commits into from
Apr 4, 2025
Merged

Conversation

aaronpowell
Copy link
Contributor

@aaronpowell aaronpowell commented Mar 31, 2025

This is an implementation of https://www.npmjs.com/package/@modelcontextprotocol/server-everything

The objective of this sample is to have all the usage covered using the .NET SDK and ensure that we can implement as much complexity as possible.

Improvements can be done with the completion of #70 and #72.

The only thing I think that is missing from here is logging - I can't find a way to set that. Logging implemented. I added a WithSetLoggingLevelHandler method to the McpServerBuilder and fixed the McpServerHandlers that wasn't exposing logging capabilities.

Commit history is a bit of a mess as I kept merging with branches as I was updating gaps.

aaronpowell and others added 30 commits March 24, 2025 13:14
This will mean we can return multiple AIContent objects from a tool, such as a mixed text/image set

Contributes to modelcontextprotocol#68
- Introducing separate classes for Text and Blob ResourceContents
- Custom JSON converter to allow those types to be returned, making it easier to follow the type system against the spec
- Updated tests
Co-authored-by: Stephen Toub <[email protected]>
Co-authored-by: Peder Holdgaard Pedersen <[email protected]>
@PederHP
Copy link
Collaborator

PederHP commented Mar 31, 2025

Is the intent to have this kept in sync with the reference everything server? If not, then I think a different name should be used to avoid confusion about the purpose and scope.

It looks (without having dived fully into it yet) to be equivalent right now, but I think it might be worth considering adding things not in the everything server and not necessarily committing to providing equivalent functionality as it evolves. On the other hand, there is a value to having a directly comparable server.

@aaronpowell
Copy link
Contributor Author

I have done the logging stuff in the (integration test) TestServer to match what the everything server has. It was modified from 15 to 1 second frequency recently but that should be trivial to adjust.

Ah sweet, I must've missed that. I'll get it included.

Is the intent to have this kept in sync with the reference everything server? If not, then I think a different name should be used to avoid confusion about the purpose and scope.

It looks (without having dived fully into it yet) to be equivalent right now, but I think it might be worth considering adding things not in the everything server and not necessarily committing to providing equivalent functionality as it evolves. On the other hand, there is a value to having a directly comparable server.

My thought was to keep it in sync, as best as possible since a) it provides a good way to dogfood all the code paths and b) it's useful to have a direct comparison.

@aaronpowell
Copy link
Contributor Author

@PederHP - Added logging in a similar design to TestServer.

Also added a new method to the McpServerBuilder so you can set it there (it's not super easy otherwise if you're using the builder pattern).

@aaronpowell aaronpowell requested a review from halter73 April 2, 2025 23:18
@aaronpowell aaronpowell requested a review from halter73 April 3, 2025 00:26
@halter73 halter73 merged commit 01410df into modelcontextprotocol:main Apr 4, 2025
8 checks passed
@halter73
Copy link
Contributor

halter73 commented Apr 4, 2025

Thank you!

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.

4 participants