Новости 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 Ответов
  • 1540 Просмотров
*

HKDOAM

  • Осваиваюсь на форуме
  • 22
  • 0 / 0
robots.txt и защита
« : 17.01.2013, 12:47:02 »
Добрый день, разрабатываю сайт на Joomla 2.5, вот как бы сайт готов, последние шаги это защита была и поисковый робот. Если защита - ответом много в сети и способов, то как поступать с robots.txt?

Это моя первая оптимизация и личный проект такого плана, поэтому стараюсь разобраться и изучить все аспекты, касающиеся моего сайта.
Вычитал что защита начинается с скрытия всех данных о том что сайт стоит на Joomla, это всякие надписи, ссылки, вклюачая директорию админ панели.... все это решимо...

А вот что делать с поисковым роботом? ведь в нем прописаны директории сайта на закрытие индексации что наталкивает хакеров на то что это Joomla? я гуглил и читал что закрыть для пользователей нельзя, а хороший хакер и так откроет robots.txt, просто думал может как то можно скрыть хотя бы наводку на то что это Joomla в robots.txt или как то защитить?

(я с другими CMS не имел дела почти).
*

ELLE

  • Глобальный модератор
  • 4506
  • 893 / 0
Re: robots.txt и защита
« Ответ #1 : 17.01.2013, 13:33:26 »
Паранойя.

Joomla распознается по многим факторам, роботс в их числе, но еще больше скажет исходный код
*

HKDOAM

  • Осваиваюсь на форуме
  • 22
  • 0 / 0
Re: robots.txt и защита
« Ответ #2 : 17.01.2013, 13:35:08 »
выходит все расширения типа файерволы, и тд до одного места? максимум пароль на админку что бы не могли попасть в панель управления?
*

ELLE

  • Глобальный модератор
  • 4506
  • 893 / 0
Re: robots.txt и защита
« Ответ #3 : 17.01.2013, 13:40:06 »
Да что им ваша админка?
Вы зайдите в раздел безопасности здесь на форуме и попробуйте отыскать хоть одну тему с заголовком "сломали админку" или вроде того.....
В большинстве случаев либо украли пароль от ftp (по вине самого владельца), либо хостер "дырявый", либо варез сами владельцы ставили.
По максимуму используйте то, что из коробки, обновляйте двиг.
*

HKDOAM

  • Осваиваюсь на форуме
  • 22
  • 0 / 0
Re: robots.txt и защита
« Ответ #4 : 17.01.2013, 13:42:55 »
я просто читал о защите и первый статьи что попадались это скрытие любой информации о движке ....

Я уже смерился с тем что все не скрыть, и защиты 100% нету...
Буду смотреть на практике, все таки мой первый проект на платном хостинге для себя, заодно и опыт...
Спасибо ELLE за утишения
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Роботу Googlebot заблокирован доступ в файле robots.txt

Автор illimited

Ответов: 3
Просмотров: 3769
Последний ответ 29.05.2022, 14:57:55
от web1
Правильный robots.txt? [вопросы/обсуждение]

Автор wishlight

Ответов: 447
Просмотров: 208188
Последний ответ 20.11.2021, 16:53:49
от Byzi
Как лучше прописать robots.txt?

Автор web1

Ответов: 2
Просмотров: 1109
Последний ответ 25.07.2021, 21:38:12
от web1
Разные robots.txt

Автор yyyuuu

Ответов: 7
Просмотров: 1147
Последний ответ 14.01.2021, 14:06:58
от rsn
Языки /en/ /ru/ проблема с входом в админку и редиректит на site.r/ru/robots.txt

Автор HolySong

Ответов: 0
Просмотров: 1030
Последний ответ 10.07.2020, 13:12:46
от HolySong