Commit 04439bf
committed
fix(security): tier-driven approval gate + restore legacy sensitive-path coverage (Spec 077 US1)
Codex round-5 findings on PR #786:
#1 (HIGH) approval gate / verdict consistency: isBlockingFinding now blocks
iff Tier=="hard". Deep-scan/external/legacy findings carry no tier and no
longer gate approval or drive a "dangerous" verdict (US3 FR-021 — they inform
but never gate). Only the in-process baseline detect engine sets Tier, so US1
hard-block behavior (hard phrase_injection / hard detect) is unchanged. This is
the single predicate behind both the ApproveServer gate and the GetScanSummary
"dangerous" status, so gate and verdict can never disagree.
#2 (MEDIUM) embedded-secret file-path coverage: restore the legacy
security.NewDetector(nil) / paths.go GetFilePathPatterns() paths the detect
check had dropped — ~/.azure/accessTokens.json + azureProfile.json,
~/.docker/config.json, *.key, *.ppk, ~/.gitconfig, ~/.pypirc,
*service_account*.json, macOS ~/Library/Keychains/*, Windows
%LOCALAPPDATA%\Microsoft\Credentials\*, and <name>.env. Curated regexes mirror
paths.go (kept offline; detect cannot import internal/security, which pulls in
os) with a source-of-truth comment. Soft findings; new unit tests cover each
restored path plus benign non-matches.
#3 (ACCEPTED, no logic change): documented the sample/example-label
phrase-position false positive in position.go as a known, conservative
over-block (visible/quarantined/--force-able, not a silent bypass), tracked as
a follow-up.
Gate: recall=1.0 (>=0.90), fp=0.0 (<=0.05). Full suite + golangci-lint v2 green.
Related: Spec 0771 parent 41a24b7 commit 04439bf
4 files changed
Lines changed: 137 additions & 27 deletions
File tree
- internal/security
- detect
- checks
- scanner
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
73 | 73 | | |
74 | 74 | | |
75 | 75 | | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
76 | 87 | | |
| 88 | + | |
77 | 89 | | |
| 90 | + | |
78 | 91 | | |
| 92 | + | |
79 | 93 | | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
80 | 100 | | |
| 101 | + | |
81 | 102 | | |
| 103 | + | |
82 | 104 | | |
83 | | - | |
84 | | - | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
85 | 115 | | |
86 | 116 | | |
87 | 117 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
107 | 107 | | |
108 | 108 | | |
109 | 109 | | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 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 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
110 | 174 | | |
111 | 175 | | |
112 | 176 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
228 | 228 | | |
229 | 229 | | |
230 | 230 | | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
| 236 | + | |
| 237 | + | |
| 238 | + | |
| 239 | + | |
| 240 | + | |
| 241 | + | |
| 242 | + | |
231 | 243 | | |
232 | 244 | | |
233 | 245 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1422 | 1422 | | |
1423 | 1423 | | |
1424 | 1424 | | |
1425 | | - | |
1426 | | - | |
1427 | | - | |
1428 | | - | |
1429 | | - | |
| 1425 | + | |
| 1426 | + | |
| 1427 | + | |
| 1428 | + | |
| 1429 | + | |
1430 | 1430 | | |
1431 | 1431 | | |
1432 | 1432 | | |
| |||
1779 | 1779 | | |
1780 | 1780 | | |
1781 | 1781 | | |
1782 | | - | |
1783 | | - | |
1784 | | - | |
1785 | | - | |
1786 | | - | |
| 1782 | + | |
| 1783 | + | |
| 1784 | + | |
| 1785 | + | |
| 1786 | + | |
| 1787 | + | |
1787 | 1788 | | |
1788 | 1789 | | |
1789 | 1790 | | |
| |||
1798 | 1799 | | |
1799 | 1800 | | |
1800 | 1801 | | |
1801 | | - | |
| 1802 | + | |
1802 | 1803 | | |
1803 | 1804 | | |
1804 | 1805 | | |
| |||
1816 | 1817 | | |
1817 | 1818 | | |
1818 | 1819 | | |
1819 | | - | |
1820 | | - | |
1821 | | - | |
1822 | | - | |
1823 | | - | |
1824 | | - | |
| 1820 | + | |
| 1821 | + | |
| 1822 | + | |
| 1823 | + | |
| 1824 | + | |
| 1825 | + | |
| 1826 | + | |
| 1827 | + | |
| 1828 | + | |
| 1829 | + | |
| 1830 | + | |
| 1831 | + | |
| 1832 | + | |
| 1833 | + | |
| 1834 | + | |
| 1835 | + | |
1825 | 1836 | | |
1826 | | - | |
1827 | | - | |
1828 | | - | |
1829 | | - | |
1830 | | - | |
1831 | | - | |
1832 | | - | |
1833 | | - | |
| 1837 | + | |
1834 | 1838 | | |
1835 | 1839 | | |
1836 | 1840 | | |
| |||
0 commit comments