Новости Joomla

Joomla 6: Автоматические обновления ядра в Joomla

Joomla 6: Автоматические обновления ядра в Joomla

👩‍💻 Joomla 6: Автоматические обновления ядра в Joomla. В октябрьском номере официального журнала Joomla - Joomla Community Magazine вышла статья David Jardin, где рассказывается о внедрении функционала автоматического обновления ядра Joomla.❓Почему сейчас? Joomla же жила как-то 20 лет без автоматических обновлений?Это оказалась самая востребованная за последнее время от пользователей Joomla функция. Но, основная причина внедрения - проблемы безопасности. Всякий раз, когда в новой версии Joomla устраняется уязвимость, злоумышленники начинают анализировать код, чтобы выяснить, какая именно уязвимость была исправлена. И как только они это выясняют - начинается разработка автоматизированных скриптов для взлома как можно большего количества сайтов. Затем доступы к автоматически взломанным сайтам продаются в профильных чатах и ресурсах "пачками" по несколько сотен тысяч или миллионов сайтов. Ваш сайт могли взломать несколько лет назад, но воспользоваться уязвимостью могут не сразу, а тогда, когда у злоумышленников возникнет необходимость. И только после этого вы может быть узнаете об этом.Анализ патча, понимание проблемы и разработка скрипта требуют времени. И если владелец сайта не обновит его до истечения этого срока, сайт может быть взломан. А хакеры действуют быстро! Для критических, легко эксплуатируемых уязвимостей речь идёт о временном окне в 10–12 часов — и этого времени явно недостаточно, чтобы все успели обновить свои сайты.Здесь выходят на первый план автоматизированные обновления: проект Joomla теперь может активно устанавливать обновления (и, следовательно, исправления безопасности) на сайты, чтобы гарантировать, что сайты действительно обновляются вовремя.🕘 От первых идей до реализации прошло 5 лет. И здесь можно вспомнить, как в Joomla 5.1 внедрили TUF - The Update Framework, позволяющий устанавливать защищённое соединение между сайтом и сервером обновлений и исключает возможность supply chain attack (атаки на цепочку поставок).Об особенностях реализации и требованиях к сайту читаем подробнее в статье на JCM.@joomlafeed#joomla #secutiry #jcm

Первый выпуск журнала NorrNext в честь 20-й годовщины Joomla™

Первый выпуск журнала NorrNext в честь 20-й годовщины Joomla™

Первый выпуск журнала NorrNext в честь 20-й годовщины Joomla™. Интервью с волонтёрами 🎈Ну что, друзья, вот и настал этот долгожданный момент. Мы выпустили первое издание собственного журнала под эгидой NorrNext, который включает в себя интервью с видными деятелями сообщества из разных стран и континентов.Общий нарратив: показать, что нас объединяет (Joomla) и узнать больше о людях, которые вносят свой вклад в развитие платформы в своих сообществах. 20 лет — это много. Давайте же узнаем о коллегах 🎁 Первый цикл включает такие страны, как Австрия, Испания, Латвия, Россия, Румыния, Тайланд, Черногория, Чехия.⚙️ С кем интервью: ✔️ Владимир Елисеев 🇷🇺✔️ Дмитрий Рекун 🇱🇻✔️ Дмитрий Цымбал 🇷🇺✔️ Евгений Сивоконь 🇷🇺 ✔️ Сергей Толкачёв 🇷🇺✔️ Dénes Székely 🇷🇴✔️ Jan Pavelka 🇨🇿✔️ Miljan Vujosevic 🇲🇪✔️ Sergio Iglesias 🇪🇸✔️ Sigrid Gramlinger 🇦🇹✔️ Pisan Chueatchatchai 🇹🇭‼️ Новые интервью будут добавляться до конца декабря 2025. Заходите по ссылке время от времени💡👉 Читать далее

0 Пользователей и 1 Гость просматривают эту тему.
  • 6 Ответов
  • 1237 Просмотров
