ChurchCRM — это система управления церковью с открытым исходным кодом. До версии 7.1.0 в PersonView.php существовала уязвимость хранимого межсайтового скриптинга из-за неправильного использования sanitizeText() в качестве средства очистки вывода для контекста атрибута HTML. Функция удаляет только HTML-теги, она не экранирует символы кавычек, позволяя злоумышленнику выйти за пределы атрибута href и внедрить произвольные обработчики событий JavaScript.
Любой прошедший проверку подлинности пользователь с ролью EditRecords может сохранять полезную нагрузку в личном поле Facebook. XSS активируется против любого пользователя, который просматривает страницу профиля этого человека, включая администраторов, позволяя перехват сеанса и полный контроль учетной записи. Эта уязвимость исправлена в версии 7.1.0.
Показать оригинальное описание (EN)
ChurchCRM is an open-source church management system. Prior to 7.1.0, a stored cross-site scripting vulnerability exists in PersonView.php due to incorrect use of sanitizeText() as an output sanitizer for HTML attribute context. The function only strips HTML tags, it does not escape quote characters allowing an attacker to break out of the href attribute and inject arbitrary JavaScript event handlers. Any authenticated user with the EditRecords role can store the payload in a person's Facebook field. The XSS fires against any user who views that person's profile page, including administrators, enabling session hijacking and full account takeover. This vulnerability is fixed in 7.1.0.
Характеристики атаки
Последствия
Строка CVSS v3.1