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

saschka

  • Захожу иногда
  • 169
  • 1 / 0
Admin Tools сброс пароля
« : 15.01.2018, 13:45:39 »
Всем привет!
Не могу найти пароль для входа в админку. Удаление содержания файла .htaccess не помогает.
Как либо сбросить пароль, либо отключить Admin Tools через базу данных? Ну или как вообще зайти в админку другим способом?
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: Admin Tools сброс пароля
« Ответ #1 : 15.01.2018, 13:52:16 »
См. тут, тут
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

saschka

  • Захожу иногда
  • 169
  • 1 / 0
Re: Admin Tools сброс пароля
« Ответ #2 : 15.01.2018, 14:24:48 »
См. тут, тут
Как удалить компонент Admin Tools, если нет возможности зайти в панель управления?
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: Admin Tools сброс пароля
« Ответ #3 : 15.01.2018, 14:33:46 »
К FTP есть доступ? К базе данных?  Зайдите в папку administrator/ и удалите 2 файла: .htaccess и .htpasswd, у вас перестанет работать дополнительная авторизация. Сам компонент можно отключить через базу данных в таблице #_extensions
« Последнее редактирование: 15.01.2018, 14:38:51 от SeBun »
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
*

saschka

  • Захожу иногда
  • 169
  • 1 / 0
Re: Admin Tools сброс пароля
« Ответ #4 : 15.01.2018, 14:59:21 »
К FTP есть доступ? К базе данных?  Зайдите в папку administrator/ и удалите 2 файла: .htaccess и .htpasswd, у вас перестанет работать дополнительная авторизация. Сам компонент можно отключить через базу данных в таблице #_extensions
В базе данных в таблице _extensions не нашел admintools
.htaccess очищал полностью, не помогло. Удалять не пробовал.
*

saschka

  • Захожу иногда
  • 169
  • 1 / 0
Re: Admin Tools сброс пароля
« Ответ #5 : 15.01.2018, 15:02:43 »
К FTP есть доступ? К базе данных?  Зайдите в папку administrator/ и удалите 2 файла: .htaccess и .htpasswd, у вас перестанет работать дополнительная авторизация. Сам компонент можно отключить через базу данных в таблице #_extensions
В итоге удалил эти два файла, помогло.
*

SeBun

  • BanMaster
  • 4030
  • 259 / 5
  • @SeBun48
Re: Admin Tools сброс пароля
« Ответ #6 : 15.01.2018, 16:41:28 »
В итоге удалил эти два файла, помогло.
Эти два файла задают так называемую basic-авторизацию. И желательно, что бы ваша админка все же была закрыта от свободного доступа. Лично я не рекомендую пользоваться AdminTools, но вот админку рекомендую закрыть. Для этого верните обратно два файла, .htaccess и .htpasswd. При этом важно помнить, что это простые текстовые файлы, и они работают без AdminTools. Их можно сгенерировать, например, здесь. Придумайте ваш дополнительный логин и пароль, которые будете вводить. И, самое главное, корректно укажите полный путь. Удачи!
Оказываю услуги по Joomla | Миграция/Обновление | Сопровождение | IT-аутсорсинг | Недорогие домены и хостинг
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Востоновление пароля

Автор djstone

Ответов: 2
Просмотров: 748
Последний ответ 20.06.2025, 11:09:23
от wishlight
Можно ли запретить суперюзеру смену пароля?

Автор Konstantin124

Ответов: 48
Просмотров: 3553
Последний ответ 08.01.2020, 14:21:40
от ProtectYourSite
Admin Tools Pro или RSFirewall

Автор wd

Ответов: 38
Просмотров: 4203
Последний ответ 10.11.2017, 10:33:45
от Arkadiy
Брутфорс пароля

Автор mickymouse

Ответов: 24
Просмотров: 1774
Последний ответ 05.11.2017, 17:10:03
от AdWeb
Admin Tools Pro

Автор Ingener

Ответов: 59
Просмотров: 13656
Последний ответ 11.10.2017, 12:15:21
от ProtectYourSite