Mercure — это протокол для передачи обновлений данных в веб-браузеры и другие HTTP-клиенты с низким энергопотреблением. До версии 0.22.0 уязвимость коллизии ключей кэша в TopicSelectorStore позволяла злоумышленнику отравить кэш результатов сопоставления, что потенциально приводило к доставке частных обновлений неавторизованным подписчикам или блокировало доставку авторизованным подписчикам. Ключ кэша был создан путем объединения селектора темы и темы с помощью разделителя подчеркивания.
Поскольку и селекторы тем, и темы могут содержать символы подчеркивания, две разные пары могут создавать один и тот же ключ. Злоумышленник, который может подписаться на хаб или публиковать обновления со специально созданными названиями тем, может использовать это для обхода проверок авторизации для частных обновлений. Эта уязвимость исправлена в версии 0.22.0.
Показать оригинальное описание (EN)
Mercure is a protocol for pushing data updates to web browsers and other HTTP clients in a battery-efficient way. Prior to 0.22.0, a cache key collision vulnerability in TopicSelectorStore allows an attacker to poison the match result cache, potentially causing private updates to be delivered to unauthorized subscribers or blocking delivery to authorized ones. The cache key was constructed by concatenating the topic selector and topic with an underscore separator. Because both topic selectors and topics can contain underscores, two distinct pairs can produce the same key. An attacker who can subscribe to the hub or publish updates with crafted topic names can exploit this to bypass authorization checks on private updates. This vulnerability is fixed in 0.22.0.
Характеристики атаки
Последствия
Строка CVSS v4.0