Новости Joomla

Загадочный параметр $live_site в configuration.php 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 можно из объекта приложения

protected function doExecute(InputInterface $input, OutputInterface $output): int    {         //...              $live_site = $this->getApplication()->get('live_site');         //...    }
и исходя из этого строить дальнейшую логику.@joomlafeed#joomla #разработка #php #cli

Вышел плагин AllVideos v.7.0 от JoomlaWorks

Вышел плагин AllVideos v.7.0 от JoomlaWorks

Вышел плагин AllVideos v.7.0 от JoomlaWorks.Этот контент-плагин - одно из старейших расширений для Joomla. Его задача - преобразовывать шорт-коды вида

{YOUTUBE}...{/YOUTUBE},
{MP3}parth/to/file.mp3{/MP3} и подобные во встроенные видео или аудио.👩‍💻 v.7.0.0. Что нового?- Добавлена поддержка Youtube Shorts. Просто скопируйте полный url видео и вставьте его внутри тегов
{YOUTUBE}...{/YOUTUBE}.- Поддержка Joomla 5.x без плагина обратной совместимости. PHP 5, PHP 7, PHP 8. - Индексация умным поиском в CLI. В Joomla 5 плагин перестал вызывать ошибку при индексации контента умным поиском через CLI,Заметьте, что этот один и тот же пакет для всех версий Joomla, начиная с 1.5.x и заканчивая 5.x. Технически "под капотом" код плагина по сути не менялся, а для поддержки следующих версий Joomla авторы вставляют "заплатки". Плагин всё ещё использует старую архитектуру файлов и классов Joomla, что, к сожалению, заставляет прибавлять к его описанию слова "пока ещё" - "пока ещё работает".
Страница расширенияGitHub расширенияJoomla Extensions Directory👩‍💻 За ссылку спасибо самому внимательному участнику нашего сообщества - Ринату Кажетову (@rkazhet).@joomlafeed#joomla #расширения

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

igorsuccess

  • Захожу иногда
  • 76
  • 0 / 0
Начал обновлять свои джумлы(у меня их десяток на одном и том же хостинге(с одинаковыми параметрами и конфигурацией). И получилось как в рулетке - некоторые сайты без проблем обновились, некоторый грохнулись с такой вот ошибкой -
Цитировать
1054 - Unknown column 'c.language' in 'where clause'
скриншот -

Начал рыть, думал шаблон виноват, конфликт,(кстати на нескольких сайтах шаблон один и тот же - и на нем одни стали, на других глюк) потому что когда поменял на  родной протостар - джумла на нем работает. Но любые другие шаблоны когда закачиваю-инсталлирую - все так же показывает картинку ДБ вместо сайта на экране. Кто разбиоается в этих полях и таблицах ДБ - что за конфликт такой выборочный? Ведь на одних сайтах обновилось нормально, на других пока пришлось Акебой назад откатывать и до К2 9 не обновлять. Спасибо заранее.
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Для начала включите отладку системы :
Общие настройки > Система > Отладка системы

После этого на той же странице где была ошибка появиться консоль отладки.
В которой будет написано какой файл и какая функция делает этот запрос.
Там будет стек вызовов по нему можно понять, какая функция делает не верный запрос

Выложите сюда код функции, а так же скриншот ошибки.
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

igorsuccess

  • Захожу иногда
  • 76
  • 0 / 0
Для начала включите отладку системы :
Общие настройки > Система > Отладка системы

После этого на той же странице где была ошибка появиться консоль отладки.
В которой будет написано какой файл и какая функция делает этот запрос.
Там будет стек вызовов по нему можно понять, какая функция делает не верный запрос

Выложите сюда код функции, а так же скриншот ошибки.

Спасибо, сейчас попробую вашим способом. А вчера искал по форумам, и приблизился к обозначению проблемы - такой глюк возникает только на сайтах, где настроил мультиязычность. То есть русский и английский к примеру где есть. Временно проблема решается отключением плагина переключателя языка. Но тогдасайт становится одноязычным. Вчера копался на ОпенСервере с копией сайта - менял меню, главные страницы - то заглушка меню была домашней, то нет, то опять та же ошибка. Покамультиязычность не получается. И это после обновления К2 на 2.9 версию. Посмотрю, что за ошибки будут при отладке - покажу скрины.
*

igorsuccess

  • Захожу иногда
  • 76
  • 0 / 0
Включил дебаг - вот что на фронт странице сейчас



Цитировать
1054 - Unknown column 'c.language' in 'where clause'
You may not be able to visit this page because of:

an out-of-date bookmark/favourite
a search engine that has an out-of-date listing for this site
a mistyped address
you have no access to this page
The requested resource was not found.
An error has occurred while processing your request.
Please try one of the following pages:

Home Page
If difficulties persist, please contact the System Administrator of this site and report the error below.

Unknown column 'c.language' in 'where clause'

Call stack
#   Function   Location
1   ()   JROOT\libraries\joomla\database\driver\mysqli.php:661
2   JDatabaseDriverMysqli->execute()   JROOT\libraries\joomla\database\driver.php:1691
3   JDatabaseDriver->loadObjectList()   JROOT\modules\mod_k2_comments\helper.php:92
4   modK2CommentsHelper::getLatestComments()   JROOT\modules\mod_k2_comments\mod_k2_comments.php:49
5   include()   JROOT\libraries\src\Helper\ModuleHelper.php:201
6   Joomla\CMS\Helper\ModuleHelper::renderModule()   
7   call_user_func_array()   JROOT\libraries\src\Cache\Controller\CallbackController.php:173
8   Joomla\CMS\Cache\Controller\CallbackController->get()   JROOT\libraries\src\Helper\ModuleHelper.php:610
9   Joomla\CMS\Helper\ModuleHelper::moduleCache()   JROOT\libraries\src\Document\Renderer\Html\ModuleRenderer.php:95
10   Joomla\CMS\Document\Renderer\Html\ModuleRenderer->render()   JROOT\libraries\src\Document\Renderer\Html\ModulesRenderer.php:47
11   Joomla\CMS\Document\Renderer\Html\ModulesRenderer->render()   JROOT\libraries\src\Document\HtmlDocument.php:491
12   Joomla\CMS\Document\HtmlDocument->getBuffer()   JROOT\libraries\src\Document\HtmlDocument.php:783
13   Joomla\CMS\Document\HtmlDocument->_renderTemplate()   JROOT\libraries\src\Document\HtmlDocument.php:557
14   Joomla\CMS\Document\HtmlDocument->render()   JROOT\libraries\src\Application\CMSApplication.php:1041
15   Joomla\CMS\Application\CMSApplication->render()   JROOT\libraries\src\Application\SiteApplication.php:780
16   Joomla\CMS\Application\SiteApplication->render()   JROOT\libraries\src\Application\CMSApplication.php:201
17   Joomla\CMS\Application\CMSApplication->execute()   JROOT\index.php:49

Я не кодер, если кто объяснит, что тделать дальше и как фиксить, буду признателен.
*

draff

  • Гуру
  • 5801
  • 434 / 7
  • ищу работу
Код
3   JDatabaseDriver->loadObjectList()   JROOT\modules\mod_k2_comments\helper.php:92
4   modK2CommentsHelper::getLatestComments()   JROOT\modules\mod_k2_comments\mod_k2_comments.php:49
А если отключить этот модуль.
*

igorsuccess

  • Захожу иногда
  • 76
  • 0 / 0
Код
3   JDatabaseDriver->loadObjectList()   JROOT\modules\mod_k2_comments\helper.php:92
4   modK2CommentsHelper::getLatestComments()   JROOT\modules\mod_k2_comments\mod_k2_comments.php:49
А если отключить этот модуль.
Спасибо за подсказку - модуль Последние Комментарии отключил - сайт заработал. Но ведь этот модуль нужен - он и для SEO и для инфо нужен. А как пофиксить, то, что произошло при обновлении к2 и чтобы все заработало?
Добавил:
Если выставить как Последние Комментарии - то выпадает ошибка, а если выставить в модуле Топ Комментариев - то не глючит. Кстати - на совершенно новой джумле попробовал настроить мультиязычность, К2-9 и комменты - и ошибка та же. Это значит разработчикам нужно баг показывать, чтобы пофиксили?
« Последнее редактирование: 23.09.2018, 16:29:01 от igorsuccess »
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Теперь все понятно. Небольшой недосмотр.

Должно быть не c.language, а category.language

modules/mod_k2_comments/helper.php ~ 86 строка
Код
$query .= " AND i.language IN ({$languageFilter}) AND c.language IN ({$languageFilter})";
Заменяем на
Код
$query .= " AND i.language IN ({$languageFilter}) AND category.language IN ({$languageFilter})";
« Последнее редактирование: 23.09.2018, 16:57:36 от Septdir »
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
*

igorsuccess

  • Захожу иногда
  • 76
  • 0 / 0
Теперь все понятно. Небольшой недосмотр.

Должно быть не c.language, а category.language

modules/mod_k2_comments/helper.php ~ 86 строка
Код
$query .= " AND i.language IN ({$languageFilter}) AND c.language IN ({$languageFilter})";
Заменяем на
Код
$query .= " AND i.language IN ({$languageFilter}) AND category.language IN ({$languageFilter})";
Спасибо огромное - ЭТОТ БАГ РЕШЕН! При помощи замены, которую вы подсказали. Причем проверил и на новой Joomla, и на перенесенном сайте. Удачи в бизнесе иподарков от Вселенной! :D *DRINK* *DRINK* *DRINK*
*

Septdir

  • Живу я здесь
  • 3370
  • 168 / 4
Исправление включили в репозиторий

https://github.com/getk2/k2/commit/145d7b0ab9580546416eccaf8c8c81739f8e4456
Не можете справиться с задачей сами пишите, решу ее за вас, не бесплатно*.
*Интересная задача, Деньги или Бартер. Натурой не беру!
CodersRank | Контакты | Мой GitHub | Workshop
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Проблема с SP Page Buildier

Автор Aleksey1982

Ответов: 20
Просмотров: 4983
Последний ответ 10.11.2023, 20:13:53
от Шмайсер
Прошу помощи. Ошибка при обновлении на Joomla 4

Автор wmsonic

Ответов: 1
Просмотров: 2041
Последний ответ 29.10.2023, 22:07:23
от Kukush
Проблема с почтой сайта на Joomla

Автор dima567

Ответов: 1
Просмотров: 1296
Последний ответ 16.09.2023, 09:44:41
от sivers
Выходит ошибка в админской панели

Автор daymarus

Ответов: 0
Просмотров: 1876
Последний ответ 10.08.2023, 12:43:43
от daymarus
При обновлении ошибка 403 Forbidden Request forbidden by administrative rules

Автор THeCMeX

Ответов: 18
Просмотров: 3770
Последний ответ 14.07.2023, 17:13:19
от art22