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

Add enum support #196

Open
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

redox
Copy link

@redox redox commented Mar 19, 2025

Motivation and Context

This adds support for enum on string property.

How Has This Been Tested?

Before After
image image

Breaking Changes

None

Types of changes

  • Bug fix (non-breaking change which fixes an issue)
  • New feature (non-breaking change which adds functionality)
  • Breaking change (fix or feature that would cause existing functionality to change)
  • Documentation update

Checklist

  • I have read the MCP Documentation
  • My code follows the repository's style guidelines
  • New and existing tests pass locally
  • I have added appropriate error handling
  • I have added or updated documentation as needed

Additional context

This adds support for
[enum](https://json-schema.org/understanding-json-schema/reference/enum)
on `string` property.
@seuros
Copy link
Contributor

seuros commented Mar 19, 2025

Can you point out where do you see this in the specification.

@redox
Copy link
Author

redox commented Mar 19, 2025

Can you point out where do you see this in the specification.

I linked https://json-schema.org/understanding-json-schema/reference/enum in the description, this is what you were looking for right?

@seuros
Copy link
Contributor

seuros commented Mar 19, 2025

I understand that the JSON schema supports enums, and I use it in OpenAPI.

However, my question was about this specification.

While the idea of using enums is great, I believe it should be an official part of the specification to ensure compatibility across different clients and servers.

If a client is strict about adhering to the specification, it could reject any request/response from a server that doesn’t conform as malformed or invalid.

I don’t intend to push back, but I think this is something worth discussing in the GitHub discussion to get community input.

From there, we (the community) can consider implementing it experimentally in both client and server capabilities.

@redox
Copy link
Author

redox commented Mar 19, 2025

Oh I see. The current specification is indeed vague about it (the TS version simply rely on object here). I might have wrongly assumed that the inputSchema would support the whole JSON Schema as it's documentation is A JSON Schema object defining the expected parameters for the tool..

I'll start a discussion in https://github.com/modelcontextprotocol/specification

@redox
Copy link
Author

redox commented Mar 19, 2025

For the record: modelcontextprotocol/specification#210

@seuros
Copy link
Contributor

seuros commented Mar 19, 2025

Just for info, when a client wants to get the data for that field, it emit a completion request for tools and resources.

So your goal is doable if your server return the correct enum.

One thing that bother me is that it keep emitting it while you are typing.

@cliffhall cliffhall added enhancement New feature or request waiting on spec Waiting on specification / discussion labels Apr 1, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request waiting on spec Waiting on specification / discussion
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants