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

Crazy...

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Помощь по защите CAPTCHAми
« : 13.10.2014, 02:33:59 »
Всем доброго времени суток.
Я человек малознающий в Joomla:) Потребовалось перевести один сайт фирмы, который делал еще 7 лет назад на XHTML. Решил озаботится проблемами безопасности. Чтение Google и FAQ результата не дали. Перечитать все ветки сайта не представляется возможным) Если вам не сложно не могли бы вы ответить на пару вопросиков, или перенаправить на нужные ресурсы.

1 вопрос:
Есть сайт на Joomla 2.5. На сайте реализована отдельная страница аутентификации посредством добавления нового (нигде не используемого) меню. И создания в этом меню пункта с типом "Форма авторизации". в итоге получилась отдельная страница mySite.ru/auth. Где в месте для контента располагается форма авторизации. Но получается что тут можно подобрать пароль брутфорсом. И вот собственно вопрос как мне вывести капчу на этой форме при некотором числе неправильных попыток? Возможно для такой реализации необходимо использовать какое то стороннее расширение? Если да, то подскажите советом какое. Если есть более правильное решение для авторизации на fronte сайта, без формы авторизации на главной, то подскажите какое. Мне идея отдельной страницы нравится больше всего.

2 вопрос:
Тоже очень важный для меня вопрос.
Можно ли вывести капчу при некотором числе неправильных попыток в админке? Если этот вариант плох, то подскажите что читать и как правильно защищать админку? Есть ли где то список действий по защите сайта разложенный по полочкам.

За
*

Crazy...

  • Осваиваюсь на форуме
  • 12
  • 0 / 0
Re: Помощь по защите CAPTCHAми
« Ответ #1 : 14.10.2014, 01:01:14 »
Неужели никто даже не может подтолкнуть в нужном направлении? Или здесь только свой круг общения?
*

flyingspook

  • Moderator
  • 3590
  • 247 / 9
Re: Помощь по защите CAPTCHAми
« Ответ #2 : 14.10.2014, 09:46:23 »
CAPTCHA любая какая нравится их массы в данное время
Цитировать
то подскажите что читать и как правильно защищать админку?
http авторизацию поставить и не засорять себе и остальным мозг
*

effrit

  • Легенда
  • 10132
  • 1118 / 13
  • effrit.com
Re: Помощь по защите CAPTCHAми
« Ответ #3 : 14.10.2014, 12:26:38 »
добрый день.
выбираем капчу по вкусу на JED.
вот пример математической, в настройках есть поддержка форм авторизации, так что к модулю должна приписаться, по идее.
http://extensions.joomla.org/extensions/access-a-security/site-security/captcha/11964
ну или поднимаемся на раздел выше и выбираем ещё что-нибудь.
*

busik

  • Захожу иногда
  • 186
  • 7 / 0
Re: Помощь по защите CAPTCHAми
« Ответ #4 : 15.10.2014, 00:25:08 »
re-CAPTCHA рекомендую в виде плагина, скачивается на офф.сайте Joomla. Как раз сегодня ставил на J 2.5, у знакомой спам посыпался. Только коды желательно получить заново и аккуратно ввести (ссылка внутри в плагине).
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Помощь в настройке Eyesite

Автор Ingener

Ответов: 29
Просмотров: 6939
Последний ответ 07.12.2023, 13:44:45
от master-smeta
Фонтомные страницы ( нужна помощь )

Автор ks8re

Ответов: 14
Просмотров: 1301
Последний ответ 01.04.2017, 10:06:41
от maximm
SQL инъекции нужна помощь

Автор mister_boy

Ответов: 8
Просмотров: 1903
Последний ответ 13.09.2016, 19:57:38
от flyingspook
нужна помощь

Автор bursnab

Ответов: 1
Просмотров: 1035
Последний ответ 12.09.2016, 07:46:02
от Taatshi
Нужна помощь! Вирус на сайте

Автор samarskii

Ответов: 7
Просмотров: 1237
Последний ответ 26.11.2015, 19:24:30
от jlend