Новости Joomla

‼️👩‍💻 Релиз безопасности Astroid 3.3.11 - шаблона-конструктора для Joomla.

‼️👩‍💻 Релиз безопасности Astroid 3.3.11 - шаблона-конструктора для Joomla.

14 часов назад (на момент публикации заметки) была обнаружена уязвимость в популярном шаблоне-конструкторе Astroid Framework. При атаке на сайт устанавливается бэкдор — системный плагин под названием plg_system_blpayload. Если вы обнаружили этот плагин на своем веб-сайте, значит, он скомпрометирован, и вам необходимо восстановить чистую резервную копию, созданную до установки плагина.

Уязвимость позволяет загружать файлы на сайт и в дальнейшем получить права администратора Joomla.
В рамках атаки (из-за которой и была обнаружена уязвимость) на сайт устанавливался плагин plg_system_blpayload, который при каждой загрузке страницы снаружи он скрытно связывается с (платформой для SEO, работающей на черном рынке (ссылку помещать не будем, просим поверить на слово). Получает список скрытых спам-ссылок (сайты азартных игр, фишинга, мошенничества), подобранный под ваш домен, затем внедряет эти ссылки в HTML-код вашей страницы непосредственно перед рендером - невидимые для посетителей, но полностью читаемые поисковыми роботами. Это называется "отравление SEO" ("отрпавление поисковой выдачи").

Однако, эта уязвимость может использоваться в других целях. Поэтому необходимо срочно проверить ваши сайты, где стоит Astroid Framework и обновить его до версии не ниже 3.3.11. Релиз безопасности выпущен 4 часа назад (на момент написания заметки).

Скачать релиз безопасности Astroid

@joomlafeed

0 Пользователей и 1 Гость просматривают эту тему.
  • 3 Ответов
  • 3391 Просмотров
*

slogic

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Понадобилось вызывать программно. Получение объекта через JControlller::getInstance().

Вопросы:
1) Как указать контекст (site, admin) красиво? Мне не очень хочется писать второй аргумент с параметрами, где должен быть указан путь.
2) Передавать аргументы получается можно только через JRequest::setVar()? Мне не очень хотелось бы так делать, но я другого варианта не вижу.
*

slogic

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
В двух словах: надо вызвать метод другого контроллера из моего кода на сервере.

Более подробно.

Хочу из кода на стороне сервера удалить продукт из интернет-магазина (JoomShopping) по известному id.

Т.е. примерно такой код:
Код
	JRequest::setVar('cid', $id);
$c = JController::getInstance('JshoppingControllerProducts');
$c->remove();

Причем контроллер должен браться из админской части кода интернет-магазина.
*

SDKiller

  • Живу я здесь
  • 2705
  • 329 / 5
  • ...ergo sum
Если вызываете через JController::getInstance - указывайте путь в опциях, причём явно.
Иначе по умолчанию будет JPATH_COMPONENT, а если вызываете из своего скрипта - и JPATH_COMPONENT и JPATH_COMPONENT_ADMINISTRATOR будут не определены.

И всё равно красиво и в одну строчку у вас не получится, так как например такие вещи

Код
    function remove(){
        $jshopConfig = &JSFactory::getConfig();
...

потребуют от вас подключать ещё и JSFactory.

Сам контроллер может вас выбросить на этапе конструктора
Код
...
checkAccessController("products");
...

Экспериментируйте )
*

slogic

  • Осваиваюсь на форуме
  • 16
  • 0 / 0
Базовое окружение у меня уже подключено, т.к. мне нужен был доступ к СУБД через фреймворк. Я полагал в Joomla! сделан какой-то поиск компонента по имени класса, осталось бы указать только контекст (site, admin).

А checkAccessController я уже видел, и морально приготовился на будущее :)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться