Новости Joomla

Загадочный параметр $live_site в configuration.php Joomla

Загадочный параметр $live_site в configuration.php Joomla

Давным-давно, когда Joomla ещё была маленькой, в неё внедрили параметр $live_site. В ней хранился домен текущего сайта на случай, если Joomla не могла его определить из-за неверной настройки сервера. Нужно это было для разных SEO-компонентов, для использования редиректов и т.д.

Со временем для работы собственно сайта этот параметр перестал быть нужным. Уже в начале 2010-х стали встречаться рекомендации оставлять этот параметр пустым, дабы оный не привёл к лишним проблемам и путанице. Тем более, в web-админке нет места, где его можно указать или посмотреть его значение. Только в configuration.php, а туда смотрят не часто.

Однако, параметр всё же остался в ядре Joomla. Зачем он нужен? А нужен он в 2-х случаях:

  • для работы класса Joomla\CMS\Uri\Uri, который часто используется в коде Joomla для работы методов
    Uri::root() и
    Uri::base(), а значит может влиять и на работу в том числе ajax-скриптов.
  • для работы Joomla в CLI - командной строке сервера. В случае если вы используете в вашем CLI-плагине методы опять-таки класса Uri, то CLI ничего не знает о текущем домене, так как запускается вне web-сервера.

Поэтому домен нужно указывать принудительно. Либо с помощью параметра командной строки

--live-site, например,
—live-site=https://site.ru/. Со слешем на конце, иначе в CLI адрес сайта станет
https://site.rujoomla.php.Либо в параметре
$live_site в файле configuration.php, так как
CliApplication берёт настройку оттуда, если параметр команды не указан или пуст.

⚠️ Иначе в качестве хоста и url класса Uri будет установлено https://joomla.invalid/set/by/console/application. В самом же коде команды получить параметр

$live_site можно из объекта приложения

<?php protected function doExecute(InputInterface $input, OutputInterface $output): int { //... $live_site = $this->getApplication()->get('live_site'); //... }

и исходя из этого строить дальнейшую логику.

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

androv77

  • Захожу иногда
  • 80
  • 5 / 0
Есть фильрация блога категорий.
Организована с помощью AJAX, чтобы странцу не перезагружать каждый раз.
Но при каждой фильтрации появляются блоки <div id="system-message-container"></div> и <h2 class="subheading-category"></h2> и весь контейнер с блоками "ломается".
Стоит страницу обновить как эти блоки скрываются до следующей фильтарции AJAX.
Убирать их с помощью display:none считаю неверным и хотел бы найти правильное решение, но не нахожу.
<jdoc:include type="message" /> не влияет я так понял.
*

androv77

  • Захожу иногда
  • 80
  • 5 / 0
Нашел файл jlcomponent_ajax.php в папке system
В нем есть строчки:
<jdoc:include type="message" />
<jdoc:include type="component" />
Первая при удалении решает проблему (убирает system-message-container).
Но вторая строчка после AJAX фильтрации создает блог в блоге.
А если и ее удалить то после фильтрации весь контейнер component пропадает, а в нем весть контент на странице.
Сейчас после филтрации блог выглядит так:
<section class="blogvrach">
    <section class="blogvrach">
    </section>
</section>

То есть блог в блоге получается.
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Стоит ли ставить плагин rel="canonical" на Joomla 3

Автор azm1n

Ответов: 2
Просмотров: 700
Последний ответ 09.05.2025, 12:39:18
от azm1n
reCapcha во всплывающем окне - "Ошибка защиты от спама"

Автор Dannik

Ответов: 12
Просмотров: 2395
Последний ответ 14.09.2023, 18:59:24
от all_zer
Как отменить system-massage?

Автор olderman

Ответов: 0
Просмотров: 482
Последний ответ 28.06.2023, 11:34:33
от olderman
Как отменить system-massage?

Автор olderman

Ответов: 0
Просмотров: 479
Последний ответ 28.06.2023, 11:33:59
от olderman
Получить текущий номер страницы плагина "Разрыв страницы" (pagebreak)

Автор sertlan

Ответов: 1
Просмотров: 753
Последний ответ 12.06.2023, 18:14:09
от sertlan