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

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Добрый день.
Помогите пожалуйста с реализацией задачи.
Есть категория с подкатегориями. Нужен следующий вариант вывода товаров:
Категория 1
  Название подкатегории 1
    Товары подкатегории 1
  Название подкатегории 2
    Товары подкатегории 2
 ...
*

ViktorMah

  • Захожу иногда
  • 252
  • 30 / 0
*

CCTRRoman

  • Захожу иногда
  • 121
  • 3 / 0
Re: Товары подкатегорий в категории
« Ответ #2 : 05.11.2014, 11:38:27 »
не совсем понятно, что Вы хотите...
попробуйте поиском - на форуме уже были похожие вопросы, например тут http://joomlaforum.ru/index.php?topic=227458.0
если нужно, что бы в категориях выводились сразу товары из всех под-категорий - для этого есть специальный плагин http://joomlaforum.ru/index.php/topic,199506.0.html
*

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Re: Товары подкатегорий в категории
« Ответ #3 : 05.11.2014, 17:55:12 »
Вам в эту тему http://joomlaforum.ru/index.php/topic,199506.0.html
Спасибо за ссылку, но как-то такой вариант не нравится. Полное изменение кода. Все стили поехали, заголовки - не заголовки, изображения не подгружаются.
Мне кажется есть более простой вариант, изменяя лишь шаблон категории.
« Последнее редактирование: 05.11.2014, 23:05:41 от BelMary »
*

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Re: Товары подкатегорий в категории
« Ответ #4 : 05.11.2014, 17:59:02 »
не совсем понятно, что Вы хотите...
попробуйте поиском - на форуме уже были похожие вопросы, например тут http://joomlaforum.ru/index.php?topic=227458.0
если нужно, что бы в категориях выводились сразу товары из всех под-категорий - для этого есть специальный плагин http://joomlaforum.ru/index.php/topic,199506.0.html


С плагином вывода товаров из подкатегорий в категорию, выводится следующим образом:
Категория 1
  Название подкатегории 1
  Название подкатегории 2
  Товары подкатегории 1
  Товары подкатегории 2

А нужно разделить товары в соответствующие подкатегории:
  Название подкатегории 1
    Товары подкатегории 1
  Название подкатегории 2
    Товары подкатегории 2
*

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
Re: Товары подкатегорий в категории
« Ответ #5 : 05.11.2014, 23:18:43 »
Нашла ответ на другом сайте. Тоже полная замен кода, но в итоге смотрится намного лучше. Пока остановилась на таком варианте, но думаю можно сделать проще. Возможно кому-то понадобится:

Открывает файл: components/com_jshopping/tables/category.php
Ищем код, строка ~151

 
Код
$query = "SELECT $adv_result FROM `#__jshopping_products` AS prod
                  LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat USING (product_id)
                  $adv_from
                  WHERE pr_cat.category_id = '".$this->_db->escape($this->category_id)."' AND prod.product_publish = '1' ".$adv_query." ".$order_query;

 
меняем на:

Код
$SubCat='';
      foreach ($this->getSubCategories($this->_db->getEscaped($this->category_id), 'name', 'asc', 1) as $SubC) {
        $SubCat.="'".$SubC->category_id."', ";
      }
      if ($SubCat!='') $SubCat=" IN (".$SubCat."'".$this->_db->getEscaped($this->category_id)."' ) ";
      else $SubCat=" = '".$this->_db->getEscaped($this->category_id)."' ";
 
        $query = "SELECT $adv_result FROM `#__jshopping_products` AS prod
                  LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat USING (product_id)
                  $adv_from
                  WHERE pr_cat.category_id ".$SubCat." AND prod.product_publish = '1' ".$adv_query." ".$order_query;
 


Далее для правильного построения ссылок открываем файл: components/com_jshopping/controllers/category.php

строка: ~119

Код
addLinkToProducts($products, $category_id);
меняем на:

Код
addLinkToProducts($products, $SubCat);

 

Потом открываем файл: components/com_jshopping/templates/default/category/category_default.php и меняем весь код на этот:

Код
<?php defined('_JEXEC') or die(); ?>
<div class="main_cat">
<h1><?php print $this->category->name?></h1>
<?php print $this->category->description?>
<?php include(dirname(__FILE__)."/products.php");?>
</div>


 

 файл: components/com_jshopping/templates/default/category/products.php меняем весь код на этот:

