Commit 6cde047
authored
refactor: move ExpandEnvArgs and NormalizeScopeKind to correct packages (#2645)
Two functions were living in packages that don't reflect their concerns
— Docker arg expansion in `mcp/` and scope normalization in `server/` —
while their natural homes already existed elsewhere.
## Changes
### `ExpandEnvArgs` → `internal/config/docker_helpers.go`
- Moved from `internal/mcp/dockerenv.go` (deleted)
- Docker `-e VAR_NAME` expansion is Docker utility logic, not MCP
protocol logic; `config/docker_helpers.go` already houses other Docker
utilities
- Updated call site in `mcp/connection.go` to `config.ExpandEnvArgs`
- Tests migrated from `internal/mcp/dockerenv_test.go` (deleted) into
`internal/config/docker_helpers_and_env_test.go`
- `mcp/connection_test.go` updated to reference `config.ExpandEnvArgs`
### `normalizeScopeKind` → `internal/config/guard_policy.go` (exported
as `NormalizeScopeKind`)
- Moved from `internal/server/guard_init.go`, where it was the only
guard-policy normalization function outside `config/`
- Centralizes all policy normalization alongside `NormalizeGuardPolicy`
and `normalizeAndValidateScopeArray`
- Call site in `guard_init.go` updated to `config.NormalizeScopeKind`
- Tests in `server/resolve_guard_policy_test.go` updated accordingly
> [!WARNING]
>
> <details>
> <summary>Firewall rules blocked me from connecting to one or more
addresses (expand for details)</summary>
>
> #### I tried to connect to the following addresses, but was blocked by
firewall rules:
>
> - `example.com`
> - Triggering command: `/tmp/go-build3253343390/b334/launcher.test
/tmp/go-build3253343390/b334/launcher.test
-test.testlogfile=/tmp/go-build3253343390/b334/testlog.txt
-test.paniconexit0 -test.timeout=10m0s s-th�� s-through=-lgcc_s .cfg
64/pkg/tool/linux_amd64/vet --gdwarf-5 --64` (dns block)
> - `invalid-host-that-does-not-exist-12345.com`
> - Triggering command: `/tmp/go-build139304951/b221/config.test
/tmp/go-build139304951/b221/config.test
-test.testlogfile=/tmp/go-build139304951/b221/testlog.txt
-test.paniconexit0 -test.timeout=10m0s
/tmp/go-build2095751038/b302/vet.cfg
64/src/runtime/c/tmp/go-build3935344048/b241/symabis
64/src/internal/-c=4 64/bin/as` (dns block)
> - `nonexistent.local`
> - Triggering command: `/tmp/go-build3253343390/b334/launcher.test
/tmp/go-build3253343390/b334/launcher.test
-test.testlogfile=/tmp/go-build3253343390/b334/testlog.txt
-test.paniconexit0 -test.timeout=10m0s s-th�� s-through=-lgcc_s .cfg
64/pkg/tool/linux_amd64/vet --gdwarf-5 --64` (dns block)
> - `slow.example.com`
> - Triggering command: `/tmp/go-build3253343390/b334/launcher.test
/tmp/go-build3253343390/b334/launcher.test
-test.testlogfile=/tmp/go-build3253343390/b334/testlog.txt
-test.paniconexit0 -test.timeout=10m0s s-th�� s-through=-lgcc_s .cfg
64/pkg/tool/linux_amd64/vet --gdwarf-5 --64` (dns block)
> - `this-host-does-not-exist-12345.com`
> - Triggering command: `/tmp/go-build2095751038/b263/mcp.test
/tmp/go-build2095751038/b263/mcp.test
-test.testlogfile=/tmp/go-build2095751038/b263/testlog.txt
-test.paniconexit0 -test.timeout=10m0s conf�� go --local sh
committer.name` (dns block)
>
> If you need me to access, download, or install something from one of
these locations, you can either:
>
> - Configure [Actions setup
steps](https://gh.io/copilot/actions-setup-steps) to set up my
environment, which run before the firewall is enabled
> - Add the appropriate URLs or hosts to the custom allowlist in this
repository's [Copilot coding agent
settings](https://github.com/github/gh-aw-mcpg/settings/copilot/coding_agent)
(admins only)
>
> </details>
<!-- START COPILOT CODING AGENT TIPS -->
---
📱 Kick off Copilot coding agent tasks wherever you are with [GitHub
Mobile](https://gh.io/cca-mobile-docs), available on iOS and Android.9 files changed
Lines changed: 212 additions & 222 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
| 9 | + | |
| 10 | + | |
9 | 11 | | |
10 | 12 | | |
| 13 | + | |
| 14 | + | |
11 | 15 | | |
12 | 16 | | |
13 | 17 | | |
| |||
113 | 117 | | |
114 | 118 | | |
115 | 119 | | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
119 | 119 | | |
120 | 120 | | |
121 | 121 | | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
| 223 | + | |
| 224 | + | |
| 225 | + | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
| 243 | + | |
| 244 | + | |
| 245 | + | |
| 246 | + | |
| 247 | + | |
| 248 | + | |
| 249 | + | |
| 250 | + | |
| 251 | + | |
| 252 | + | |
| 253 | + | |
| 254 | + | |
| 255 | + | |
| 256 | + | |
| 257 | + | |
| 258 | + | |
| 259 | + | |
| 260 | + | |
| 261 | + | |
| 262 | + | |
| 263 | + | |
| 264 | + | |
| 265 | + | |
122 | 266 | | |
123 | 267 | | |
124 | 268 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
700 | 700 | | |
701 | 701 | | |
702 | 702 | | |
| 703 | + | |
| 704 | + | |
| 705 | + | |
| 706 | + | |
| 707 | + | |
| 708 | + | |
| 709 | + | |
| 710 | + | |
| 711 | + | |
| 712 | + | |
| 713 | + | |
| 714 | + | |
| 715 | + | |
| 716 | + | |
| 717 | + | |
| 718 | + | |
| 719 | + | |
| 720 | + | |
| 721 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
14 | 14 | | |
15 | 15 | | |
16 | 16 | | |
| 17 | + | |
17 | 18 | | |
18 | 19 | | |
19 | 20 | | |
| |||
105 | 106 | | |
106 | 107 | | |
107 | 108 | | |
108 | | - | |
| 109 | + | |
109 | 110 | | |
110 | 111 | | |
111 | 112 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| 13 | + | |
13 | 14 | | |
14 | 15 | | |
15 | 16 | | |
| |||
256 | 257 | | |
257 | 258 | | |
258 | 259 | | |
259 | | - | |
| 260 | + | |
260 | 261 | | |
261 | 262 | | |
262 | 263 | | |
| |||
This file was deleted.
0 commit comments