Новости 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 Пользователей и 2 Гостей просматривают эту тему.
  • 41 Ответов
  • 22373 Просмотров
*

Sergeyy

  • Захожу иногда
  • 154
  • 3 / 0
А какая Fabrik? Если 3, то есть вариант  такой:
Можно добавить в таблицу элемент типа 'calc' и в нем соединить другие элементы.

По-моему нужно смотреть в сторону шаблона div при этом не писать элементы в default_row  php echo $this->_row->data->элемент;
(есть подводные камни), а разместить их как угодно при помощи CSS
*

spak

  • Новичок
  • 8
  • 0 / 0
А если стоит fabrik 2, то решить эту проблему нельзя?
*

spak

  • Новичок
  • 8
  • 0 / 0
Привет, Sergeyy! А можно поподробней, как при помощи CSS разместить несколько элементов в 1 колонке таблицы. Заранее благодарю.
*

Sergeyy

  • Захожу иногда
  • 154
  • 3 / 0
Без знаний CSS трудновато будет!
Используйте:
    clear: both
    float: left
    margin-left: 300px
    float: right
и
    position: absolute;
где необходимо!

у вас таблица выглядит так:
Код
<li class="table_name___element_name1
<li class="table_name___element_name2
<li class="table_name___element_name3
<li class="table_name___element_name4

CSS будет:
Код
.table_name___element_name1 {
    box-shadow: 0 0 3px #999999;
    float: left;
    margin-left: 20px;
    padding: 3px 10px;
    width: 100px;
}

.table_name___element_name2 {
    box-shadow: 0 0 3px #999999;
    float: left;
    margin-left: 20px;
    padding: 3px 10px;
    width: 150px;
}

.table_name___element_name3 {
    box-shadow: 0 0 3px #999999;
    clear: both;
    float: left;
    margin-left: 160px;
    padding: 3px 10px;
    width: 150px;
}

.table_name___element_name4 {
    border: 1px dotted #000000;
    margin-left: 350px;
    position: absolute;
    width: 300px;
}

Вот на моём тестовом сайте пример pro-joom.ru
Поставьте полагин Фаербуг и смотрите код!
*

spak

  • Новичок
  • 8
  • 0 / 0
Уважаемый Sergeyy, спасибо за ответ Не могли бы Вы связаться со мной по скайпу - gerasim778. Заранее благодарю.
*

Sergeyy

  • Захожу иногда
  • 154
  • 3 / 0
Напишите мне на маил-агент:
sergo.agent@mail.ru
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
По-моему нужно смотреть в сторону шаблона div при этом не писать элементы в default_row  php echo $this->_row->data->элемент;
(есть подводные камни), а разместить их как угодно при помощи CSS
Полностью согласен. Но если человек мог бы править  default_row.php или *.css, то вопрос как соединить два поля не задавался бы ...  )
« Последнее редактирование: 11.01.2013, 23:38:26 от pirks »
*

Sergeyy

  • Захожу иногда
  • 154
  • 3 / 0
Полностью согласен. Но если человек мог бы править  default_row.php или *.css, то вопрос как соединить два поля не задавался бы ...  )
Да это понятно!
Но ведь мой вариант самый простой, да и реализация его описана в моём коде выше.
Если spakу это реально нужно...
*

spak

  • Новичок
  • 8
  • 0 / 0
Мне это реально очень важно. Только я не могу понять где править CSS. Я использую шаблон таблицы default. Как я понял за вывод данных в цикле из базы отвечает <?php
         foreach ($group as $this->_row) {
            echo $this->loadTemplate( 'row' );
          }
          ?>

default_rov выглядит так:

<tr id="<?php echo $this->_row->id;?>" class="<?php echo $this->_row->class;?>">
   <?php foreach ($this->headings as $heading=>$label) {   ?>
      <td><?php echo @$this->_row->data->$heading;?></td>
   <?php }?>
</tr>


Таблица CSS выглядит так:

.fabrikForm {
   margin-top: 15px;
}

table.fabrikTable tr.fabrik_calculations td {
   border: 0 !important;
}

.firstPage,.previousPage,.aPage,.nextPage,.lastPage {
   display: inline;
   padding: 3px;
}

table.filtertable {
   width: 50%;
}

.fabrikHover {
   background-color: #ffffff;
}

/** highlight the last row that was clicked */
.fabrikRowClick {
   background-color: #ffffff;
}

/** highlight the loaded row - package only */
.activeRow {
   background-color: #FFFFCC;
}

.emptyDataMessage {
   background-color: #EFE7B8;
   border-color: #EFD859;
   border-width: 2px 0;
   border-style: solid;
   padding: 5px;
   margin: 10px 0;
   font-size: 1em;
   color: #CC0000;
   font-weight: bold;
}

.tablespacer {
   height: 20px;
}

.fabrikButtons {
   text-align: right;
   padding-top: 10px;
}

ul.fabrikRepeatData {
   padding: 0;
   margin: 0;
   list-style: none;
}

ul.fabrikRepeatData li {
   background-image: none;
   padding: 0;
   margin: 0;
}