Код
<?php defined('_JEXEC') or die(); ?>
<?php if ($this->display_list_products){?>
<?php include(dirname(__FILE__)."/../".$this->template_block_form_filter);?>
 
<?php // start main category items?>
 <?php if (count($this->rows)){?>
 <div class="main_products">
 <?php foreach ($this->rows as $k=>$product){?>
 
 <?php if (($product->category_id) == ($this->category->category_id)) {?>
 
 <div class="product_item w<?php print $this->count_product_to_row?>" >
 <?php include(dirname(__FILE__)."/../list_products/".$product->template_block_product);?>
 <?php //include (JPATH_COMPONENT."/templates/".$this->category->category_template."/list_products/". $product->template_block_product);?>
 </div>
 
 <?php }?>
 
 <?php }?>
 </div>
 <?php } //end main items?>
 
 
<div class="jw_category">
 <?php if (count($this->categories)){ //start children categories?>
 <div class = "jw list_category">
 <?php foreach($this->categories as $k=>$category){?>
 
 <div class="jw_cat">
 <div class = "category">
 
 <?php if ($category->category_image) { //caterory image?>
 <div class="image">
 <a href = "<?php print $category->category_link;?>"><img class="jshop_img" src="<?php print $this->image_category_path;?>/" alt="<?php print htmlspecialchars($category->name)?>" title="<?php print htmlspecialchars($category->name)?>" /></a>
 </div>
 <?php } //end cat image?>
 <div class="cat_link">
 <a class = "cat_title" href = "<?php print $category->category_link?>"><?php print $category->name?></a>
 <p class = "jw_cat_sdesc"><?php print $category->short_description?></p>
 </div>
 </div>
 
 <?php if (count($this->rows)){ // start children category items?>
 <div class="jw_products">
 <?php foreach ($this->rows as $k=>$product){?>
 
 <?php if (($product->category_id) == ($category->category_id)) {?>
 
 <div class="product_item w<?php print $this->count_product_to_row?>" >
 <?php include(dirname(__FILE__)."/../list_products/".$product->template_block_product);?>
 </div>
 
 <?php }?>
 
 <?php }?>
 </div>
 <?php } // end children category items?>
 <?php if ($this->display_pagination){
 include(dirname(__FILE__)."/../".$this->template_block_pagination);
 }?>
 
 </div>
 <?php } ?>
 </div>
 <?php } // end children categories?>
</div>
 
 
<?php }?>
*

CCTRRoman

  • Захожу иногда
  • 121
  • 3 / 0
Re: Товары подкатегорий в категории
« Ответ #6 : 06.11.2014, 01:46:39 »
скиньте ссылку на Ваш проект - интересно посмотреть что получилось в итоге после всех манипуляций
*

BelMary

  • Захожу иногда
  • 87
  • 6 / 0
*

viteg

  • Захожу иногда
  • 209
  • 2 / 0
Re: Товары подкатегорий в категории
« Ответ #8 : 28.11.2014, 16:23:19 »
Спасибо. Все работает.

Но после этого решения есть другая проблема:
Когда нужно добавить отдельную категорию в отдельную страницу, то при открытии этой страницы - она пустая.
Пробую добавить данный код
Код
<div class="jshop_list_product">    
<?php
    include(dirname(__FILE__)."/../".$this->template_block_form_filter);
    if (count($this->rows)){
        include(dirname(__FILE__)."/../".$this->template_block_list_product);
    }
    if ($this->display_pagination){
        include(dirname(__FILE__)."/../".$this->template_block_pagination);
    }
?>
</div>
в components/com_jshopping/templates/default/category/products.php после
Код
<?php } // end children categories?>
но тогда на странице со всеми подкатегориями товары дублируются.
Умом понимаю, что нужно написать простенький php скрипт, чтобы добавленный мною код подключался только при отсутствии подкатегорий (или чтото подобное...), но знания php не хватает.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор sergeytolkachyov

Ответов: 26
Просмотров: 38912
Последний ответ 14.10.2025, 12:54:56
от sergeytolkachyov
JShopping 5: отображение всех подкатегорий

Автор Napst3r

Ответов: 2
Просмотров: 1643
Последний ответ 10.01.2025, 14:54:21
от Napst3r
JoomShopping, вывод всех категории к которым принадлежит товар

Автор Valent777

Ответов: 12
Просмотров: 3564
Последний ответ 01.11.2024, 14:57:28
от kit2m2
Дополнительные поля для категории JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 2188
Последний ответ 07.07.2024, 08:43:15
от nevigen
Последние просмотренные товары JoomShopping

Автор Sulpher

Ответов: 29
Просмотров: 9848
Последний ответ 13.10.2023, 22:05:16
от sergeytolkachyov