*

Gerostrat

  • Захожу иногда
  • 374
  • 2 / 0
  • Свидетель чайной ложки
Я использую модуль, чтобы выводить в статье ссылки на статьи, которые схожи за тематикой, как бы создавая перелинковку между статьями и образуя своеобразный "семантический кокон", как его называют. Полезно и логично для SEO.

Модуль подбирает 15 статей, я из них вытягиваю эти ссылки по 1-й и вставляю через каждые 10 абзацев в виде "Читайте также". Очень даже неплохо получается, если правильно статьям присваивать метки.

Есть разный способ получения этого списка. Брать статьи только у которых совпадают ВСЕ метки, или только половина, или хотя бы одна.
Так же и вывод - либо в случайном порядке, либо по количеству совпадений меток у материалов, либо же комбинация этих двух.

Если поставить в случайном порядке – ссылки будут каждый раз выводиться разные на одной и той же странице. Т.е. обновил - ссылки поменялись. А если поставить по количеству совпадений – ссылки не будут меняться, но... всех статей. Т.е. в любой статье с одинаковыми метками ссылки будут сверху вниз по статье идти одни и те же. Что тоже не прикольно.

В чём вопрос. Как бы его так сделать, чтобы модуль работал по принчипу, что ссылки подбираются не случайно, но при этом для каждой статьи они брались только из статей, которые были опубликованы ДО этой статьи.

Т.е. есть статьи А1, А2, А3,... А20. Публиковались они в таком же порядке. У всех у них одинаковые метки.

Как сделать, чтобы в статье А4 показывались только ссылки на статьи А3, А2 и А1. В статье А10, только А9, А8 и ниже (более раннеопубликованные).

 ^-^
*

sivers

  • Живу я здесь
  • 2593
  • 360 / 0
Взять ИД текущего материала, по нему вытянуть дату публикации материала. Далее, либо добавить условие в запрос модуля, либо добавить проверку по дате в цикл вывода материалов.

Если сможете поправить запрос модуля, то можно и не вытаскивать дату на первом этапе, а вставить подзапрос.
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Gerostrat

  • Захожу иногда
  • 374
  • 2 / 0
  • Свидетель чайной ложки
Я так понимаю, что если делать это в запросе модуля, то это где-то тут

Код
$db         = JFactory::getDbo();
$user       = JFactory::getUser();
$groups     = implode(',', $user->getAuthorisedViewLevels());
$matchtype  = $params->get('matchtype', 'all');
$maximum    = $params->get('maximum', 5);
$ordering   = $params->get('ordering', 'count');
$tagsHelper = new JHelperTags;
$prefix     = $option . '.' . $view;
$id         = $app->input->getInt('id');
$now        = JFactory::getDate()->toSql();
$nullDate   = $db->getNullDate();

$tagsToMatch = $tagsHelper->getTagIds($id, $prefix);

if (!$tagsToMatch || $tagsToMatch === null)
{
return array();
}

$tagCount = substr_count($tagsToMatch, ',') + 1;

$query = $db->getQuery(true)
->select(
array(
$db->quoteName('m.core_content_id'),
$db->quoteName('m.content_item_id'),
$db->quoteName('m.type_alias'),
'COUNT( ' . $db->quoteName('tag_id'). ') AS ' . $db->quoteName('count'),
$db->quoteName('ct.router'),
$db->quoteName('cc.core_title'),
$db->quoteName('cc.core_alias'),
$db->quoteName('cc.core_catid'),
$db->quoteName('cc.core_language'),
$db->quoteName('cc.core_params'),
)
);

$query->from($db->quoteName('#__contentitem_tag_map', 'm'));

$query->join('INNER', $db->quoteName('#__tags', 't'). ' ON m.tag_id = t.id')
->join('INNER', $db->quoteName('#__ucm_content', 'cc'). ' ON m.core_content_id = cc.core_content_id')
->join('INNER', $db->quoteName('#__content_types', 'ct'). ' ON m.type_alias = ct.type_alias');

