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

x1

  • Давно я тут
  • 635
  • 15 / 0
  • Linux — это Windows для бытовой техники
OSMap - Class 'Alledia\OSMap\Factory' not foun
« : 27.11.2021, 13:03:01 »
После обновления OSMap до версии 5.02 на J3.10.3 (заметил не сразу) в админке на хостинге появилась проблема.
При редактировании пункта меню с выводом карты появилось сообщение:
Код
[Joomlashack Extension Support] Joomlashack Framework not found
[OSMap] Joomlashack framework not found
При попытке открыть компонент:
Код
0 Class 'Alledia\OSMap\Factory' not foun
Здесь (https://www.joomlashack.com/blog/tutorials/framework-not-found/) пишут, что проблема связана с доступом к файлам, и видимо это так, поскольку на localhost этой проблемы у меня нет, все работает как надо.
Там же предлагают для лечения использовать FixFramework, но он у меня срабатывает на хостинге с ошибкой -  не может удалить какие то файлы.
Кто то сталкивался с таким?
*

x1

  • Давно я тут
  • 635
  • 15 / 0
  • Linux — это Windows для бытовой техники
Re: OSMap - Class 'Alledia\OSMap\Factory' not foun
« Ответ #1 : 29.11.2021, 12:41:32 »
Решил сам. Выяснилось, что обновление компонента было запущено на хостинге и возникли проблемы с атрибутами файлов - каких именно выяснять не стал. Помогло простое удаление всех папок  OSMap и библиотеки  allediaframework и их копирование поновой по FTP с локалхоста. Простая перезапись поверх не помогает.
*

Doctor Death

  • Захожу иногда
  • 144
  • 1 / 12
Re: OSMap - Class 'Alledia\OSMap\Factory' not foun
« Ответ #2 : 25.01.2025, 10:21:43 »
спасибо, у меня така же проблема после какого обновление
рекомендация помогла
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Русская локализация OSMap Free (обновляется)

Автор Kostelano

Ответов: 1
Просмотров: 2598
Последний ответ 29.03.2025, 07:25:00
от azm1n