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

antarey

  • Захожу иногда
  • 168
  • 1 / 0
MySQL trigger
« : 14.12.2020, 10:24:59 »
При установке компонента нужно создать триггер для таблицы. Перечитал подобные вопросы - результата 0
Вот скрипт
Код
DROP TRIGGER IF EXISTS `#__petition_number`;
CREATE TRIGGER `#__petition_number` BEFORE INSERT ON `#__aepetitions` FOR EACH ROW BEGIN declare auto_increment_id int default 0; select auto_increment INTO auto_increment_id from information_schema.tables where table_name = '#__aepetitions' and table_schema = database(); SET new.title = CONCAT('EP-',auto_increment_id,'-',DATE_FORMAT(CURDATE(),'%d%m%y')); SET new.alias = CONCAT('EP-',auto_increment_id,'-',DATE_FORMAT(CURDATE(),'%d%m%y')); END;
В чем проблема?
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Joomla 3.10.12 и MySQL 8

Автор designer71

Ответов: 0
Просмотров: 803
Последний ответ 19.10.2023, 11:25:18
от designer71
Анализ запросов к MySQL

Автор darkghost

Ответов: 4
Просмотров: 636
Последний ответ 26.10.2021, 10:13:15
от wishlight
MySQL: количество просмотров материала

Автор dron

Ответов: 9
Просмотров: 857
Последний ответ 27.09.2020, 11:26:06
от dron
[РЕШЕНО] MySQL запрос на получение данных из доп. полей и статей

Автор effrit

Ответов: 11
Просмотров: 855
Последний ответ 20.09.2020, 20:07:40
от effrit
Удаляется БД из MySQL после перезагрузки ОС

Автор easy

Ответов: 0
Просмотров: 580
Последний ответ 04.12.2019, 06:57:05
от easy