0click-уязвимости в источниках питания APC ставят под удар 80% компаний

0click-уязвимости в источниках питания APC ставят под удар 80% компаний

0click-уязвимости в источниках питания APC ставят под удар 80% компаний

В прошивках смарт-источников непрерывного питания производства APC (подразделение Schneider Electric) обнаружены уязвимости, позволяющие удаленно захватить контроль над устройством и учинить диверсию на предприятии. Производитель уже начал выкатывать обновления прошивки с патчами.

Компания APC является одним из ведущих вендоров источников бесперебойного питания (ИБП). Ее изделия широко используются в здравоохранении, ИТ-индустрии, ритейле, а также в госструктурах и на промышленных предприятиях. По внутренним оценкам, объем поставок APC уже превысил 20 млн устройств. Выявленные в них уязвимости (объединены под общим именем TLStorm), по словам авторов находки, актуальны примерно для 80% организаций в разных странах.

Исследователи из Armis изучили взаимодействие смарт-устройств APC с серверами удаленного мониторинга и управления и нашли две критические уязвимости в реализации TLS, а также ошибку проектирования, связанную с обновлением прошивки:

  • CVE-2022-22806 (ровно 9 баллов CVSS) — путаница состояния во время TLS-хэндшейка; позволяет удаленно выполнить сторонний код в системе в обход аутентификации;
  • CVE-2022-22805 (9 баллов) — переполнение буфера при повторной сборке сетевых пакетов; грозит удаленным исполнением вредоносного кода;
  • CVE-2022-0715 (8,9 балла при подключении к облаку, 6,9 при управлении из локальной сети) — неадекватная криптозащита прошивки.

В последнем случае для защиты прошивки APC использует симметричное шифрование, а цифровая подпись не предусмотрена. Более того, ключ шифрования одинаков для всех прошивок ИБП одной и той же модели, и его можно извлечь с устройства. В итоге злоумышленник может создать вредоносный вариант прошивки и загрузить его как обновление с USB-носителя, по сети или через интернет.

Эксплойт во всех случаях осуществляется без взаимодействия с пользователем. PoC-атака показала, что комбинация найденных уязвимостей позволяет сымитировать сервер Schneider Electric, собрать информацию об ИБП за файрволом, подменить прошивку и использовать взломанное устройство для дальнейшего проникновения в корпоративную сеть.

Риск атаки TLStorm высок для продуктов семейств Smart-UPS и SmartConnect (серии SMT, SMC, SCL, SMX, SRT, SMTL). Вендор уже начал выпускать новые прошивки и предлагает временные меры защиты от эксплойта.

Критическая уязвимость в telnetd жила почти 10 лет и давала root-доступ

Исследователь по информационной безопасности Саймон Йозефссон обнаружил критическую уязвимость в компоненте telnetd, входящем в состав GNU InetUtils. Брешь незаметно существовала почти десять лет — с мая 2015 года — и позволяла удалённо входить в систему без аутентификации, сразу под пользователем root.

Проблема затрагивает все версии GNU InetUtils с 1.9.3 по 2.7 включительно. По сути, любой злоумышленник при определённых условиях мог получить полный контроль над системой, даже не зная пароля.

Как поясняет Йозефссон, сервер telnetd запускает системную утилиту /usr/bin/login, обычно от имени root, и передаёт ей имя пользователя. В уязвимой реализации это имя можно получить из переменной окружения, переданной клиентом.

Если клиент подсовывает значение -f root и подключается к серверу с опцией telnet -a (режим автологина), происходит следующее:

  • telnetd передаёт значение переменной окружения USER напрямую в login(1);
  • никакой проверки или экранирования не выполняется;
  • login(1) воспринимает -f root как служебный параметр;
  • а параметр -f означает вход без проверки пароля.

В итоге сервер автоматически аутентифицирует подключение как root — полностью обходя процесс валидации.

Обычное подключение по telnet не позволяет указать имя пользователя в таком виде. Однако в режиме автологина (-a) имя пользователя берётся не из командной строки, а именно из переменной окружения USER.

Именно здесь и кроется корень проблемы: telnetd доверял содержимому USER без какой-либо валидации. Достаточно было установить переменную окружения в значение -f root, и система сама открывала дверь.

Йозефссон показал рабочий пример атаки на системе Trisquel GNU/Linux 11, где после одной команды пользователь моментально получал root-доступ.

Как выяснилось, уязвимость появилась в коммите от 19 марта 2015 года и попала в релиз GNU InetUtils 1.9.3 от 12 мая того же года. Изначально изменение задумывалось как исправление проблемы с автологином в средах с Kerberos — разработчики добавили передачу имени пользователя через переменную окружения, но забыли проверить её содержимое.

Саймон Йозефссон рекомендует как можно скорее ограничить сетевой доступ к telnet-порту только для доверенных клиентов; установить патч или обновиться до версии GNU InetUtils, в которой уязвимости нет;  в идеале — ещё раз задуматься, нужен ли telnet в инфраструктуре вообще.

Напомним, в этом месяце мы сообщали об опасной уязвимости в GNU Wget2, которая позволяет удалённо перезаписывать файлы.

RSS: Новости на портале Anti-Malware.ru