Новости 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 Ответов
  • 1000 Просмотров
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
Добрый вечер/день.

С сайта joomshopping.pro был взять модуль Модуль Top Hits
Я его поковырял как мне надо, дополнил функции.

Но вот мне понадобилось получить топ хиты по определеному ID производителя.

Кто подскажет возможно ли такое сделать именно готовыми функциями шопинга?

как пример стандартного функционала получение хитов по категории
Код
 $cat_str = $params->get('catids', NULL); 

  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);
    }

$rows = $product->getTopRatingProducts($params->get('count_products', 4), $cat_arr);



Я пробовал сделать таким способом, по ай бренда  выбрал из всех товаров, N кол. товаров и закинул в массив новый. А там хотел отсортировать php сортировкой и вывести.
1. проблема после этого сайт начал очень долго грузится.
2.  Когда использовал я сортировку уже второго массива сайт падал 500 ошибкой. Может я не корректно ее применил ?
Код ниже
Спойлер
[свернуть]

Код
usort($мой_массив, function($a,$b){
    return ($a['hits']-$b['hits']);
});



-->
[свернуть]


P.S. Я соединил два модуля, хиты внедрил в Модуль Bestseller(модуль на том же сайте что и модуль хиты брал)
« Последнее редактирование: 26.10.2017, 17:55:27 от pavel2950 »
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
Сам разобрался, в components/com_jshopping/tables/product.php
в районе 990 строки я вставляю после  getTopHitsProducts функцию для получение, топ хитов по брендам

в функцию дабов. параметр для передачи $manuf_id,

а в SQL запрос добавил "AND prod.product_manufacturer_id = $manuf_id"



Код
function getTopHitsProductsManufacturer($count,  $array_categories = null, $manuf_id, $filters = array()){

        $jshopConfig = JSFactory::getConfig();

        $db = JFactory::getDBO();

        $adv_query = ""; $adv_from = ""; $adv_result = $this->getBuildQueryListProductDefaultResult();

        $this->getBuildQueryListProductSimpleList("tophits", $array_categories, $filters, $adv_query, $adv_from, $adv_result);

        $dispatcher = JDispatcher::getInstance();

        $dispatcher->trigger( 'onBeforeQueryGetProductList', array("top_hits_products", &$adv_result, &$adv_from, &$adv_query, &$order_query, &$filters));

        $query = "SELECT $adv_result FROM `#__jshopping_products` AS prod

                  INNER JOIN `#__jshopping_products_to_categories` AS pr_cat ON pr_cat.product_id = prod.product_id

                  LEFT JOIN `#__jshopping_categories` AS cat ON pr_cat.category_id = cat.category_id

                  $adv_from

                  WHERE prod.product_publish=1 AND cat.category_publish=1 ".$adv_query." AND prod.product_manufacturer_id = $manuf_id

                  GROUP BY prod.product_id

  ORDER BY prod.hits

  desc LIMIT ".$count;

        $db->setQuery($query);

        $products = $db->loadObjectList();

        $products = listProductUpdateData($products, 1);

        return $products;

    }

дальше строка вызова выглядела так

$brands = $product->getTopHitsProductsManufacturer($params->get('count_products', 7), $cat_arr,$manufacturer );


*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
как то вы сильно сложно подошли к вопросу :) ничего этого не нужно делать, тем более хакать ядро. все уже придумано до нас :) у метода getTopRatingProducts есть третий параметр $filters, массив, в который можно передать 'manufacturers' => array(ID производителя)

P.S. и качать что-либо с сайта joomshopping_pro тоже не нужно. мало того, что сайт никакого отношения к официальному сайту JoomShopping не имеет, так еще плюс к этому на него забили, и не обновляют давным давно.
« Последнее редактирование: 31.10.2017, 12:55:34 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
как то вы сильно сложно подошли к вопросу :) ничего этого не нужно делать, тем более хакать ядро. все уже придумано до нас :) у метода getTopRatingProducts есть третий параметр $filters, массив, в который можно передать 'manufacturers' => array(ID производителя)

P.S. и качать что-либо с сайта joomshopping_pro тоже не нужно. мало того, что сайт никакого отношения к официальному сайту JoomShopping не имеет, так еще плюс к этому на него забили, и не обновляют давным давно.

Большое спасибо, за подсказку. Как всегда выручили.


А можете все же подсказать, как правильно должен быть 3 параметр, а то я тык мык и не фига. Буду признателен и  + вам в репу кину)
« Последнее редактирование: 31.10.2017, 21:35:44 от pavel2950 »
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну так
массив, в который можно передать 'manufacturers' => array(ID производителя)

Код
$product->getTopRatingProducts($params->get('count_products', 4), $cat_arr, array('manufacturers' => array(ID производителя)));
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pavel2950

  • Захожу иногда
  • 194
  • 3 / 0
array('manufacturers' => array(ID производителя))


Ооо большое спасибо, я пытался отпр. массив через переменую но не работало. А вот массив влепить сразу и нормас все. Вы гуру просто!!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
та можно и через переменную, разницы особо нет. видимо что то все таки не так сделали...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Передать значение цены товара

Автор yurykom

Ответов: 16
Просмотров: 1213
Последний ответ 07.05.2019, 22:26:16
от dmitry_stas
Как передать select option в MySQL в форме заказа?

Автор Qverty2012

Ответов: 24
Просмотров: 2756
Последний ответ 17.06.2018, 16:03:42
от Qverty2012
передать параметры по ajax c JQ в php Полный вид товара

Автор pavel2950

Ответов: 3
Просмотров: 1067
Последний ответ 18.08.2017, 14:40:16
от pavel2950
"Неверный параметр" при сбросе пароля

Автор PSN

Ответов: 6
Просмотров: 1300
Последний ответ 31.10.2016, 16:52:47
от kit2m2
Передать свою переменную из корзины в заказ

Автор Ragivort

Ответов: 8
Просмотров: 1248
Последний ответ 25.11.2015, 19:49:02
от dmitry_stas