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

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Задача для экспертов в MySQL. )

у нас есть  _users,  _user_usergroup_map, _usergroups ( надо ли? )

Это мы можем  -
SELECT  _users.username FROM  _users,  _user_usergroup_map
        WHERE  _users.id =  _user_usergroup_map.user_id
        AND  _user_usergroup_map.group_id = 7

Получаем  список пользователей входящих в группу с id = 7 , т.е. Administrator.

Есть переменная $user_id - текущий пользователь.

Что надо? Сущий пустяк! )

IF текущий пользователь ($user_id) входит в группу Administrator THEN вывести всех из _users
ELSE  вывести только пользователей входящих в группу Administrator

Где зарыта собака? )
Все нужно сделать в одном запросе, без php. )
Одна переменная в одном запросе.
Реально ли это?

Если реально,  называйте стоимость работ! )
« Последнее редактирование: 20.12.2016, 00:17:56 от pirks »
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #1 : 20.12.2016, 06:38:41 »
двумя запросами через проверку:
if (JFactory::getUser($user_id)->gid != 7)
{
    // тут запрос на полный список, без уссловий
} else {
   // тут запрос только админов (выше вроде корректно)
}
« Последнее редактирование: 20.12.2016, 06:47:26 от AlekVolsk »
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #2 : 20.12.2016, 08:42:25 »
AlekVolsk, спасибо, но это я понимаю. Так и сделал бы. )
Если бы не одно условие - в одном запросе выяснить, какой группе принадлежит текущий user и сделать соответствующий select.
Тут надо использовать вложенные SELECT, CASE, IF и т.д.
А может быть и переменные MySQL.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #3 : 20.12.2016, 09:13:10 »
так не получится: вы можете использовать вложенный селект как условие выборки, но вы не можете отказаться от условия вообще, если результат вложенного селекта не соответствует требуемому условию

как вариант, можно попробовать использовать хранимые процедуры, но это опять же - уже не один запрос
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #4 : 20.12.2016, 22:27:31 »
Меня все таки гложат сомнения, что это нельзя сделать в одном запросе. )
В этот раз я выкрутился, проблему решил, но такая задача может возникнуть   опять и хотелось бы понять - реализуемо это или нет.
Как-то давно решал подобное с помощью алиасов. )
Но для для сложных SQL запросов нужно иметь светлую и пустую голову. )
На днях все-таки попробую . )
 
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #5 : 20.12.2016, 23:40:19 »
первое что пришло в голову, вариант с IN и IF

Код: sql
SELECT * FROM `#__users` WHERE id IN (SELECT user_id FROM `#__user_usergroup_map` WHERE group_id=7) OR id > IF((SELECT count(*) FROM `#__user_usergroup_map` WHERE group_id=7 AND user_id= $user_id ) > 0, 0, 2147483647)

P.S. или надо было сначала озвучить стоимость? :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #6 : 21.12.2016, 09:17:47 »
P.S. или надо было сначала озвучить стоимость? :)

Сейчас проверю!

P.S.  $2? Не? ))
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #7 : 22.12.2016, 14:01:11 »
запрос правильный? :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #8 : 22.12.2016, 14:09:56 »
запрос правильный? :)
Пока  с наскоку не пошел. ) Но тут еще может проявляться кривость моих рук. Поэтому пока ответа на вопрос нет. )
В HeiDiSQL не тестировался?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #9 : 22.12.2016, 14:20:18 »
нет. в phpMyAdmin тестировался
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #10 : 23.12.2016, 21:14:25 »
dmitry_stas Спасибо!
Все работает!  :D
Яндекс- кошелек давай - $2 твои!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #11 : 23.12.2016, 21:38:27 »
ахаха :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

pirks

  • Захожу иногда
  • 136
  • 8 / 0
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #12 : 23.12.2016, 21:56:52 »
Это  круто!
Особенно - вот это
Код
id > IF((SELECT count(*) FROM `#__user_usergroup_map` WHERE group_id=7 AND user_id= $user_id ) > 0, 0, 2147483647)

 
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Один запрос MySQL к _users + _user_usergroup_map
« Ответ #13 : 23.12.2016, 22:06:36 »
ну надо ж было как то обдурить, подзапрос выполнить :)
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

База данных MySQL периодически не отвечает

Автор nightbeast

Ответов: 10
Просмотров: 926
Последний ответ 09.10.2016, 23:27:09
от voland