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

sertiop

  • Новичок
  • 4
  • 0 / 2
Доброго времени суток.
У меня вот такой вопрос.
Вот смотрите в корень хоста установил Joomla 1.5. Сделал субдомен и там сделал еще один сайт на движке джостина.
Вопрос. Они в разных папках. Разные движки. Можно ли сделать так что бы у них была одна база по пользователям? То есть регистрируюсь на сайте Joomla этот пользователь автоматически пропитывался в базе джостина которая находиться на субдомене?
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: База данных пользователей
« Ответ #1 : 19.07.2009, 12:23:32 »
можно конечно, можно как легкий хак компонента com_user - добавить INSERT в соседнюю БД (если они на одном хосте - никаких проблем не вызывает), можно без всех API делать коннект и писать данные
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

sertiop

  • Новичок
  • 4
  • 0 / 2
Re: База данных пользователей
« Ответ #2 : 19.07.2009, 13:01:30 »
а можно поподробнее? у вас есть аська?? можете связатся со мной? плиззз!!!! вот моя 220760434
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: База данных пользователей
« Ответ #3 : 19.07.2009, 13:05:06 »
нет, подробней сегодня не будет, воскресенье все-таки
Я думаю что за пару часов можно найти в гугле инструкции как выполнять соединение с БД и запрос по записи определенных данных.
В помощь по движку будет вот эта статья Как добавить пользователя Joomla через phpMyAdmin (это к тому - какие запросы нужно будет выполнять)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

sertiop

  • Новичок
  • 4
  • 0 / 2
Re: База данных пользователей
« Ответ #4 : 19.07.2009, 13:10:06 »
ну если вы говорите просто то скажите где что прописать где прописать инсерт или что?? плиииз очень надо
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: База данных пользователей
« Ответ #5 : 19.07.2009, 13:13:24 »
components\com_user\controller.php, нужно смотреть и дописывать в функцию function register_save()
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

sertiop

  • Новичок
  • 4
  • 0 / 2
Re: База данных пользователей
« Ответ #6 : 19.07.2009, 13:14:32 »
ну это не долго же??? вы могли бы с этим помочь, я просто не знаю что куда как дописывать.. пожалуйста...
*

Aleks_El_Dia

  • Moderator
  • 3671
  • 353 / 0
  • AEDStudio Joomla! Direction
Re: База данных пользователей
« Ответ #7 : 19.07.2009, 13:29:44 »
C таким подходом сложно будет чему нибудь научится самому)) А всю работу за вас никто все равно делать не будет.

Если заплатить - то и знать не обязательно)))))))
« Последнее редактирование: 19.07.2009, 16:20:13 от Aleks_El_Dia »
Спам придумали боги в отместку за наши молитвы (с) Рома Воронежский
На молоко: Z369038872422 || R210017695494 || U247040729215 || ЯД 410011288250383
Мигрирую сайты, переношу расширения J!1.0->J!1.5->J!2.5. Более 50 успешных миграций.
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: База данных пользователей
« Ответ #8 : 19.07.2009, 15:29:11 »
Товарищу sertiop выдано готовое решение в файле controller.php, жду от него поступления обещанных средств (копейки но дело в принципе), потому вопрос можно считать исчерпанным.
Кому интересно - выложу топорное решение (кстати у меня почему то не захотел отрабатываться LAST_INSERT_ID  :o, потому пришлось делать дополнительный запрос на получение параметров из jos_core_acl_aro)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Re: База данных пользователей
« Ответ #9 : 19.07.2009, 23:25:30 »
Резюмирую, не зла ради но справедливости
Товарищ sertiop - идиот, наглец и кидала
От него было в личку получено сообщение
Цитировать
300 час.. вы за 300 рублей сможете сделать это то что я сейчас прошу? если да то давайте деньги сразу же перечеслю .. через скока вы сможете это сделать??? мне побыстрее бы плиииз
Через час в аське было выдано рабочее решение с комментариями по адаптации к системе, на что пошли вопли "у меня ничего не работает" и подобное.
300 рублей конечно не жалко, но не связывайтесь с этим товарищем (Сергей - очень очень хочу опцию черного списка, чтобы сразу видеть в топиках ху есть ху)

Придерживаюсь мнения, что буду помогать людям с сообщениями от сотни или с нормальной кармой :)
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

smart

  • Администратор
  • 6478
  • 1318 / 15
  • Хочешь сделать хорошо — сделай!
Re: База данных пользователей
« Ответ #10 : 20.07.2009, 13:37:20 »
300 рублей конечно не жалко, но не связывайтесь с этим товарищем (Сергей - очень очень хочу опцию черного списка, чтобы сразу видеть в топиках ху есть ху)
Чуть позже реализую, а пока предлагаю в коммерческом разделе повесить объяву...
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Ошибка #1050 при переносе базы данных на хостинг

Автор Ksen

Ответов: 7
Просмотров: 24781
Последний ответ 16.03.2020, 17:47:29
от Petrovich
Авторизация пользователей

Автор Вик2811

Ответов: 0
Просмотров: 984
Последний ответ 27.08.2019, 13:55:52
от Вик2811
Передача данных в форму при нажатии на ссылку

Автор usmdamir

Ответов: 4
Просмотров: 1638
Последний ответ 26.07.2017, 09:40:22
от usmdamir
Re: Изменение таблиц базы данных

Автор ZAlex60

Ответов: 4
Просмотров: 1465
Последний ответ 23.09.2016, 09:57:14
от ZAlex60
Ввод данных на сайте – подстановка их в текст. документ

Автор Plazmodina

Ответов: 4
Просмотров: 2706
Последний ответ 10.09.2015, 15:20:44
от DeKajper