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

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Разработка компонента
« : 23.05.2017, 10:22:54 »
Привет всем.Кто шарит в разработке компонентов для Joomla?
Создаю компонент, но при установке влетает ошибка файла install.sql Расширение Установить: ошибка выполения SQL-запроса: Ошибка базы данных с номером 1064 типа ошибка синтаксиса, но если берешь и через БД делаешь запрос, то все устанавливается. В чем проблема не могу понять.Вот сам запрос

CREATE TABLE IF NOT EXISTS `doska` (
`id` int(5) unsigned NOT NULL auto_increment,
`name` varchar(255) NOT NULL,
`parent_id` int(5) NOT NULL DEFAULT '0',
`alias` varchar(255) NOT NULL ,
`state` tinyint(1) NULL DEFAULT '1',
PRIMARY KEY ( `id`)
)ENGINE=MyISAM DEFAULT CHARSET=utf8;
*

robert

  • Живу я здесь
  • 4974
  • 457 / 20
Re: Разработка компонента
« Ответ #1 : 23.05.2017, 10:29:10 »
Привет всем.Кто шарит в разработке компонентов для Joomla?
Да таких тут целая орда.
Не надо "типа", приведите текст ошибки полностью.
Не будь паразитом, сделай что-нибудь самостоятельно!
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #2 : 23.05.2017, 10:31:46 »
создание первичного ключа следует вынести в отдельный запрос, а к таблице следует дописать префикс '#__'
*

b2z

  • Глобальный модератор
  • 7284
  • 778 / 0
  • Разраблю понемногу
Re: Разработка компонента
« Ответ #3 : 23.05.2017, 11:57:20 »
создание первичного ключа следует вынести в отдельный запрос
Зачем?

Цитировать
а к таблице следует дописать префикс '#__'
Да, это верное замечание.

Код: sql
CREATE TABLE IF NOT EXISTS `#__doska`

Цитировать
ENGINE=MyISAM
Я бы InnoDB использовал.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #4 : 23.05.2017, 12:00:24 »
Зачем?
некоторые сборки мускула ругаются именно на это, например рег.ру этой фигней страдает
*

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Re: Разработка компонента
« Ответ #5 : 23.05.2017, 13:27:50 »
создание первичного ключа следует вынести в отдельный запрос, а к таблице следует дописать префикс '#__'
С префиксом тоже самое.
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #6 : 23.05.2017, 13:41:36 »
скопируйте сюда полный текст сообщения об ошибке
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Разработка компонента
« Ответ #7 : 23.05.2017, 14:00:56 »
сервер на windows?
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Re: Разработка компонента
« Ответ #8 : 23.05.2017, 14:08:04 »
скопируйте сюда полный текст сообщения об ошибке
Код
Предупреждение

