Atif Ali
bd5b62c976
feat: expose MCP tool annotations for tool grouping ( #23195 )
...
## Summary
- add shared MCP annotation metadata to toolsdk tools
- emit MCP tool annotations from both coderd and CLI MCP servers
- cover annotation serialization in toolsdk, coderd MCP e2e, and CLI MCP
tests
## Why
- Coder already exposed MCP tools, but it did not populate MCP tool
annotation hints (`readOnlyHint`, `destructiveHint`, `idempotentHint`,
`openWorldHint`).
- Hosts such as Claude Desktop use those hints to classify and group
tools, so without them Coder tools can get lumped together.
- This change adds a shared annotation source in `toolsdk` and has both
MCP servers emit those hints through `mcp.Tool.Annotations`, avoiding
drift between local and remote MCP implementations.
## Testing
- Tested locally on Cladue Desktop and the tools are categorized
correctly.
<table>
<tr>
<td> Before
<td> After
<tr>
<td> <img width="613" height="183" alt="image"
src="https://github.com/user-attachments/assets/29d2e3fb-53bc-4ea7-bdb3-f10df4ef996b "
/>
<td> <img width="600" height="457" alt="image"
src="https://github.com/user-attachments/assets/cc384036-c9a7-4db9-9400-43ad51920ff5 "
/>
</table>
Note: Done using Coder Agents, reviewed and tested by human locally
2026-03-18 10:21:45 +00:00
..
2026-03-10 20:10:08 -05:00
2025-06-20 13:16:55 -06:00
2026-01-21 19:06:19 +00:00
2026-03-16 12:36:26 -05:00
2026-03-17 15:36:20 -06:00
2026-03-02 16:02:01 +01:00
2026-03-16 15:30:25 -05:00
2026-02-24 16:45:56 +00:00
2025-12-15 13:44:44 -09:00
2026-02-06 09:52:17 -07:00
2026-03-13 00:22:55 +11:00
2026-03-18 09:35:13 +01:00
2026-03-17 12:16:43 -07:00
2025-10-16 01:56:43 +11:00
2026-01-08 15:24:11 +04:00
2026-03-18 09:35:13 +01:00
2026-02-19 09:02:19 +00:00
2026-02-03 17:52:07 +00:00
2026-01-29 13:50:15 +01:00
2026-03-14 17:24:19 +00:00
2026-01-08 15:24:11 +04:00
2026-01-08 15:24:11 +04:00
2026-03-17 12:46:24 -04:00
2026-03-13 10:40:57 +00:00
2026-03-13 10:38:39 +00:00
2026-03-09 13:54:31 +01:00
2026-03-05 20:29:49 +00:00
2026-02-23 22:46:17 -06:00
2025-06-20 13:16:55 -06:00
2026-03-18 10:21:45 +00:00
2026-01-08 15:24:11 +04:00
2026-03-05 20:29:49 +00:00
2026-02-23 12:18:44 +01:00
2025-10-15 17:37:37 +00:00
2025-08-16 01:31:00 +10:00
2026-02-19 09:02:19 +00:00
2026-03-05 20:29:49 +00:00
2026-01-30 13:30:06 +01:00
2026-03-16 12:36:26 -05:00
2025-10-23 15:38:49 -05:00
2025-06-17 09:00:32 -08:00
2026-03-06 15:11:05 -08:00
2026-03-17 12:16:43 -07:00
2025-06-20 13:16:55 -06:00
2025-07-08 14:31:05 +00:00
2026-02-19 09:02:19 +00:00
2026-03-17 12:46:24 -04:00
2026-03-13 17:35:26 +00:00
2026-02-24 17:04:42 +00:00
2025-12-14 03:00:03 +00:00
2026-01-08 15:24:11 +04:00
2026-01-08 15:24:11 +04:00
2025-08-22 16:32:35 +10:00
2025-06-20 13:16:55 -06:00
2026-03-06 15:09:58 +01:00
2026-03-17 13:50:47 +11:00
2026-03-10 16:53:28 +00:00
2026-01-08 15:24:11 +04:00
2026-02-27 14:26:48 +00:00
2026-03-13 20:37:41 -07:00
2026-03-12 18:07:52 +02:00
2025-11-17 13:24:12 +00:00
2026-02-25 13:14:32 +02:00
2026-03-07 01:36:03 +00:00
2025-09-26 11:56:34 +02:00
2026-03-06 09:14:11 +00:00
2026-02-24 15:27:03 +00:00
2026-01-08 15:24:11 +04:00
2026-01-08 15:24:11 +04:00
2025-10-27 17:14:16 -06:00
2026-02-27 16:50:56 +00:00
2026-03-18 09:35:13 +01:00
2026-03-18 09:35:13 +01:00
2025-06-20 13:16:55 -06:00
2026-03-09 13:54:31 +01:00
2026-03-18 09:35:13 +01:00
2026-01-08 15:24:11 +04:00
2026-03-13 14:09:39 +00:00
2026-03-13 14:09:39 +00:00
2025-06-25 13:03:32 +00:00
2025-06-24 09:14:41 +01:00
2026-01-12 18:19:19 -08:00
2025-12-15 17:41:47 +00:00
2025-09-04 14:28:29 +10:00
2026-01-08 15:24:11 +04:00
2025-12-15 11:26:41 -06:00
2025-05-15 15:32:52 +01:00
2025-06-20 13:16:55 -06:00
2025-06-20 13:16:55 -06:00
2026-01-26 09:24:45 +00:00
2025-08-19 10:41:33 +02:00
2025-08-19 10:41:33 +02:00
2025-06-20 13:16:55 -06:00
2026-03-04 18:01:56 -08:00
2026-03-04 12:54:39 +02:00
2026-01-08 15:24:11 +04:00
2026-02-03 12:48:25 -06:00
2026-03-13 08:15:37 +11:00
2026-02-13 08:19:07 -06:00
2026-01-08 15:24:11 +04:00
2026-01-15 12:41:28 +03:00
2026-01-15 12:41:28 +03:00
2026-01-15 12:41:28 +03:00
2025-07-03 18:33:47 +02:00
2026-03-06 09:14:11 +00:00
2025-10-22 15:18:42 -05:00
2026-02-03 17:52:07 +00:00
2025-07-15 14:55:34 +10:00
2025-07-15 14:55:34 +10:00
2026-02-02 09:03:18 -06:00
2026-02-03 17:52:07 +00:00
2026-02-19 09:02:19 +00:00
2025-07-28 15:02:26 +01:00
2025-08-21 16:03:34 -04:00
2026-02-03 17:52:07 +00:00
2025-06-20 13:16:55 -06:00
2026-03-03 10:19:00 -05:00
2026-02-03 17:52:07 +00:00
2026-01-12 18:19:19 -08:00
2025-09-26 11:43:32 +02:00
2025-09-26 11:43:32 +02:00
2025-06-20 13:16:55 -06:00
2026-01-08 15:24:11 +04:00
2026-02-13 19:44:50 -05:00
2026-02-13 19:44:50 -05:00
2026-03-03 16:50:18 +00:00
2026-03-03 16:50:18 +00:00
2025-06-20 13:16:55 -06:00
2026-03-16 11:56:59 -04:00
2026-03-16 11:56:59 -04:00
2026-03-11 10:19:08 -07:00
2026-03-11 10:19:08 -07:00
2026-03-17 13:50:47 +11:00
2026-03-17 13:50:47 +11:00
2026-01-12 18:19:19 -08:00
2025-06-18 14:07:53 +00:00
2026-03-06 10:47:55 +01:00
2026-03-09 20:37:05 +00:00
2026-03-10 18:46:01 +00:00
2025-12-22 10:21:39 +04:00
2026-03-12 18:07:52 +02:00
2026-02-18 09:44:06 +01:00
2025-06-20 13:16:55 -06:00
2025-09-26 11:56:34 +02:00
2026-02-03 09:45:23 +00:00
2026-03-13 20:37:41 -07:00
2025-12-15 11:26:41 -06:00
2026-01-08 15:24:11 +04:00
2026-03-13 20:37:41 -07:00
2026-03-17 12:16:43 -07:00
2026-01-08 15:24:11 +04:00