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

Garum

  • Давно я тут
  • 654
  • 47 / 0
  • Акула пера
Более легкое решение того как скрыть от пользователя иконки редактирования, удаления и опубликования картинок в его галерее. Это решение для тех, кто не использовал решение на верхнем посте. Данное решение от верхнего отличается тем, что для пользователя остается ссылка на "Моя галерея", куда он сможет зайти и посмотреть свои фотки. Повторяю данное решение только для пользователей, т.е. для группы Зарегистрированный, для других групп не работает.
Идем в папку Идем в папку \components\com_joomgallery\helpers находим файл helper.php находим строку:
Код
     {
          $params->set('show_mygal_no_access', 1);
        }
      }
    }
После пишем код:
Код
if(!$params->get('disable_global_info') && $config->get('jg_userspace') == 1)
    {
      if(   (($config->get('jg_showuserpanel') == 1) && ($user->get('aid') > 0))
         || (($config->get('jg_showuserpanel') > 1 ) && ($user->get('aid') == 1))
         || ($config->get('jg_showuserpanel') == 3)
        )
      {
        if($user->get('aid')!= 1)
        {
          $params->set('show_mygall', 1);
        }
        else
        {
          $params->set('show_mygall_no_access', 1);
        }
      }
    }
Далее идем в Идем в папку components\com_joomgallery\views\userpanel\tmpl ищем файл default.php в нем ищем строку:
Код
<a href="<?php echo JRoute::_('index.php?view=edit&id='.$row->id.$this->slimitstart); ?>">
            <?php echo JHTML::_('joomgallery.icon', 'edit.png', 'JGS_COMMON_EDIT'); ?></a>
        </div>
И заменим его на:
Код
       <?php 
      if($this->params->get('show_mygall')): ?>
        <a href="<?php echo JRoute::_('index.php?view=edit&id='.$row->id.$this->slimitstart); ?>">
            <?php echo JHTML::_('joomgallery.icon', 'edit.png', 'JGS_COMMON_EDIT'); ?></a></div>
     <?php endif;
      if($this->params->get('show_mygall_no_access')): ?>
         <?php echo JHTML::_('joomgallery.icon', 'download_gr.png', 'JGS_COMMON_EDIT'); ?>
        </div>
           <?php   endif; ?>
Здесь иконку Редактировать сделали не кликабельной.

Далее в этом же файле находим строку:
Код
<a href="javascript:if(confirm('<?php echo JText::_('JGS_COMMON_ALERT_SURE_DELETE_SELECTED_ITEM', true); ?>')){ location.href='<?php echo JRoute::_('index.php?task=delete&id='.$row->id.$this->slimitstart, false);?>';}">
            <?php echo JHTML::_('joomgallery.icon', 'edit_trash.png', 'JGS_COMMON_DELETE'); ?></a>
        </div>
Заменим его на:
Код
<?php 
      if($this->params->get('show_mygall')): ?>
        <a href="javascript:if(confirm('<?php echo JText::_('JGS_COMMON_ALERT_SURE_DELETE_SELECTED_ITEM', true); ?>')){ location.href='<?php echo JRoute::_('index.php?task=delete&id='.$row->id.$this->slimitstart, false);?>';}">
            <?php echo JHTML::_('joomgallery.icon', 'edit_trash.png', 'JGS_COMMON_DELETE'); ?></a></div>
       <?php endif;
      if($this->params->get('show_mygall_no_access')): ?>
         <?php echo JHTML::_('joomgallery.icon', 'download_gr.png', 'JGS_COMMON_DELETE'); ?>
          </div>        
          <?php   endif; ?>
Здесь иконку Удалить сделали не кликабельной.
Иконка download_gr.png в папке components\com_joomgallery\assets\images дана только для примера, вам же следует найти подходящую иконку для редактирования и удаления или преобразовать их в серый цвет и засунуть их в эту же папку, но иконку download_gr.png ЗАМЕНЯТЬ НЕ СЛЕДУЕТ.

Далее ищем:
Код
         <a href="<?php echo JRoute::_('index.php?task=publishimage&id='.$row->id.$this->slimitstart); ?>"<?php echo JHTML::_('joomgallery.tip', $p_text, $p_title, true, false); ?>>
            <?php echo JHTML::_('joomgallery.icon', $p_img.'.png', $p_img); ?></a><?php
        if($row->published && $row->hidden):
          $h_title = JText::_('JGS_COMMON_HIDDEN_ASTERISK');
          $h_text  = JText::_('JGS_COMMON_PUBLISHED_BUT_HIDDEN');
          echo '<span'.JHTML::_('joomgallery.tip', $h_text, $h_title, true, false).'>'.JText::_('JGS_COMMON_HIDDEN_ASTERISK').'</span>';
          $display_hidden_asterisk = true;
        endif; ?>
        </div>
<?php   if($this->_config->get('jg_approve')):
          $a_img = 'cross';
          if($row->approved):
            $a_img = 'tick';
          endif; ?>
        <div class="jg_up_eappr">
          <?php echo JHTML::_('joomgallery.icon', $a_img.'.png', $a_img); ?>
        </div>
<?php   endif; ?>
      </div>
    </div>
