Commit e34dcfb
fix(rest-api): address PR review — return 500 on JSP failure and enforce READ permission in rules include (#34888)
BaseRestPortlet.getJspResponse():
- Replaced the legacy debug-HTML fallback with a WebApplicationException(500).
Non-WebApplicationException failures (e.g. NullPointerException, IOException)
now log the full stack trace at ERROR for admins and return a plain 500 with
no entity, instead of HTTP 200 with internal exception details rendered as
HTML. Side effect: also closes the pre-existing XSS surface where path and
e.toString() were interpolated into the error markup unencoded.
include.jsp:
- Added explicit READ permission check via PermissionAPI.doesUserHavePermission
after findContentletByIdentifierAnyLanguage. Anonymous sessions and users
without READ on the contentlet now receive 403 with a generic "Access denied"
body, instead of leaking existence via 200/404.
BaseRestPortletTest:
- Rewrote getJspResponse_returnsErrorHtmlForGenericException and
getJspResponse_returnsErrorHtmlForRuntimeException as
getJspResponse_throws500ForGenericException /
getJspResponse_throws500ForRuntimeException; both assert WAE(500) propagates
and getResponse().hasEntity() == false to lock in the no-detail-leak contract.
- Replaced fully qualified javax.servlet.ServletException with the imported
simple name for consistency with the rest of the file.
Refs: #34888
Co-Authored-By: Claude Opus 4.7 (1M context) <[email protected]>1 parent 9975407 commit e34dcfb
3 files changed
Lines changed: 53 additions & 33 deletions
File tree
- dotCMS/src
- main
- java/com/dotcms/rest
- webapp/WEB-INF/jsp/rules
- test/java/com/dotcms/rest
Lines changed: 6 additions & 13 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
131 | 131 | | |
132 | 132 | | |
133 | 133 | | |
134 | | - | |
135 | | - | |
136 | | - | |
137 | | - | |
138 | | - | |
139 | | - | |
140 | | - | |
141 | | - | |
142 | | - | |
143 | | - | |
144 | | - | |
145 | | - | |
146 | | - | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
147 | 140 | | |
148 | 141 | | |
149 | 142 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
| 3 | + | |
3 | 4 | | |
4 | 5 | | |
5 | 6 | | |
| |||
51 | 52 | | |
52 | 53 | | |
53 | 54 | | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
54 | 65 | | |
55 | 66 | | |
56 | 67 | | |
| |||
Lines changed: 36 additions & 20 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | 3 | | |
| 4 | + | |
4 | 5 | | |
5 | 6 | | |
6 | 7 | | |
| |||
14 | 15 | | |
15 | 16 | | |
16 | 17 | | |
| 18 | + | |
17 | 19 | | |
18 | 20 | | |
19 | 21 | | |
| |||
117 | 119 | | |
118 | 120 | | |
119 | 121 | | |
120 | | - | |
121 | | - | |
| 122 | + | |
| 123 | + | |
122 | 124 | | |
123 | 125 | | |
124 | 126 | | |
| |||
140 | 142 | | |
141 | 143 | | |
142 | 144 | | |
143 | | - | |
144 | | - | |
| 145 | + | |
| 146 | + | |
145 | 147 | | |
146 | 148 | | |
147 | 149 | | |
| |||
158 | 160 | | |
159 | 161 | | |
160 | 162 | | |
161 | | - | |
| 163 | + | |
| 164 | + | |
162 | 165 | | |
163 | 166 | | |
164 | 167 | | |
165 | | - | |
| 168 | + | |
166 | 169 | | |
167 | 170 | | |
168 | | - | |
169 | | - | |
170 | | - | |
171 | | - | |
172 | | - | |
173 | | - | |
174 | | - | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
175 | 184 | | |
176 | 185 | | |
177 | 186 | | |
178 | | - | |
| 187 | + | |
179 | 188 | | |
180 | 189 | | |
181 | 190 | | |
182 | | - | |
183 | | - | |
184 | | - | |
185 | | - | |
186 | | - | |
187 | | - | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
188 | 204 | | |
189 | 205 | | |
0 commit comments