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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Как вывести дополнительную цену из БД в списке товаров в админке.
Добавил код в файл списка товаров в админке
Код
<td>
  <?php echo formatprice($row->product_price, sprintCurrency($row->currency_id));?>
</td>
<td>
  <?php echo formatprice($row->product_myprice, sprintCurrency($row->currency_id));?>
</td>
Добавил в БД строку product_myprice ниже цены товара и заполнил значениями.
Но в админке ничего не выводится.
Подскажите, пожалуйста, какие еще файлы поправить чтобы вывод моей цены заработал.
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
\administrator\components\com_jshopping\models\products.php
Функция getAllProducts
Нужно добавить в SELECT Ваше поле (в двух запросах)
pr.product_myprice
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Вставил в эту функцию, после pr.product_price свою цену pr.product_myprice, в 2-х запросах.
Не сработало, список товаров вообще не выводится. В структуре БД product_myprice существует после product_price.
Где еще нужно добавить?
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Переменная product_price_disc

Сначала вывел тут
administrator/components/com_jshopping/views/product_list/tmpl/default.php
Код
<?php echo formatprice($row->product_price_disc, sprintCurrency($row->currency_id));?>

Потом сделал изменения тут
administrator/components/com_jshopping/models/products.php
Код
if ($category_id) {
            $query = "SELECT pr.product_id, pr.product_publish, pr_cat.product_ordering, pr.`".$lang->get('name')."` as name, pr.`".$lang->get('short_description')."` as short_description, man.`".$lang->get('name')."` as man_name, pr.product_ean as ean, pr.product_quantity as qty, pr.product_thumb_image as image, pr.product_price, pr.product_price_disc, pr.currency_id, pr.hits, pr.unlimited, pr.product_date_added, pr.label_id $query_filed FROM `#__jshopping_products` AS pr
                      LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat USING (product_id)
                      LEFT JOIN `#__jshopping_manufacturers` AS man ON pr.product_manufacturer_id=man.manufacturer_id
                      $query_join
                      WHERE pr.parent_id=0 ".$where." ".$this->_allProductsOrder($order, $orderDir, $category_id)." ".$limit;
        }else{
            $mysqlversion = getMysqlVersion();
            if ($mysqlversion < "4.1.0"){
                $spec_where = "cat.`".$lang->get('name')."` AS namescats";
            }else{
                $spec_where = "GROUP_CONCAT(cat.`".$lang->get('name')."` SEPARATOR '<br>') AS namescats";
            }
           
            $query = "SELECT pr.product_id, pr.product_publish, pr.`".$lang->get('name')."` as name, pr.`".$lang->get('short_description')."` as short_description, man.`".$lang->get('name')."` as man_name, ".$spec_where.", pr.product_ean as ean, pr.product_quantity as qty, pr.product_thumb_image as image, pr.product_price, pr.product_price_disc, pr.currency_id, pr.hits, pr.unlimited, pr.product_date_added, pr.label_id $query_filed FROM `#__jshopping_products` AS pr
                      LEFT JOIN `#__jshopping_products_to_categories` AS pr_cat USING (product_id)
                      LEFT JOIN `#__jshopping_categories` AS cat ON pr_cat.category_id=cat.category_id
                      LEFT JOIN `#__jshopping_manufacturers` AS man ON pr.product_manufacturer_id=man.manufacturer_id
                      $query_join
                      WHERE pr.parent_id=0 ".$where." GROUP BY pr.product_id ".$this->_allProductsOrder($order, $orderDir)." ".$limit;
        }
После того как добавил в селект переменную список товаров вообще не выводится.
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Огромное спасибо, все получилось!
Вопрос закрыт, невнимателен в коде сайта.
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Огромное спасибо, все получилось!
Вопрос закрыт, невнимателен в коде сайта.
В карточке товара для вывода моей цены сработал код
Код
formatprice($this->product->product_price_disc)
А как в категории или в другом месте вывести мою цену? Код ниже не работает, ничего не выводит.
components/com_jshopping/templates/default/list_products/product.php
Код
<?php print formatprice($product->product_price_disc);?>
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
\components\com_jshopping\lib\jtableauto.php function getBuildQueryListProductDefaultResult
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
\components\com_jshopping\lib\jtableauto.php function getBuildQueryListProductDefaultResult
А что относительно корзины?
<?php print formatprice($prod['price_disc'])?> // в оригинале было ['price']
« Последнее редактирование: 21.10.2015, 10:49:02 от tomas_morgam »
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
с корзины надо начинать было. тогда бы вам сразу сказали, что там далеко не одна строка. вывести цену - это одно. а учитывать ее при покупке - совсем другое. ковыряйте модель cart
Спасибо, это также получилось. И последнее, правка емейл, где смотреть? Открыл модель checkout.php - не понятно где именно вытягивается цена и как "подсунуть" свою переменную.
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
какой email?
Шаблон письма-заказа, который отсылается на почту.
/components/com_jshopping/templates/default/checkout/orderemail.php
Код
<?php print formatprice($prod->product_price_disc*$prod->product_quantity, $order->currency_code); ?>
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну так а вы в заказ уже сохранили свою цену?

может вам проще было для этого использовать обычную (стандартную) цену? а вашу новую просто показывать там где сейчас показываете стандартную.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Да, цену подключил в форме заказа просто сменив "price" на "price_disc".
Код
<?php print formatprice(($prod['price_disc'])*$prod['quantity']);?>
С формирование емейл так не выходит.

Так я и не могу найти где выводится стандатрая цена, чтобы изменить на новую.
*

dmitry_stas

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

tomas_morgam

  • Захожу иногда
  • 126
  • 0 / 0
Как вывести в списке товара возле названия список категорий, к которым подключен товар (товар в 2-3 категориях).
Желательно перед этим кодом
Код
<?php if (!$manufacturer_id){?>        
   <td>
      <?php echo $row->man_name;?>
   </td>
   <?php }?>
*

Linfuby

  • Завсегдатай
  • 1242
  • 176 / 0
  • Всё просто...
Код: php
<?php if (!$category_id){?>
   <td>
      <?php echo $row->namescats;?>
   </td>
   <?php }?>
Немного воображения и логики, и любая проблема становится решенной.
Кривые решения - дают кривой результат!
Решения для JoomShopping
Благодарности и поддержка принимаются по след. реквизитам:
Яндекс.Деньги - 41001751720054
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

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

Автор sergeytolkachyov

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

Автор sergeytolkachyov

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

Автор goga_pgasovav

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

Автор sergeytolkachyov

Ответов: 0
Просмотров: 2522
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov
JoomShopping как вывести фильтр в наличии

Автор thevaca

Ответов: 4
Просмотров: 2329
Последний ответ 15.08.2024, 17:41:20
от thevaca