| Название | PublicCMS 5 Improper Access Controls |
|---|
| Описание | `TradePaymentController.cancel` accept a `paymentId` from the request and invoke service-layer state changes without verifying that the payment belongs to the authenticated user. Any logged-in user can cancel or initiate a refund for another user's payment if they know the `paymentId`. Poc:1. Use a test account Creating a payment, get `paymentId` ;2. Login as a low-privileged user ,extract `_csrf` token from cookie value: `PUBLICCMS_USER=<userId>_<csrfToken>`;3. The payment status changes (cancelled) even though the attacker does not own the payment.
|
|---|
| Источник | ⚠️ https://github.com/sanluan/PublicCMS/issues/108 |
|---|
| Пользователь | AliceS614 (UID 94277) |
|---|
| Представление | 21.01.2026 13:55 (5 месяцы назад) |
|---|
| Модерация | 05.02.2026 20:25 (15 days later) |
|---|
| Статус | принято |
|---|
| Запись VulDB | 344592 [Sanluan PublicCMS до 4.0.202506.d/5.202506.d/6.202506.d Trade Payment TradePaymentService.java paid paymentId эскалация привилегий] |
|---|
| Баллы | 20 |
|---|