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

Cerber

  • Захожу иногда
  • 266
  • 34 / 0
  • Богиня Иштар и ее пес Пи..ц
Как в шаблоне админки “Редактировать товар” вытащить название производителя?
Как бы могу вытащить id производителя ... а потом наверно лезть в другую таблицу.?
*

dmitry_stas

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

Cerber

  • Захожу иногда
  • 266
  • 34 / 0
  • Богиня Иштар и ее пес Пи..ц
Класс :) я как раз закончил.


Код: php
<?php  //Manufacturer name//
$db = JFactory::getDBO();
$sql = "SELECT * FROM #__jshopping_manufacturers";
$db->setQuery($sql);
$factories = $db->loadObjectList();
foreach($factories as $factory){
$name_brend = JSFactory::getLang()->get("name");
$brends[$factory->manufacturer_id] = $factory->$name_brend;
}

echo $brends[$row->product_manufacturer_id];
?>

Селекты потрошить не пробовал, но рискну
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
угу. а можно выдрать из селекта производителей регуляркой (тa option, которая selected), без доп. запросов будет
при редактировании товара один доп запрос будет проще нежели регулярку. Хотя у нас же есть JS - не надо ни запросов ни регулярку, GetElementByID
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
ну нам же надо не весь HTML, а только небольшой фрагмент через регулярку пропустить, который $this->lists['manufacturers']. хотя согласен, там и запрос конечно по id - считай не запрос :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
ну нам же надо не весь HTML, а только небольшой фрагмент через регулярку пропустить
А зачем вообще нам регулярка, когда на том же квери обращение к элементу
Код: javascript
$( "#mysel option:selected" ).text();
И подставили этот текст в нужное место DOM, без запросов и регулярок, чисто для отображения.
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmitry_stas

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

dmitry_stas

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

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
а исходя из того, что оно и так показывается в селекте, то просто предполагаю, что не только показать.
я не спец в шоппинге, но раз оно в карточке товара уже выделяется активным - значит название производителя есть в общем массиве, выше сделать var_dump входящего и вытащить нужное значение.
Но это я уже углубляюсь (хотя опять же - без регулярок, запросов и JS - все штатно)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
я не спец в шоппинге, но раз оно в карточке товара уже выделяется активным - значит название производителя есть в общем массиве, выше сделать var_dump входящего и вытащить нужное значение.
не, во вью попадает только уже сформированный селект. отдельно производителя нет.
Код
        $lists['manufacturers'] = JHTML::_('select.genericlist', $manufs,'product_manufacturer_id','class = "inputbox" size = "1"','manufacturer_id','name',$product->product_manufacturer_id);
        $view->assign('lists', $lists);
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
не, во вью попадает только уже сформированный селект. отдельно производителя нет.
Понятно. Тогда самый простой и быстрый вариант для отображения производителя - пример выше на JS
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

Cerber

  • Захожу иногда
  • 266
  • 34 / 0
  • Богиня Иштар и ее пес Пи..ц
... просто Cerber не уточнил, для чего именно нужно название...
Все банально, подставить в тайтл и добавить в краткое, чтоб можно было искать по названию производителя.


Код: javascript
<script>document.write($("#product_manufacturer_id option:selected").text());</script>
На простом HTML сайте отрабатывает, а вот в админке нет.
Пробовал по разному, просто сценарий не отрабатывает.

Вариант полегче -- -- -- -- -- -- -- -- --
Код: php
<?php	//Manufacturer name//
$db = JFactory::getDBO();
$query = "SELECT * FROM #__jshopping_manufacturers WHERE manufacturer_id={$row->product_manufacturer_id}";
$db->setQuery($query);
$factories = $db->loadObjectList();
foreach($factories as $factory){
    $brend_name = JSFactory::getLang()->get("name");
    echo $factory->$brend_name;
}
?>
« Последнее редактирование: 01.10.2016, 13:09:25 от Cerber »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Товар - файл. Как ограничить добавление в корзину только 1 шт?

Автор SLV

Ответов: 15
Просмотров: 3452
Последний ответ 24.07.2025, 11:34:21
от SLV
JoomShopping, вывод всех категории к которым принадлежит товар

Автор Valent777

Ответов: 12
Просмотров: 3564
Последний ответ 01.11.2024, 14:57:28
от kit2m2
Пакетная загрузка изображений в товар/категорию JoomShopping

Автор Frost68

Ответов: 3
Просмотров: 2377
Последний ответ 13.08.2024, 06:54:24
от Lemonez
JoomShopping 5 в части браузеров не удалить товар

Автор oslyabya

Ответов: 3
Просмотров: 1892
Последний ответ 05.07.2024, 15:11:29
от kit2m2
Разные ссылки и названия на один товар

Автор gooodwin67

Ответов: 2
Просмотров: 1548
Последний ответ 04.11.2023, 12:34:19
от nevigen