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

Вышли релизы Joomla 6.0.3 и Joomla 5.4.3

Релиз Joomla 6.0.3 и Joomla 5.4.3

Проект Joomla рад сообщить о выпуске Joomla 6.0.3 и Joomla 5.4.3. Это релиз исправлений ошибок и улучшений для серии Joomla 6.0 и Joomla 5.4.

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

Diiimonn

  • Захожу иногда
  • 234
  • 29 / 0
Проблема с router.php
« : 23.02.2011, 17:52:54 »
Вобщем рашил заморочится с созданием router.php к свеженаписанному компоненту.
Вроде бы ничего сложного но...

исходный url: http://site.ru/index.php?option=com_tovar&cat=1
во всем компоненте действует только такой формат ссылки, меняется только cat.

надо получить: http://site.ru/1.html

в компоненте ссылку пропускаю через JRoute: JRoute::_(index.php?option=com_tovar&cat=1)
router.php:
Код
function tovarBuildRoute(&$query)
{
$segments = array();
if(isset($query['cat']))
{
$segments[] = $query['cat'];
unset($query['cat']);
}
return $segments;
}

function tovarParseRoute($segments)
{
$vars = array();
$vars['cat'] = $segments[0];
return $vars;
}

Однако после включения ЧПУ получаю ссылку вида: http://site.ru/component/tovar/1.html
Если взглянуть на com_content или com_contact то там в ссылках получается чистый алиас и все.
Чет никак не могу убить component и tovar.
Что подскажите?
Создание расширений для Joomla
Skype: diiimonn
ICQ: 351181332
*

LOBsTerr

  • Осваиваюсь на форуме
  • 23
  • 2 / 0
  • Вопрос?
Re: Проблема с router.php
« Ответ #1 : 18.03.2011, 07:38:52 »
Привет Dillimon,
Я нашел один вариант, но единственно чем он плох, надо править немного файлы ядра. Вот, что единственно мне не нравиться в моем варианте, ну а остальная логика переноситься на тебя самого.
Я только начал разбираться с этой проблемой, мне было бы очень интересно посмотреть как с этим разбираются известные компоненты SEF. Но под рукой ни одного нет. Но моя главная цель была не использовать как раз эти компоненты. И так вот мое решение:

1) Ищем файл /includes/router.php

Код
/*
* Build the application route
*/

                //вот откуда берется в урле component!
                //если не нашли Элемент меню и он не является текущим компонентов
$built = false;
if (isset($query['Itemid']) && !empty($query['Itemid']))
{
$item = $menu->getItem($query['Itemid']);

if (is_object($item) && $query['option'] == $item->component) {
$tmp = !empty($tmp)? $item->route.'/'.$tmp : $item->route;
$built = true;
}
}

                //и собственной здесь строка собирается уже вместе с компонентом
                if($built) {
                        $tmp = 'component/'.substr($query['option'], 4).'/'.$tmp;
                }

Вот проблемная часть в кода. Как видно вся проблема именно здесь. Понятно почему они так сделали, им же надо знать, что это за компонент, если он не является ссылкой меню. Хотя можно было предусмотреть другую логику.

И так я немного модифицировал последнее условие
Код
if(isset($query['option']) && !$built) {
        $tmp = 'component/'.substr($query['option'], 4).'/'.$tmp;
}

То если не передан option в URI, мы не добавляем component.

В но для этого нам надо самим удалил option из url, Router.php вашего компонент удаляем option:

Код
function [ComponentName]BuildRoute(&$query)
{
        unset($query['option']);

        //build your URI
}

Далее нам надо самостоятельно обработать URI, а иначе получим 404 ошибку "Компонент не найден". Для этого создаем плагин.

Плагин будет делать следующее, парсить урл по вашим правилам и затем возвращать переменную option в URI в зависимости от того, как вы распарсили URI.
Пример:
Код
class plgSystem[Name]Router extends JPlugin {

    var $_config = null;

    function plgSystemSushiRouter(& $subject, $config) {
        global $mainframe;

if ($mainframe->isAdmin()) {
            return;
        }
        
        parent::__construct($subject, $config);
    }