И заменим его на:
Код
         <?php 
      if($this->params->get('show_mygall')): ?>
        <a href="<?php echo JRoute::_('index.php?task=publishimage&id='.$row->id.$this->slimitstart); ?>"<?php echo JHTML::_('joomgallery.tip', $p_text, $p_title, true, false); ?>>
            <?php echo JHTML::_('joomgallery.icon', $p_img.'.png', $p_img); ?></a>
        <?php endif;
      if($this->params->get('show_mygall_no_access')): ?>
              <?php echo JHTML::_('joomgallery.icon', $p_img.'.png', $p_img); ?></a><?php
        if($row->published && $row->hidden):
          $h_title = JText::_('JGS_COMMON_HIDDEN_ASTERISK');
          $h_text  = JText::_('JGS_COMMON_PUBLISHED_BUT_HIDDEN');
          echo '<span'.JHTML::_('joomgallery.tip', $h_text, $h_title, true, false).'>'.JText::_('JGS_COMMON_HIDDEN_ASTERISK').'</span>';
          $display_hidden_asterisk = true;
        endif; ?>
       <?php endif; ?> </div>
   <?php   if($this->_config->get('jg_approve')):
          $a_img = 'cross';
          if($row->approved):
            $a_img = 'tick';
          endif; ?>
        <div class="jg_up_eappr">
          <?php echo JHTML::_('joomgallery.icon', $a_img.'.png', $a_img); ?>
        </div>
<?php   endif; ?>
      </div>
    </div>
Здесь иконку Опубликовать сделали не кликабельной.

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

Примерно также можно сделать для детального вида и категорий, чтобы иконки были некликабельны или вообще не показывались пользователям.
« Последнее редактирование: 06.01.2012, 19:29:20 от Garum »
http://izans.ru/oboi?view=category&catid=6 фото самых красивых девушек на рабочий стол
*

Garum

  • Давно я тут
  • 654
  • 47 / 0
  • Акула пера
В этом посте http://joomlaforum.ru/index.php/topic,165721.msg1028413.html#msg1028413, что я писал выше, возникает ошибка в категории, если картинок больше одного. В связи с этим я рекомендую заменить все коды (детальный вид можете оставить, он работает) в посте на следующие.
Для изменения в детальном просмотре фоток идем в components\com_joomgallery\views\detail\tmpl находим файл  default.php, и вней ищем строку:
Код
<?php echo $this->image->hits; ?>  
После пишем код:
Код
<?php
$count = $this->image->hits;
 $users = array('раз', 'раз', 'раза');
$index = $count % 100;
if ($index >=11 && $index <= 14) $index = 0;
else $index = ($index %= 10) < 5 ? ($index > 2 ? 2 : $index): 0;
echo $users[$index];   ?>

Так же изменим в категории с мини картинками. Идем в папку components\com_joomgallery\views\category\tmpl ищем файл default_images.php, найдем строку:
 
Код
<?php echo JText::sprintf('JGS_COMMON_HITS_VAR', $row->hits); ?>

после него добавим строку:
Код
<?php
$count=$row->hits;
 $users = array('раз', 'раз', 'раза');
$index = $count % 100;
if ($index >=11 && $index <= 14) $index = 0;
else $index = ($index %= 10) < 5 ? ($index > 2 ? 2 : $index): 0;
echo $users[$index];   ?>
Проверяйте на работоспособность.

« Последнее редактирование: 06.01.2012, 13:58:44 от Garum »
http://izans.ru/oboi?view=category&catid=6 фото самых красивых девушек на рабочий стол
*

Garum

  • Давно я тут
  • 654
  • 47 / 0
  • Акула пера
Если у вас оценки в тестовом виде и написано к примеру так: 3,00 (5 оценки), то я предалагаю слово оценки склонять в зависимости от цифры, т.е. правильнее было бы так:  3,00 (5 оценок). Для этого идем в папку components\com_joomgallery\helpers\html ищем файл JoomGallery.php и сразу после строки:
Код
 // Standard rating output as text
пишем код:
Код
$count=$image->imgvotes;
 $rate = array('оценок', 'оценка', 'оценки');
$index = $count % 100;
if ($index >=11 && $index <= 14) $index = 0;
else $index = ($index %= 10) < 5 ? ($index > 2 ? 2 : $index): 0;
Затем заменяем строку:
Код
$html = $rating.' ('.$image->imgvotes.' '.  JText::_('JGS_COMMON_ONE_VOTE'). ')';

на:
Код
 $html = $rating.' ('.$image->imgvotes.' '. $rate[$index].')';
и еще одну строку:
Код
$html = $rating.' ('.$image->imgvotes.' '.  JText::_('JGS_COMMON_VOTES'). ')';
Заменим на:
Код
$html = $rating.' ('.$image->imgvotes.' '. $rate[$index].')';
Теперь слово оценки будет склоняться в зависимости от количества оценок
http://izans.ru/oboi?view=category&catid=6 фото самых красивых девушек на рабочий стол
*

Garum

  • Давно я тут
  • 654
  • 47 / 0
  • Акула пера
По умолчанию поиск в галере не ищет ключевые слова картинок. Чтобы это исправить надо пойти в папку components\com_joomgallery\models и зайти в файл search.php, затем находим код:
Код
  OR a.imgtitle       LIKE '%$searchstring%'
И после пишем:
Код
OR a.metakey       LIKE '%$searchstring%'
Теперь поиск в галерее ищет и ключевые слова.

Если хотите можете также добавить код:
Код
OR a.metadesc      LIKE '%$searchstring%'
Теперь поиск заденет еще и мета описание картинки.
С вас много плюсов!
http://izans.ru/oboi?view=category&catid=6 фото самых красивых девушек на рабочий стол
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться