Новости 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

👩‍💻 Joomla включена в программу Google Summer of Code 2026.

👩‍💻 Joomla включена в программу Google Summer of Code 2026.

Google Summer of Code (GSoC) - программа компании Google, которая позволяет участникам программы под руководством опытных наставников писать код для организаций, занимающейся открытым исходным кодом. Joomla принимает участие в этой программе не в первый раз и в 2026 году снова включена в список GSoC. Для программы утверждается список "идей", воплотить которые должны участники под руководством наставников.

Проекты Joomla в рамках программы GSoC 2026.

Проект I: Ajax-бэкенд.
- Действия в административной панели без необходимости обновлять страницу.
- Автоматическое сохранение содержимого во время редактирования.
- Расширенный фильтр - поиск и фильтрация по пользовательским полям.

Проект II: Автоматизация рабочих процессов (workflow + task scheduler).
Joomla имеет функцию процессов и планировщика задач. Теперь эти две функции следует объединить, чтобы пользователь мог настраивать назначенные рабочие процессы таким образом, чтобы переходы выполнялись автоматически, с возможностью точного определения времени. Должна быть возможность создавать циклы или прямые запланированные рабочие процессы. Предполагается, что интерфейс должен учитывать хороший пользовательский опыт, удобство использования и современные стандарты доступности. Ожидается, что будет добавлен интерфейс для управления процессами и их расписанием на страницах категорий и материалов. Так же ожидается, что сторонние компоненты также смогут воспользоваться этим функционалом.

Проект III: Мультикатегории.
В настоящее время Joomla! не позволяет назначать один элемент нескольким категориям. Хотя система тегов часто используется в качестве замены, существует острая потребность в нативной поддержке нескольких категорий, чтобы привести Joomla! в соответствие с другими современными системами управления контентом.

Проект IV: Обучение с подкреплением на основе отзывов переводчиков.
Joomla собирается использовать автоматический перевод документации. В каждом языке есть свои специфические слова, характерные для Joomla. Предполагается обучать языковые модели, используя обратную связь от переводчиков, чтобы постоянно улучшать качество переводов и учитывать специфические языковые особенности Joomla.

Принять участие GSoC 2026
Подробнее о проектах Joomla GSoC 2026
Чат GSoC в Mattermost (международное сообщество Joomla)

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

ABTOP

  • Захожу иногда
  • 493
  • 33 / 4
Многие, включая меня, жаловались на неправильную кодировку слова "Голоса" или "Голосовать" как����������
Поскольку местная поддержка не высказала ни одной дельной мысли, пришлось кумекать самому.
И вот, что я обнаружил:

Проблема номер один.
Основная проблема в том, что красавчеги-разработчеги Mosets Tree используют strtolower для конвертации заглавной буквы в строчную в этом слове. Убедимся в этом открыв sub_listingDetails.tpl.php и начиная со строки 125 видим:
Код
if( $this->link->link_votes <= 1 ) {
echo $this->link->link_votes . " " . strtolower(JText::_( 'Vote' ));
} elseif ($this->link->link_votes > 1 ) {
echo $this->link->link_votes . " " . strtolower(JText::_( 'Votes' ));
}

Использование strtolower в случае, когда заранее известна необходимость поддержки кодировки UTF граничит с идиотизмом.
Руководство по PHP ясно говорит, что
Цитировать
Returns string  with all alphabetic characters converted to lowercase.
Note that 'alphabetic' is determined by the current locale. This means that in i.e. the default "C" locale, characters such as umlaut-A (Ä) will not be converted.
Проще говоря, это работает для ASCII и тамошние дальнейшие примеры изобилуют решениями для нелатинских алфавитов.

Как этой беде помочь?
Можно использовать mb_convert_case, но тут мы сталкиваемся проблемой номер два.

Проблема номер два.
Красавчеги-разработчеги Mosets Tree не отличают глаголов от существительных. В английском такая глупость позволительна чаще, чем в русском, но мы в данном случае, получим "1 голосовать", то есть надо доделывать ещё и языковые константы. Поскольку существительное "голосов" всё-равно не будет стыковаться с числительным, то проще и корректнее использовать давнишний русский приём двоеточия - "Голосов: 1".

Как это сделать?
Открываем вышеуказанный файл - sub_listingDetails.tpl.php - и заменяем указанные строки 125-129 на одну такую строку:
Код
echo JText::_( 'Votes' ). ": " . $this->link->link_votes ;

