Новости 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 Гость просматривают эту тему.
  • 5 Ответов
  • 1188 Просмотров
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Всем привет.
Есть модуль вывода популярных товаров для категории. Принцип работы понятен берется по хитам товара. Но товаров много и некоторых нету временно или уже нету. Склад не подключен по этому товар которого нету помечен меткой "Нету в наличии" . Исходя из этого возникла потребность не выводить товар с меткой"Нету в наличии" в модуле Хитов.
Если в файле default.php добавляю условие
Код
<?php foreach($last_prod as $curr){ if ($curr->_label_name == 'Товара нет в наличии' ) continue;?>
То как бы все выходит, но тогда количество товаров может быть и 0 если все самые посещаемые будут с этой меткой. Так как основной перебор массива идет в mod_jshopping_tophits_products.php и там же определяется количество выводимых товаров. Сам файл mod_jshopping_tophits_products.php имеет такой вид
Код
<?php
    defined('_JEXEC') or die('Restricted access');
    error_reporting(E_ALL & ~E_NOTICE);
   
    if (!file_exists(JPATH_SITE.DS.'components'.DS.'com_jshopping'.DS.'jshopping.php')){
        JError::raiseError(500,"Please install component \"joomshopping\"");
    }
   
    require_once (JPATH_SITE.DS.'components'.DS.'com_jshopping'.DS."lib".DS."factory.php");
    require_once (JPATH_SITE.DS.'components'.DS.'com_jshopping'.DS."lib".DS."functions.php");       
    JSFactory::loadCssFiles();
    JSFactory::loadLanguageFile();
    $jshopConfig = JSFactory::getConfig();

    $product = JTable::getInstance('product', 'jshop');
    $cat_str = JRequest::getInt('category_id');
    if (is_array($cat_str)) {   
        $cat_arr = array();
        foreach($cat_str as $key=>$curr){
           if (intval($curr)) $cat_arr[$key] = intval($curr);
        } 
    } else {
        $cat_arr = array();
        if (intval($cat_str)) $cat_arr[] = intval($cat_str);
    }
   
     
$last_prod = $product->getTopHitsProducts($params->get('count_products', 4), $cat_arr); 
    foreach($last_prod as $key=>$value){
        $last_prod[$key]->product_link = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id=' . $value->category_id.'&product_id=' . $value->product_id ,1);
    }
   
    $noimage = "noimage.gif";
    $show_image = $params->get('show_image',1);
    require(JModuleHelper::getLayoutPath('mod_jshopping_tophits_products'));       
?>
Тот же финт не прокатывает и если добавить по аналогии
Код
$last_prod = $product->getTopHitsProducts($params->get('count_products', 4), $cat_arr);  
    foreach($last_prod as $key=>$value){
         if ($value->_label_name == 'Товара нет в наличии' ) continue;
        $last_prod[$key]->product_link = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id=' . $value->category_id.'&product_id=' . $value->product_id ,1);
    }
Ничего не выходит. Прошу помощи спецов в данном вопросе.
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Модуль хиты товаров по условию
« Ответ #1 : 06.11.2017, 11:24:55 »
ничего и не выйдет. что в шаблоне, что в mod_jshopping_tophits_products.php идет перебор уже отобранных товаров. и как вы правильно написали может быть такое что будут вообще все с такой меткой. этого не сделать в переборе в модуле, уже поздно там делать это. нужно именно отобрать без этого label_id. и варианта тут аж 4:
1. включить склад
2. написать плагин
3. написать полностью свой запрос на выборку, чтобы отбор был без учета этого label_id
4. хак ядра ЖШ
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Re: Модуль хиты товаров по условию
« Ответ #2 : 06.11.2017, 12:39:44 »
Хорошо раз это уже выбрано раньше. Тогда можно как увеличить Показатель 'count_products' на 1  если есть товар с такой сметкой. Типа
Код
foreach($last_prod as $curr){
if ($curr->_label_name == 'Товара нет в наличии' ){
                      count_products=count_products+1;
}
}
$last_prod = $product->getTopHitsProducts($params->get('count_products', 4), $cat_arr); 
    foreach($last_prod as $key=>$value){
        $last_prod[$key]->product_link = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id=' . $value->category_id.'&product_id=' . $value->product_id ,1);
    }
Понятно что count_products не так должно быть :)
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Модуль хиты товаров по условию
« Ответ #3 : 06.11.2017, 12:43:15 »
кому интересно я писал предыдущий пост? :) уже поздно что то увеличивать, товары в количестве count_products уже отобраны. их не станет волшебным образом больше. толку от того, что вы увеличите count_products с 4-х до 5-ти после того, как вы отобрали 4 товара?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

misteri27

  • Захожу иногда
  • 490
  • 0 / 0
Re: Модуль хиты товаров по условию
« Ответ #4 : 06.11.2017, 13:38:30 »
Стоп. В качестве бреда изменив в
Код
$last_prod = $product->getTopHitsProducts($params->get('count_products', 4), $cat_arr);  
    foreach($last_prod as $key=>$value){
        $last_prod[$key]->product_link = SEFLink('index.php?option=com_jshopping&controller=product&task=view&category_id=' . $value->category_id.'&product_id=' . $value->product_id ,1);
    }
Код
$params->get('count_products', 4)
на бред типа
Код
$v=3;
...$params->get('', $v)
Но все равно в mod_jshopping_tophits_products.php
[code]foreach($last_prod as $curr){
if ($curr->_label_name == 'Товара нет в наличии' ){
                      $v=$v+1;
}
Не получается
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Модуль хиты товаров по условию
« Ответ #5 : 06.11.2017, 14:39:37 »
не знаю, как по другому объяснить... попробуем на яблоках. вы пошли в магазин, купили там 4 яблока. пришли домой, начали их мыть, смотрите, а 1 гнилое. выкинули его, и думаете - вот блин, надо было 5 взять, тогда бы одно выкинул, и осталось бы 4, как и нужно. так вот ключевое слово в этой фразе - было :) надо было, понимаете? дома уже нет смысла в процессе перебора яблок увеличивать их количество. их у вас 4, и от того что вы увидев 1 гнилое захотите купить 5, их 5 не станет. угу?

варианты прежние:

1. включаем склад - пришли в магазин, и видим, что вот они спелые 5 ящиков, а вот отдельно гнилушки 2.
2. пишем плагин - дорогая, а скажи мне, гнилые тоже брать?
3. свой запрос - такс, пожалуй я переберу яблоки еще в магазине, а не дома.
4. хак ядра - товарищ директор, у вас яблоки в магазине порченые, нехорошо их подсовывать покупателям.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

WT JoomShopping Favorite - кнопки избранного в категории товаров и карточке тов

Автор sergeytolkachyov

Ответов: 26
Просмотров: 38908
Последний ответ 14.10.2025, 12:54:56
от sergeytolkachyov
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 2
Просмотров: 3846
Последний ответ 04.07.2025, 10:30:36
от sergeytolkachyov
[Решено] Сбросить счётчик ID товаров JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 2368
Последний ответ 13.02.2025, 00:11:20
от goga_pgasovav
Плагин обновления цен и остатков товаров JoomShopping из CSV

Автор sergeytolkachyov

Ответов: 0
Просмотров: 2520
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov
WT JShopping Cart - модуль Bootstrap 5 корзины для JoomShopping 5 и Joomla 4

Автор sergeytolkachyov

Ответов: 7
Просмотров: 5102
Последний ответ 15.12.2024, 09:34:09
от kit2m2