Так где мне править стиль?




В  FireBug моя таблица выглядит так


<form id="tableform_1" class="fabrikForm" name="fabrikTable" method="post" action="/table/index.php?option=com_fabrik&view=table&tableid=1&calculations=0&resetfilters=0&Itemid=6">
<br style="clear:right">
<div class="tablespacer"></div>
<div class="emptyDataMessage" style="display:none"></div>
<div class="fabrikDataContainer" style="">
<table id="table_1" class="fabrikTable">
<thead>
<tr class="fabrik___heading">
<tr class="fabrik___heading x">
<th class="base_db___fabrik_internal_id_heading ">name_element</th>
<th class="base_db___name_element_heading ">
<a class="fabrikorder" href="#">name_element/a>
</th>
<th class="base_db___name_element_heading ">
<a class="fabrikorder-asc" href="#">name_element/a>
</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading ">
<a class="fabrikorder" href="#">name_element</a>
</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading ">
<a class="fabrikorder" href="#">name_element</a>
</th>
<th class="base_db_db___name_element_heading ">
<a class="fabrikorder" href="#">name_element/a>
</th>
<th class="base_db_db___name_element_heading ">
<a class="base_db" href="#">name_element</a>
</th>
<th class="base_db_db___name_element_heading ">
<a class="fabrikorder" href="#">name_element</a>
</th>
<th class="base_db_db___name_element_heading "> name_element</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading "> name_element</th>
<th class="base_db_db___name_element_heading "> name_element</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading ">name_elevtnt</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___name_element_heading ">name_element</th>
<th class="base_db_db___text_heading ">name_element</th>
</tr>
</thead>
<tbody>
<tr id="table_1_row_1" class="fabrik_row oddRow0 fabrikRowClick">
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1">1</a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1">name_element</a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td></td>
<td></td>
<td>
<ul class="fabrikRepeatData">
<li></li>
</ul>
</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td>
<ul class="fabrikRepeatData">
<li></li>
</ul>
</td>
<td>
<a class="fabrik___rowlink" href="/table/index.php?option=com_fabrik&c=form&view=details&Itemid=6&fabrik=1&rowid=1&fabrik_cursor=0&fabrik_total=4&tableid=1"></a>
</td>
<td></td>
</tr>
</tbody>
</table>


Подскажите, пожалуйста и извините, что туплю.
« Последнее редактирование: 16.01.2013, 23:27:52 от spak »
*

Sergeyy

  • Захожу иногда
  • 154
  • 3 / 0
Используйте шаблон DIV !

Пропишите для каждого элемента класс(это в Fabrik: Элементы - Настройки отображения в таблице - CSS - Cell class),
хотя он и сам приписывается каждому элементу...

Пропишите эти классы в template_css.php шаблона DIV (пример в моём посте выше)

Не забудьте шаблон переименовать, а то при обновлении все труды пропадут!
*

spak

  • Новичок
  • 8
  • 0 / 0
Спасибо, Sergeyy. Попробую так как Вы советуете. Если получиться, напишу.
*

kalinka76

  • Осваиваюсь на форуме
  • 23
  • 0 / 0
  • I`m free
Сваял под свои нужды плагин, который делает ссылки используя данные текущей строки. применил для вызова корректировки товаров VirtueMart. Наверное можно и на два столбца сделать, используя collspan для ячейки. Напишите педробнее что конкретно надо.

Кстати для работы с sql есть плагин авторов fabriksql. Задаеш sql запрос и он выполняется для каждой строки таблицы

В свойствах элемента в настоящее время появился атрибут "Произвольная ссылка". Если ее задать и в ней прописать {элемент} в нужном месте, то получится ссылка в соответствующем столбце (тоже что делает мой плагин, но штатными средствами)
Здравствуйте, несколько лет назад использовала fabrik 2.0, и помню, что, действительно, был такой плагин fabriksql. Сейчас поставила fabrik 3.3.2, плагина такого теперь нет. Подскажите, пожалуйста, каким образом теперь можно вывести значение поля из другой таблицы?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

С чего начать знакомство с Fabrik? (Несколько уроков посвященных компоненту)

Автор xpank

Ответов: 7
Просмотров: 6116
Последний ответ 22.06.2022, 16:07:31
от RomanA
Fabrik кол-во строк в таблице

Автор Vdmit

Ответов: 2
Просмотров: 3575
Последний ответ 24.05.2021, 10:55:53
от Vdmit
Fabrik list plugin - Table Edit

Автор yunoshev

Ответов: 0
Просмотров: 3681
Последний ответ 09.01.2021, 11:22:10
от yunoshev
Может быть Fabrik уже не конструктор форм, а CCK ?

Автор pirks

Ответов: 0
Просмотров: 4597
Последний ответ 19.02.2017, 09:43:48
от pirks
Fabrik для чайников как сделать Hello, world?

Автор AngelikaKS

Ответов: 1
Просмотров: 6352
Последний ответ 15.06.2016, 16:40:43
от Gorilla