Всё.
*

liadesign

  • Новичок
  • 7
  • 0 / 0
Я испарил как были крякозяблы так и остались, в чем еще может быть причина
*

nikkem

  • Новичок
  • 4
  • 0 / 0
кодировка базы как вариант !
*

ABTOP

  • Захожу иногда
  • 493
  • 33 / 4
Я испарил как были крякозяблы так и остались, в чем еще может быть причина
Кракозябры кракозябрам рознь. Я ведь не случайно свои кракозябры процитировал...
*

Sakhalin

  • Захожу иногда
  • 162
  • 6 / 0
АВТОР, спасибо все встало отлично! +1
*

diks13

  • Захожу иногда
  • 257
  • 10 / 0
Я испарил как были крякозяблы так и остались, в чем еще может быть причина
попробуй в .htaccess  прописать AddDefaultCharset UTF-8
*

lazer

  • Осваиваюсь на форуме
  • 38
  • 0 / 0
А ведь все заработало! Автор молодец
*

masternaraione

  • Новичок
  • 8
  • 0 / 1
Многие, включая меня, жаловались на неправильную кодировку слова "Голоса" или "Голосовать" как����������
Поскольку местная поддержка не высказала ни одной дельной мысли, пришлось кумекать самому.
И вот, что я обнаружил:

Проблема номер один.
Основная проблема в том, что красавчеги-разработчеги Mosets Tree используют strtolower для конвертации заглавной буквы в строчную в этом слове. Убедимся в этом открыв sub_listingDetails.tpl.php и начиная со строки 125 видим:
Код
if( $this->link->link_votes <= 1 ) {
echo $this->link->link_votes . " " . strtolower(JText::_( 'Vote' ));
} elseif ($this->link->link_votes > 1 ) {
echo $this->link->link_votes . " " . strtolower(JText::_( 'Votes' ));
}

Использование strtolower в случае, когда заранее известна необходимость поддержки кодировки UTF граничит с идиотизмом.
Руководство по PHP ясно говорит, чтоПроще говоря, это работает для ASCII и тамошние дальнейшие примеры изобилуют решениями для нелатинских алфавитов.

Как этой беде помочь?
Можно использовать mb_convert_case, но тут мы сталкиваемся проблемой номер два.

Проблема номер два.
Красавчеги-разработчеги Mosets Tree не отличают глаголов от существительных. В английском такая глупость позволительна чаще, чем в русском, но мы в данном случае, получим "1 голосовать", то есть надо доделывать ещё и языковые константы. Поскольку существительное "голосов" всё-равно не будет стыковаться с числительным, то проще и корректнее использовать давнишний русский приём двоеточия - "Голосов: 1".

Как это сделать?
Открываем вышеуказанный файл - sub_listingDetails.tpl.php - и заменяем указанные строки 125-129 на одну такую строку:
Код
echo JText::_( 'Votes' ). ": " . $this->link->link_votes ;

Всё.

Спасибо огромное. +1 автору. Сделал как написано и всё получилось.
*

Gryphus

  • Новичок
  • 3
  • 0 / 0
А что делать с такими - 20 Г������с�� кракозябрами? и такими - 0 От��ы��ы
*

ABTOP

  • Захожу иногда
  • 493
  • 33 / 4
Убедиться, что упорядочение базы данных задано как одна из utf8_general_ci или utf8_unicode_ci
*

IgorFIN

  • Осваиваюсь на форуме
  • 28
  • 2 / 0
Я нашел выход как побороть кракозяблы без хака компонента.

В файлах локализации в проблемных полях перевода использовать не Кирилицу а десятичный код букв.

Например
Код
\administrator\language\ru-RU\ru-RU.com_mtree.ini
CORE="&#1054;&#1089;&#1085;&#1086;&#1074;&#1085;&#1086;&#1081;"

\language\ru-RU\ru-RU.com_mtree.ini
VOTE="&#1043;&#1086;&#1083;&#1086;&#1089;&#1072;"
« Последнее редактирование: 31.05.2012, 15:53:19 от IgorFIN »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

3 Проблемы с Mosets Tree

Автор Bruce

Ответов: 2
Просмотров: 2413
Последний ответ 18.01.2010, 17:52:25
от Ksen-nn