JInstaller: :Install: Ошибка SQL You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CREATE TABLE IF NOT EXISTS `#__doska` ( `id` int(5) unsigned NOT NULL au' at line 1 SQL=CREATE TABLE IF NOT EXISTS `#__doska` ( `id` int(5) unsigned NOT NULL auto_increment, `name` varchar(255) NOT NULL, `parent_id` int(5) NOT NULL DEFAULT '0', `alias` varchar(255) NOT NULL , `state` tinyint(1) NULL DEFAULT '1', PRIMARY KEY ( `id`) )ENGINE=MyISAM DEFAULT CHARSET=utf8;
Расширение Установить: ошибка выполения SQL-запроса: Ошибка базы данных с номером 1064
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'CREATE TABLE IF NOT EXISTS `#__doska` ( `id` int(5) unsigned NOT NULL au' at line 1 SQL=CREATE TABLE IF NOT EXISTS `#__doska` ( `id` int(5) unsigned NOT NULL auto_increment, `name` varchar(255) NOT NULL, `parent_id` int(5) NOT NULL DEFAULT '0', `alias` varchar(255) NOT NULL , `state` tinyint(1) NULL DEFAULT '1', PRIMARY KEY ( `id`) )ENGINE=MyISAM DEFAULT CHARSET=utf8;
SQL =
CREATE TABLE IF NOT EXISTS `#__doska` (
 `id` int(5) unsigned NOT NULL auto_increment,
 `name` varchar(255) NOT NULL,
 `parent_id` int(5) NOT NULL DEFAULT  '0',
 `alias` varchar(255) NOT NULL ,
 `state` tinyint(1) NULL DEFAULT  '1',
PRIMARY KEY ( `id`)
)ENGINE=MyISAM  DEFAULT CHARSET=utf8;
*

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Re: Разработка компонента
« Ответ #9 : 23.05.2017, 14:08:22 »
сервер на windows?
нет, хостинг Beget
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #10 : 23.05.2017, 14:13:33 »
попробуйте все-таки убрать PRIMARY KEY ( `id`),
также попробуйте вынести отдельно автоинкремент, его указание обычно идет после указания первичного ключа:

ALTER TABLE `#__doska` ADD PRIMARY KEY (`id`);
ALTER TABLE `#__doska` MODIFY `id` int(5) NOT NULL AUTO_INCREMENT;
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Разработка компонента
« Ответ #11 : 23.05.2017, 14:14:16 »
нет, хостинг Beget
смешно :) сервер хостинга Beget - на windows?

попробуйте сделать http://joomlaforum.ru/index.php/topic,338131.msg1709310.html#msg1709310
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Re: Разработка компонента
« Ответ #12 : 23.05.2017, 14:16:16 »
попробуйте все-таки убрать PRIMARY KEY ( `id`)
тоже самое
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #13 : 23.05.2017, 14:17:43 »
проверьте кодировку файла
*

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Re: Разработка компонента
« Ответ #14 : 23.05.2017, 14:23:28 »
проверьте кодировку файла
Кодировка UTF-8
сейчас попробовал вставить в файл запрос от революшион слайдер и такая же фишка, только тут то точно все верно
CREATE TABLE IF NOT EXISTS `#__revslider_sliders` (
  `id` int(10) unsigned NOT NULL auto_increment,
  `title` varchar(255) NOT NULL,
  `alias` varchar(255) NOT NULL default '',
  `params` text NOT NULL,
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=utf8;
*

AlekVolsk

  • Гуру
  • 6913
  • 416 / 4
Re: Разработка компонента
« Ответ #15 : 23.05.2017, 14:25:03 »
ну тогда надо смотреть самому более предметно, дальнейшее - это уже гадание по гуще, в комм.раздел
*

dimasan57

  • Захожу иногда
  • 93
  • 1 / 0
Re: Разработка компонента
« Ответ #16 : 23.05.2017, 14:27:42 »
ну тогда надо смотреть самому более предметно, дальнейшее - это уже гадание по гуще, в комм.раздел
Решено! Кодировка должна быть без BOM
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Создание релиза компонента средствами GitHub

Автор SkyAn

Ответов: 4
Просмотров: 954
Последний ответ 01.11.2019, 17:42:04
от Septdir
Ошибка при попытке получить параметры активного пункта меню в контроллере компонента

Автор Inoken

Ответов: 10
Просмотров: 1792
Последний ответ 19.06.2017, 14:29:22
от dmitry_stas
Зависимость модуля от компонента и страницы

Автор Тренд

Ответов: 34
Просмотров: 3004
Последний ответ 16.06.2017, 19:48:39
от dmitry_stas
Организация доступа пользователей к контенту кастомного компонента

Автор Inoken

Ответов: 4
Просмотров: 1210
Последний ответ 15.06.2017, 10:05:40
от Inoken
Получение содержимого страницы любого компонента

Автор jmaf

Ответов: 6
Просмотров: 1437
Последний ответ 03.04.2016, 18:25:06
от b2z