Новости Joomla

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод...

👩‍💻 Как триггерить события для плагинов на манер Joomla 5+?В Joomla 6 должны удалить метод triggerEvent(), с помощью которого раньше вызывались события для плагинов. Теперь чтобы в своём коде вызвать событие для плагина и получить от него результаты нужно:- создать объект класса события- передать в него параметры

use Joomla\CMS\Event\AbstractEvent;use Joomla\CMS\Factory;use Joomla\CMS\Plugin\PluginHelper;// Грузим плагины нужных группPluginHelper::importPlugin('system');// Создаём объект события$event = AbstractEvent::create('onAfterInitUniverse', [    'subject' => $this,    'data'    => $data, // какие-то данные    'article' => $article, // ещё материал вдовесок    'product' => $product, // и товаров подвезли]);// Триггерим событиеFactory::getApplication()->getDispatcher()->dispatch(    $event->getName(), // Тут можно строку передать 'onAfterInitUniverse'    $event);// Получаем результаты// В случае с AbstractEvent это может быть не 'result',// а что-то ещё - куда сами отдадите данные.// 2-й аргумент - значение по умолчанию, // если не получены результаты$results = $event->getArgument('result', []);
Плюсы такого подхода - вам не нужно запоминать порядок аргументов и проверять их наличие. Если вы написали свой класс события, то в плагине можно получать аргументы с помощью методов $event->getArticle(), $event->getData(), $event->getProduct() и подобными - реализуете сами под свои нужды. Если такой класс события написали, то создаёте экземпляр своего класса события и укажите его явно в аргументе eventClass
use Joomla\Component\MyComponent\Administrator\Event\MyCoolEvent;$event = MyCoolEvent::create('onAfterInitUniverse', [    'subject'    => $this,    'eventClass' => MyCoolEvent::class, // ваш класс события    'data'       => $data, // какие-то данные    'article'    => $article, // ещё материал вдовесок    'product'    => $product, // и товаров подвезли]);
Ожидаемо, что класс вашего события будет расширять AbsractEvent или другие классы событий Joomla.🙁 Есть неприятный нюанс - нельзя просто так вызывать событие и ничего не передать в аргументы. Аргумент subject обязательный. Но если вы всё-таки не хотите туда ничего передавать - передайте туда пустой stdClass или объект Joomla\registry\Registry.
@joomlafeed#joomla #php #webdev

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

warlocksp

  • Завсегдатай
  • 1198
  • 17 / 4
Найти по FTP - базу SQL - ?
« : 18.03.2015, 12:18:47 »
Добрый день,

Как на ftp найти базу SQL - ?
Подскажите пожалуйста...
Мудр не тот, кто знает много, а тот, чьи знания полезны. Эсхил
*

almika

  • Захожу иногда
  • 325
  • 27 / 0
Re: Найти по FTP - базу SQL - ?
« Ответ #1 : 18.03.2015, 12:23:22 »
Я не знаю, может на каких-то хостингах и дают доступ к файлу базы по ftp, но обычно через php admin или похожее. А зачем Вам файл базы данных?
*

warlocksp

  • Завсегдатай
  • 1198
  • 17 / 4
Re: Найти по FTP - базу SQL - ?
« Ответ #2 : 18.03.2015, 12:26:47 »
Я не знаю, может на каких-то хостингах и дают доступ к файлу базы по ftp, но обычно через php admin или похожее. А зачем Вам файл базы данных?

Клиент просит скопировать сайт для установки новой, другой CMS...
Дал ftp только...
Мудр не тот, кто знает много, а тот, чьи знания полезны. Эсхил
*

Ragivort

  • Завсегдатай
  • 1154
  • 58 / 2
  • Такая Life
Re: Найти по FTP - базу SQL - ?
« Ответ #3 : 18.03.2015, 12:28:00 »
Установите Akeeba Backup, сдклайте бэкап сайта и скачайте его.
Дозволь мне свершить то добро, которое я способен свершить, теперь, ибо я могу более не вернуться сюда.
*

motokraft

  • Завсегдатай
  • 1326
  • 72 / 13
Re: Найти по FTP - базу SQL - ?
« Ответ #4 : 18.03.2015, 12:39:27 »
Добрый день,

Как на ftp найти базу SQL - ?
Подскажите пожалуйста...

через ftp никак, надо делать в phpMyAdmin
...
*

flyingspook

  • Живу я здесь
  • 3590
  • 247 / 9
Re: Найти по FTP - базу SQL - ?
« Ответ #5 : 18.03.2015, 13:05:10 »
Клиент просит скопировать сайт для установки новой, другой CMS...
Дал ftp только...
Если от админки есть доступ то поможет Akeeba Backup
Для админки так же есть расширение типа phpMyAdmin
Через FTP можго скачать БД используя скрипты типа dumper примерно такие
« Последнее редактирование: 18.03.2015, 13:08:27 от flyingspook »
*

Ragivort

  • Завсегдатай
  • 1154
  • 58 / 2
  • Такая Life
Re: Найти по FTP - базу SQL - ?
« Ответ #6 : 18.03.2015, 13:10:34 »
Если от админки есть доступ то поможет Akeeba Backup

Бэкап можно скачать и через ftp в папке administrator/com_akeeba/backups

Но ессно. если админки нет, компонент не установишь
Дозволь мне свершить то добро, которое я способен свершить, теперь, ибо я могу более не вернуться сюда.
*

naprimer

  • Осваиваюсь на форуме
  • 10
  • 0 / 0
Re: Найти по FTP - базу SQL - ?
« Ответ #7 : 21.07.2017, 20:44:30 »
Да нафига все эти заморочки?
Если есть доступ по ФТП, устанавливайте один файл (скачать можно здесь: https://www.adminer.org/#download), загрузите в корневую директорию сайта и перейдите по адресу http://вашсайт/полное_название_загруженного_файла.
А дальше вводите название БД, имя пользователя и пароль. И вуа-ля.
*

Gosha7488

  • Новичок
  • 2
  • 0 / 0
Re: Найти по FTP - базу SQL - ?
« Ответ #8 : 26.07.2017, 22:12:05 »
Скорее всего, у него нет ни названия БД, ни имени пользователя, ни пароля.

Если есть доступ ftp, то это не проблема.
*

Gosha7488

  • Новичок
  • 2
  • 0 / 0
Re: Найти по FTP - базу SQL - ?
« Ответ #9 : 26.07.2017, 22:13:41 »
Да нафига все эти заморочки?
Если есть доступ по ФТП, устанавливайте один файл (скачать можно здесь: https://www.adminer.org/#download), загрузите в корневую директорию сайта и перейдите по адресу http://вашсайт/полное_название_загруженного_файла.
А дальше вводите название БД, имя пользователя и пароль. И вуа-ля.
Спасибо! Работает
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как на php найти совпадения цифр? [ РЕШЕНО ]

Автор dm-krv

Ответов: 8
Просмотров: 961
Последний ответ 01.11.2018, 16:57:12
от dm-krv
Юникод при записи параметров в базу данных

Автор Taatshi

Ответов: 12
Просмотров: 1224
Последний ответ 30.10.2017, 14:27:31
от SeBun
Перенесено: Как найти недостающий XML-файл?

Автор b2z

Ответов: 0
Просмотров: 977
Последний ответ 02.09.2014, 11:05:17
от b2z