$query->where($db->quoteName('m.tag_id'). ' IN (' . $tagsToMatch . ')');
$query->where('t.access IN (' . $groups . ')');
$query->where('(cc.core_access IN (' . $groups . ') OR cc.core_access = 0)');

// Don't show current item
$query->where('(' . $db->quoteName('m.content_item_id'). ' <> ' . $id
. ' OR ' . $db->quoteName('m.type_alias'). ' <> ' . $db->quote($prefix). ')'
);

// Only return published tags
$query->where($db->quoteName('cc.core_state'). ' = 1 ')
->where('(' . $db->quoteName('cc.core_publish_up'). '=' . $db->quote($nullDate). ' OR '
. $db->quoteName('cc.core_publish_up'). '<=' . $db->quote($now). ')'
)
->where('(' . $db->quoteName('cc.core_publish_down'). '=' . $db->quote($nullDate). ' OR '
. $db->quoteName('cc.core_publish_down'). '>=' . $db->quote($now). ')'
);

Не поможете з правкой запроса, пожалуйтса?
*

sivers

  • Живу я здесь
  • 2593
  • 360 / 0
Попробуйте заменить это:
Код
. $db->quoteName('cc.core_publish_up'). '<=' . $db->quote($now). ')'

на это:
Код
. $db->quoteName('cc.core_publish_up'). '<=(SELECT `core_publish_up` FROM `#__ucm_content` WHERE `core_content_id` = cc.core_content_id AND `core_content_item_id` = ' . $db->quote($id). '))'

тестить мне это не на чем, так что работоспособность не проверял
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
*

Gerostrat

  • Захожу иногда
  • 374
  • 2 / 0
  • Свидетель чайной ложки
Хм. Так вообще ничего не отображается...
*

Gerostrat

  • Захожу иногда
  • 374
  • 2 / 0
  • Свидетель чайной ложки
Если предположить, что более поздняя дата публикации подразумевает у документа больший ID. Если публикации на сайте идут подряд.

Тогда в этом коде можно было бы просто "<>" поменять на "<". Что скажете?
Код
// Don't show current item
$query->where('(' . $db->quoteName('m.content_item_id'). ' <> ' . $id
. ' OR ' . $db->quoteName('m.type_alias'). ' <> ' . $db->quote($prefix). ')'
);

*

sivers

  • Живу я здесь
  • 2593
  • 360 / 0
иногда очередность публикации может не совпадать с очередностью ИД. Если вы создаете материалы с отложенной публикацией, например.

кроме замены знака надо еще удалить строку с ' OR ' . иначе никакого эффекта не будет

Код
// Don't show current item
$query->where('(' . $db->quoteName('m.content_item_id'). ' < ' . $id
. ')'
);
На связи в telegram @sivers
sivers @ inbox . ru
https://sivers.su/
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывести модуль в модуле

Автор jimka

Ответов: 2
Просмотров: 1581
Последний ответ 18.04.2025, 15:39:36
от fbr
Radical Multi Field создаёт папку для каждой статьи

Автор Missile

Ответов: 7
Просмотров: 1163
Последний ответ 25.11.2024, 15:22:12
от Missile
Как установить header Cache-Control только для одной страницы по URL?

Автор Slava77

Ответов: 0
Просмотров: 970
Последний ответ 23.03.2024, 00:16:36
от Slava77
Как вставить модуль в код нужной страницы php?

Автор zvi

Ответов: 9
Просмотров: 4968
Последний ответ 21.02.2024, 11:03:08
от saynez
Убрать из модуля новостей ссылку на статью, на которой выводится модуль

Автор zeus07

Ответов: 3
Просмотров: 1433
Последний ответ 08.11.2023, 21:17:26
от GrayAn