Commit 42ce4bf
fix(mcp): symlink-safe allow-list for snippet reads + test-lint cleanup
search_code/get_file_neighbors attach a source snippet read from the
indexed File.path. Those paths come from repo content, so a crafted repo
could store/symlink a path resolving outside the indexed worktree and turn
a snippet read into an arbitrary host-file read. _read_snippet now resolves
the real path (following symlinks) and only reads inside an allowed root
(ALLOWED_ANALYSIS_DIR and/or the /<project>/ repo root), preserving the
legacy read only when no root is derivable. project is threaded through
_node_summary, search_code and get_file_neighbors. Adds _is_within +
_snippet_path_allowed helpers and 6 pure-Python guard tests.
Also addresses bot review nits in test_search_cache.py: explain the
best-effort empty-except in the synth_graph teardown and rename the unused
branch unpack to _branch in the 7 tests.
Co-authored-by: Copilot <223556219+Copilot@users.noreply.github.com>1 parent 9d4b4c7 commit 42ce4bf
3 files changed
Lines changed: 146 additions & 8 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
752 | 752 | | |
753 | 753 | | |
754 | 754 | | |
| 755 | + | |
| 756 | + | |
| 757 | + | |
| 758 | + | |
| 759 | + | |
| 760 | + | |
| 761 | + | |
| 762 | + | |
| 763 | + | |
| 764 | + | |
| 765 | + | |
| 766 | + | |
| 767 | + | |
| 768 | + | |
| 769 | + | |
| 770 | + | |
| 771 | + | |
| 772 | + | |
| 773 | + | |
| 774 | + | |
| 775 | + | |
| 776 | + | |
| 777 | + | |
| 778 | + | |
| 779 | + | |
| 780 | + | |
| 781 | + | |
| 782 | + | |
| 783 | + | |
| 784 | + | |
| 785 | + | |
| 786 | + | |
| 787 | + | |
| 788 | + | |
| 789 | + | |
| 790 | + | |
| 791 | + | |
| 792 | + | |
| 793 | + | |
| 794 | + | |
| 795 | + | |
| 796 | + | |
| 797 | + | |
| 798 | + | |
| 799 | + | |
| 800 | + | |
| 801 | + | |
| 802 | + | |
755 | 803 | | |
756 | 804 | | |
757 | 805 | | |
758 | 806 | | |
759 | 807 | | |
| 808 | + | |
760 | 809 | | |
761 | 810 | | |
762 | 811 | | |
| |||
766 | 815 | | |
767 | 816 | | |
768 | 817 | | |
| 818 | + | |
| 819 | + | |
| 820 | + | |
| 821 | + | |
769 | 822 | | |
770 | 823 | | |
771 | 824 | | |
| 825 | + | |
| 826 | + | |
772 | 827 | | |
773 | 828 | | |
774 | 829 | | |
| |||
852 | 907 | | |
853 | 908 | | |
854 | 909 | | |
| 910 | + | |
855 | 911 | | |
856 | 912 | | |
857 | 913 | | |
| |||
1206 | 1262 | | |
1207 | 1263 | | |
1208 | 1264 | | |
| 1265 | + | |
1209 | 1266 | | |
1210 | 1267 | | |
1211 | 1268 | | |
| |||
1366 | 1423 | | |
1367 | 1424 | | |
1368 | 1425 | | |
1369 | | - | |
| 1426 | + | |
| 1427 | + | |
| 1428 | + | |
1370 | 1429 | | |
1371 | 1430 | | |
1372 | 1431 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
90 | 90 | | |
91 | 91 | | |
92 | 92 | | |
| 93 | + | |
| 94 | + | |
93 | 95 | | |
94 | 96 | | |
95 | 97 | | |
| |||
112 | 114 | | |
113 | 115 | | |
114 | 116 | | |
115 | | - | |
| 117 | + | |
116 | 118 | | |
117 | 119 | | |
118 | 120 | | |
| |||
131 | 133 | | |
132 | 134 | | |
133 | 135 | | |
134 | | - | |
| 136 | + | |
135 | 137 | | |
136 | 138 | | |
137 | 139 | | |
| |||
149 | 151 | | |
150 | 152 | | |
151 | 153 | | |
152 | | - | |
| 154 | + | |
153 | 155 | | |
154 | 156 | | |
155 | 157 | | |
| |||
172 | 174 | | |
173 | 175 | | |
174 | 176 | | |
175 | | - | |
| 177 | + | |
176 | 178 | | |
177 | 179 | | |
178 | 180 | | |
| |||
192 | 194 | | |
193 | 195 | | |
194 | 196 | | |
195 | | - | |
| 197 | + | |
196 | 198 | | |
197 | 199 | | |
198 | 200 | | |
| |||
217 | 219 | | |
218 | 220 | | |
219 | 221 | | |
220 | | - | |
| 222 | + | |
221 | 223 | | |
222 | 224 | | |
223 | 225 | | |
| |||
238 | 240 | | |
239 | 241 | | |
240 | 242 | | |
241 | | - | |
| 243 | + | |
242 | 244 | | |
243 | 245 | | |
244 | 246 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
0 commit comments