Новости 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 Ответов
  • 1389 Просмотров
*

bokus

  • Осваиваюсь на форуме
  • 12
  • 1 / 0
Здравствуйте делаю свой компонент для внутреннего сайта организации и не могу осмыслить следующую проблему, есть некая таблица SQL запросов к ораклячей базе
Код
CREATE TABLE #__rosreestr_sqlrequests (
  id int(11) NOT NULL AUTO_INCREMENT,
  asset_id int(10) unsigned NOT NULL DEFAULT '0',
  title varchar(255) DEFAULT NULL COMMENT 'Название запроса',
  sqlreq mediumtext NOT NULL COMMENT 'SQL запрос',
    ...
    ...

Данные во front-end вытаскиваю
Код
<field
name="idsql"
type="sql"
multiple="false"
size="1"
label="SQL запрос"
query="SELECT * FROM #__rosreestr_sqlrequests order by 2"
key_field="id"
value_field="title"
required="true"
onchange = "$('#jform_gosqlreq').val('0'); submit()"
>
<option value="" disabled="true">-= Выберите SQL запрос =-</option>
</field>


также для таблицы в back-end задано право на запуск


проблема в том как вывести список из базы с учетом права на запуск, т.е. если нет права то в список они не попадают.
« Последнее редактирование: 30.10.2012, 13:30:47 от bokus »
*

bokus

  • Осваиваюсь на форуме
  • 12
  • 1 / 0
Re: Использование ACL во front-end
« Ответ #1 : 26.10.2012, 10:17:01 »
Решено! Нашел решение данного вопроса, делюсь со всеми кто столкнется с данной ситуацией

после сёрфинга по инету наткнулся на статью http://docs.joomla.org/Creating_a_custom_form_field_type и сделал следующие действия

1) скопировал и переименовал необходимый тип поля (т.е. sql) из libraries\joomla\form\fields\sql.php в свой компонент \components\com_rosreestr\models\fields\SQLRunSQL.php

2) в скопированном файле добавил условие If (JFactory::getUser()->authorise('rosreestr.runsqlreq', 'com_rosreestr.sqlrequest.' . $item->id)) т.е. получилось

Код
....
if (!empty($items)){
foreach ($items as $item){
If (JFactory::getUser()->authorise('rosreestr.runsqlreq', 'com_rosreestr.sqlrequest.' . $item->id)) {
if ($translate == true)
$options[] = JHtml::_('select.option', $item->$key, JText::_($item->$value));
else
$options[] = JHtml::_('select.option', $item->$key, $item->$value);
}
}
}
....


3) в описании формы переименовал тип поля
Код
<field
name="idsql"
type="sqlrunsql"
multiple="false"
....
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Использование ACL во front-end
« Ответ #2 : 26.10.2012, 11:43:44 »
Вот, пример хорошего пользователя - поделился решением, причем полезным. Плюсанул ;)
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

[Решено] title category

Автор spirit1086

Ответов: 4
Просмотров: 1412
Последний ответ 17.08.2015, 16:42:04
от spirit1086
[Решено] Программная регистрация пользователя во внешней бд

Автор DimkaJack

Ответов: 8
Просмотров: 1991
Последний ответ 06.08.2014, 18:32:39
от DimkaJack
[Решено] Вставить визуальный редактор в модуль

Автор mat.konstantin

Ответов: 6
Просмотров: 4045
Последний ответ 10.03.2014, 14:33:05
от mat.konstantin
Использование иконок на FrontEnd

Автор Xiss

Ответов: 6
Просмотров: 1374
Последний ответ 16.02.2014, 00:57:18
от Xiss
[Решено] Как разобрать JURI::current() при помощи route.php?

Автор platonische

Ответов: 17
Просмотров: 3386
Последний ответ 10.01.2014, 20:55:19
от Arkadiy