Commit 87c9b07
fix: prevent glob injection and cross-server secret leakage in MCP gateway
Validates secret names against glob metacharacters before they reach the
Desktop secrets resolver, which treats the pattern field as a glob. A
catalog entry with name "**" would otherwise cause GetSecret to send
{"pattern": "docker/mcp/**"}, returning all vault secrets and injecting
them into outbound HTTP headers to the remote server (SSH-10 / external
report).
Also scopes the secrets map in configuration.Find() to only the keys
declared by each server, preventing cross-server secret access by name
guessing.
- Add ValidateSecretName() to the secret package as the enforcement point
- Call it in remote.go:getSecretValue() to block HTTP header exfiltration
- Call it in secrets_uri.go buildFallbackURIs/buildVerifiedURIs to block
glob injection into se:// URIs for container-based servers
- Scope Secrets in configuration.Find() to per-server declared secrets
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>1 parent 88f82d1 commit 87c9b07
File tree
5 files changed
+43
-1
lines changed- cmd/docker-mcp/secret-management/secret
- pkg
- gateway
- mcp
5 files changed
+43
-1
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
24 | 24 | | |
25 | 25 | | |
26 | 26 | | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
27 | 37 | | |
28 | 38 | | |
29 | 39 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
15 | 27 | | |
16 | 28 | | |
17 | 29 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
92 | 92 | | |
93 | 93 | | |
94 | 94 | | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
95 | 103 | | |
96 | 104 | | |
97 | 105 | | |
98 | 106 | | |
99 | 107 | | |
100 | 108 | | |
101 | | - | |
| 109 | + | |
102 | 110 | | |
103 | 111 | | |
104 | 112 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
48 | 48 | | |
49 | 49 | | |
50 | 50 | | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
51 | 55 | | |
52 | 56 | | |
53 | 57 | | |
| |||
68 | 72 | | |
69 | 73 | | |
70 | 74 | | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
71 | 79 | | |
72 | 80 | | |
73 | 81 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
169 | 169 | | |
170 | 170 | | |
171 | 171 | | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
172 | 176 | | |
173 | 177 | | |
174 | 178 | | |
| |||
0 commit comments