Новости Joomla

‼️ 👩‍💻 Обновление безопасности для Tassos Framework!

‼️ 👩‍💻 Обновление безопасности для Tassos Framework!

7 января 2026 года греческому разработчику Тассосу Мариносу сообщили об уязвимости в системном плагине Tassos Framework, который входит в состав его расширений для Joomla.

⚠️ Проблема затрагивает следующие расширения:
- Convert Forms - конструктор форм обратной связи для Joomla
- EngageBox - конструктор всплывающих окон для Joomla
- Google Structured Data - пакет плагинов микроразметки для Joomla
- Advanced Custom Fields - пакет плагинов пользовательских полей (видео-сервисы, карты и иже с ними)
- Smile Pack - пакет расширений
- MailChimp Auto-Subscribe

Незамедлительно была проведена полная внутренняя проверка кода, внедрены дополнительные меры проверки и повышения безопасности, а также выпущены исправленные версии всех затронутых расширений. Проблема полностью решена.

👉 Суть уязвимости.
Уязвимость заключалась в том, как плагин Tassos Framework обрабатывал определенные AJAX-запросы через com_ajaxточку входа Joomla. При определенных условиях внутренняя функциональность фреймворка могла быть вызвана без надлежащих ограничений.

В худшем случае это могло позволить неавторизованному злоумышленнику читать файлы, доступные веб-серверу. Это также могло позволить удалять файлы с сервера при выполнении определенных условий.

При определенных обстоятельствах запросы к базе данных могли быть изменены для извлечения данных из базы данных Joomla. В совокупности эти возможности потенциально могли быть использованы для повышения уровня доступа и выполнения несанкционированного кода.

В настоящее время нет никаких доказательств того, что эта уязвимость была использована в реальных условиях.

Немедленно обновите расширения до безопасных версий (Joomla 4/5/6 | Joomla 3):
- Convert Forms - v5.1.1 / v.4.1.1
- EngageBox - v.7.1.1 / v,6,3,9
- Google Structured Data - v.6.1.1 / v.5.6.9
- Advanced Custom Fields - v.3.1.1 / v.2.8.10
- Smile Pack - v.2.1.1 / v.1.2.4.
- MailChimp Auto-Subscribe - v.5.1.1+ / v.5.0.4

Все указанные версии включают в себя релиз безопасности плагина Tassos Framework System Plugin v6.0.62.

Если у вас установлено несколько расширений Tassos, достаточно обновить только одно, чтобы применить патч. Однако всегда рекомендуется обновлять все расширения.

@joomlafeed

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

stmasrp

  • Новичок
  • 2
  • 0 / 0
Уважаемые форумчане, прошу дать совет в следующем вопросе. Как можно доработать или настроить движок, чтобы пользователь сайта мог видеть материалы предназначенные только ему? Или к примеру материалы созданные только им самим? Соответственно к материалам других пользователей доступа быть не должно. Перерыл форум, подобных вопросов не нашел(
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Нужно сделать переопределения макетов вывода и добавить в них проверку на то, что материал создан текущим пользователем (сравниваем ID создателя материала с ID текущего пользователя). Например, переопределить com_content/views/category/tmpl/blog.php и строчки:

Код: php
echo $this->loadTemplate('item');

заменить на проверку:

Код: php
if ($item->created_by == JFactory::getUser()->get->('id')) :
    echo $this->loadTemplate('item');
endif;

По тому же принципу сделать проверку (если это необходимо) в:
Код: ini
com_content/views/article/tmpl/default.php
com_content/views/archive/tmpl/default.php
com_content/views/featured/tmpl/default.php
com_content/views/category/tmpl/default_articles.php (здесь вместо $item будет $article)
*

stmasrp

  • Новичок
  • 2
  • 0 / 0
Спасибо огромное за ответ, буду пробовать!)
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Спасибо огромное за ответ, буду пробовать!)
Я чуток исправил код, там была лишняя фигурная скобка.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Чуть упрощу, для тройки достаточно этого:
Код: php
if ($item->created_by == JFactory::getUser()->id)
  echo $this->loadTemplate('item');
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Чуть упрощу, для тройки достаточно этого:
Код: php
if ($item->created_by == JFactory::getUser()->id)
  echo $this->loadTemplate('item');