    function onAfterInitialise() {
        $app = &JFactory::getApplication();
        $router = &$app->getRouter();
        $router->attachBuildRule('route[Name]Rule');
        $this->parseSushiRule($router);
    }

    function Parse[Name]Rule($router){
        $uri = &JURI::getInstance();
        if (!$uri->getVar('option')){
            //Парсим урл по своей логике здесь
//В конце не забываем добавить option в URI
$uri->setVar('option', $component_name);
        }
    }
}

Подведу итоги.
1) У нас только одна модификация ядра  /includes/router.php, что очень удобно
2) У нас один плагин, в котором сосредоточена логика, для всех наших компонентов. При этом если router.php получил название компонента (option), все идет стандартным путем.
3) Мы определяем как будут вести себя компоненты в их файлах Router.php, то есть убрали option все будет обрабатывать plugin. Не убрали, все работает как есть
4) Пока не нашел ничего лучше, может оно и есть
5) Кажется немного запутано на первый взгляд, но если проделать и понять, все довольно просто.
6) Спрашивайте отвечу на любые вопросы
« Последнее редактирование: 18.03.2011, 07:43:57 от LOBsTerr »
*

Diiimonn

  • Захожу иногда
  • 234
  • 29 / 0
Re: Проблема с router.php
« Ответ #2 : 18.03.2011, 16:45:58 »
спасибо за ответ и наработки.
Я решил проблему добавлением псевдонима в меню.
Создание расширений для Joomla
Skype: diiimonn
ICQ: 351181332
*

vtx

  • Захожу иногда
  • 221
  • 19 / 0
Re: Проблема с router.php
« Ответ #3 : 14.10.2011, 13:45:40 »
Здравствуйте.
А как удалить component/virtuemart/ из внешних ссылок для этого компонента?
понимаю что в роуторе надо изменить примерно так
Код
if(!$built) {
if ($component = "com_virtuemart") {
      $option='shop';
$tmp = '/'.$tmp;
}else{

$tmp = 'component/'.substr($query['option'], 4).'/'.$tmp;

}
}
Но в итоге получаем ответ сервера 404.
Как пофиксить?
*

Lex

  • Завсегдатай
  • 1615
  • 274 / 1
Re: Проблема с router.php
« Ответ #4 : 14.10.2011, 13:49:29 »
component в ссылке возникает если не прописан алиас пункта меню
Жизнь заставила учиться.
В личке на вопросы не отвечаю.
*

vtx

  • Захожу иногда
  • 221
  • 19 / 0
Re: Проблема с router.php
« Ответ #5 : 14.10.2011, 13:57:41 »
это я понимаю.
но у меня на главной стоит модуль с фильтром товаров вирта, и он генерит подобные ссылки.
внутри магазина все хорошо.
*

Diiimonn

  • Захожу иногда
  • 234
  • 29 / 0
Re: Проблема с router.php
« Ответ #6 : 15.10.2011, 15:29:40 »
Цитировать
но у меня на главной стоит модуль с фильтром товаров вирта, и он генерит подобные ссылки.
возможно надо копать в сторону подставления правильного Itemid в генерируемых ссылках.
Создание расширений для Joomla
Skype: diiimonn
ICQ: 351181332
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Проблема с редиректом

Автор cher68

Ответов: 2
Просмотров: 4487
Последний ответ 03.08.2019, 18:46:28
от cher68
Проблема с генерацией нового пароля взамен забытого старого в 1.5.16-1.5.17?

Автор ecolora

Ответов: 30
Просмотров: 31302
Последний ответ 08.12.2017, 12:25:27
от Masha2245
Проблема Кэширование в Joomla 1.5.26

Автор berTalino

Ответов: 6
Просмотров: 2725
Последний ответ 02.08.2017, 15:31:50
от berTalino
Проблема со стилями в шапке сайта

Автор cps83

Ответов: 2
Просмотров: 2186
Последний ответ 09.08.2016, 11:14:00
от cps83
Проблема после переноса в субдиректорию

Автор brendmaster

Ответов: 8
Просмотров: 2689
Последний ответ 28.05.2015, 14:54:40
от Stasweb