Не закрывать if - плохой стиль программирования. К слову. И не в тройке дело.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Тогда так :)
Код: php
if ($item->created_by == JFactory::getUser()->id) {
  echo $this->loadTemplate('item');
}
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Тогда так :)
Код: php
if ($item->created_by == JFactory::getUser()->id) {
  echo $this->loadTemplate('item');
}
В макетах обычно используют if : / endif;
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
В макетах обычно используют if : / endif;
Я давно от этого отказался, скобками удобнее, да и в Notepad++ скобки блоком подсвечиваются, который можно свернуть
*

vipiusss

  • Гуру
  • 5739
  • 344 / 11
  • Скайп: renor_
Доброе время. J 3.4.1

Зашёл в components/com_content/views/category/tmpl/blog.php
Нашёл:

echo $this->loadTemplate('item'); на 2 строках: 61 и 86

Заменил на :

if ($item->created_by == JFactory::getUser()->get->('id')) :
    echo $this->loadTemplate('item');
endif;


Создал в админке новые категорию и материал в ней, указал автором материала юзера А.
Создал в меню тип: Блог категории этой.

Но при открытии юзером Б данной сылки в меню на этот Блог категории, он всё равно видит материал, созданный юзером А.

Подскажите, что не так делаю?
Миграция, установка, обновление версий Joomla  |  Создание сайтов "под ключ"  |  Эксклюзивные заглушки "offline"  |  Работа с "напильником" над шаблонами и расширениями
*

b2z

  • Глобальный модератор
  • 7288
  • 778 / 0
  • Разраблю понемногу
Зашёл в components/com_content/views/category/tmpl/blog.php
Может у Вас переопределение в шаблоне, поэтому изменения не применяются?
*

vipiusss

  • Гуру
  • 5739
  • 344 / 11
  • Скайп: renor_
Скорее всего, т.к. только что проделал процедуру с шаблон/html/и т.д. и вообще белый экран теперь при заходе в данную категорию.
Пересоздам полностью всё, отпишу, может в этом и вина:
1.надо в шаблон,2.Пересоздать по новому.
Миграция, установка, обновление версий Joomla  |  Создание сайтов "под ключ"  |  Эксклюзивные заглушки "offline"  |  Работа с "напильником" над шаблонами и расширениями
*

vipiusss

  • Гуру
  • 5739
  • 344 / 11
  • Скайп: renor_
Разобрался!
Понадеялся на это:

Спойлер
[свернуть]

А оказывается никто, ничего не исправлял и я как "вася петин друг" решил по правильному совету endif; вместо скобки и на автопилоте скопировал первый!

Короче рабочий код:

if ($item->created_by == JFactory::getUser()->id) {
  echo $this->loadTemplate('item');
}


Поставлю обоим "+" (AlekVolsk и b2z) каждому за свой вклад!
Спасибо, вопрос решён, всё функционирует!
Миграция, установка, обновление версий Joomla  |  Создание сайтов "под ключ"  |  Эксклюзивные заглушки "offline"  |  Работа с "напильником" над шаблонами и расширениями
*

Сergei

  • Захожу иногда
  • 189
  • 0 / 0
Как вывести материалы для определенного пользователя на отдельной странице?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Не могу разблокировать материалы, модули для редактирования

Автор Ecodrev

Ответов: 3
Просмотров: 1572
Последний ответ 24.03.2025, 20:20:55
от R31rus
Пароль Пользователя

Автор Олег5

Ответов: 3
Просмотров: 999
Последний ответ 14.02.2025, 10:41:20
от fbr
Как установить header Cache-Control только для одной страницы по URL?

Автор Slava77

Ответов: 0
Просмотров: 1465
Последний ответ 23.03.2024, 00:16:36
от Slava77
Я создал пользователя Author, но он не может зайти в редактирование

Автор Olegus79

Ответов: 7
Просмотров: 1363
Последний ответ 19.10.2023, 20:48:52
от Vastriet
Joomla 3 создает материалы с нулевым id

Автор asmol

Ответов: 0
Просмотров: 896
Последний ответ 24.09.2023, 14:22:21
от asmol