Новости Joomla

SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla

SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla

👩‍💻 SW JProjects v.2.5.0 - компонент каталога цифровых проектов на Joomla.Компонент - менеджер цифровых проектов для Joomla! CMS. Компонент обеспечивает создание каталога цифровых проектов и предоставляет возможность скачивания, в том числе с использованием лицензионных ключей.👩‍💻 v.2.5.0. Что нового?Схемы структур данных для серверов обновлений. Теперь с SW JProjects вы может создавать сервер обновлений не только для расширений Joomla, но и свои собственные. Например, вам нужно, чтобы структура данных сервера обновлений была другая и формат должен быть, например, не XML, а JSON. Формирование структуры данных для сервера обновлений расширений Joomla вынесено в отдельный плагин. Вы можете создать свой собственный плагин и реализовать в нём нужную вам структуру данных, добавив или наоборот исключив отображаемые данные. Сервер обновлений в компоненте по-прежнему отображает информацию о списке проектов и их версиях, о конкретном проекте и его changelog.Можно выбрать схему данных сервера обновлений глобально для всего компонента, выбрать другую схему данных для категории проектов, а так же выбрать схему в каждом проекте.

Разработчикам в качестве образца можно посмотреть плагин схемы данных для Joomla в составе компонента или же плагин-образец JSON-схемы на GitHub.
Группа плагинов swjprojects. Для нужд компонента создана группа плагинов swjprojects. В частности, в этой группе находится плагин структуры данных Joomla расширений для сервера обновлений.Изменение языковых констант. Изменены некоторые языковые константы в панели администратора. Если вы делали переопределение констант - переопределите их снова.👩‍💻 Joomla 6. Внесены изменения для корректной установки и работы компонента на Joomla 6. Компонент успешно протестирован на Joomla 6-beta2.Минимальная версия Joomla - 5. Подняты минимальные системные требования: Joomla 5.0.0 и PHP 8.1.
- Страница расширения👉 Плагин-образец кастомной JSON-схемы данных для сервера обновлений на GitHub.- GitHub расширения- Документация на GitHub- Joomla Extensions Directory#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 Гость просматривают эту тему.
  • 11 Ответов
  • 1102 Просмотров
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Поиск на сайте - SQL запрос
« : 06.08.2016, 19:27:01 »
есть две таблицы #__objects и #__secret
Пример данных в таблице #__objects
--------------
| id | name |
--------------
| 1 | имя 1 |
| 2 | имя 2 |
| 3 | имя 3 |
|....| имя...|
--------------

Пример данных в таблице #__secret
---------------------------
| id | id_objects |  type  | number |
---------------------------
| 1 |       1        | object | 345677 |
| 2 |       1        | phone | 314677 |
| 3 |       1        | phone | 355572 |
| 4 |       2        | object | 263478 |
| 5 |       3        | object | 764382 |
----------------------------

Вопрос!

как нам получить вывод данных
если:
Код: php-brief
$value_phone = "677";
$q->select(array('a.*', 'b.*'))
            ->from('#__objects AS a')
            ->join('INNER', '#__secret AS b ON (a.id = b.id_objects)')
            ->where('b.number LIKE "%'.$value_phone.'%"')

проблема в том, что моё условие выборки даёт 2 объекта!
а мне надо один объект! в данном случае с id = 1 в таблице #__objects

надеюсь понятно объяснил  ^-^
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #1 : 06.08.2016, 22:07:42 »
Вопрос!

как нам получить вывод данных
вывод данных - это echo. или var_dump. или еще print_r например есть. а вопрос в чем? :)

проблема в том, что моё условие выборки даёт 2 объекта!
проблема в том, что нигрена не понятно :) как оно может дать 1, если по вашему условию LIKE "%'.$value_phone.'%" 2 подходит - id=1 и id=2? а почему именно id=1? вы или в условие type="object" добавьте, или если я не угадал, то объясните нормально

P.S. кстати помимо INNER JOIN есть еще LEFT JOIN. и также есть еще GROUP BY. если с условием не угадал, то из этого что-нибудь обязательно поможет :)
« Последнее редактирование: 06.08.2016, 22:11:44 от dmitry_stas »
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

passer

  • Завсегдатай
  • 1013
  • 75 / 3
Re: Поиск на сайте - SQL запрос
« Ответ #2 : 06.08.2016, 23:50:25 »
Добавьте еще одно условие по type например.
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #3 : 07.08.2016, 01:56:38 »
вывод данных - это echo. или var_dump. или еще print_r например есть. а вопрос в чем? :)
проблема в том, что нигрена не понятно :) как оно может дать 1, если по вашему условию LIKE "%'.$value_phone.'%" 2 подходит - id=1 и id=2? а почему именно id=1? вы или в условие type="object" добавьте, или если я не угадал, то объясните нормально

P.S. кстати помимо INNER JOIN есть еще LEFT JOIN. и также есть еще GROUP BY. если с условием не угадал, то из этого что-нибудь обязательно поможет :)

ну вопрос о правильном SQL запросе для получения нужного результата!
Если у нас есть два совпадения в таблице #__secret, то необходимо вывести один объект к которому они, эти совпадения принадлежат
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #4 : 07.08.2016, 10:19:51 »
ну вопрос о правильном SQL запросе для получения нужного результата!
я уже вам вроде нужные варианты написал.

Если у нас есть два совпадения в таблице #__secret, то необходимо вывести один объект к которому они, эти совпадения принадлежат
если при этом все равно, какая строка присоединится из #__secret, то используйте группировку (GROUP BY) по id из первой таблицы. если не все равно - добавляйте WHERE b.type=...
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #5 : 07.08.2016, 17:51:52 »
я уже вам вроде нужные варианты написал.
если при этом все равно, какая строка присоединится из #__secret, то используйте группировку (GROUP BY) по id из первой таблицы. если не все равно - добавляйте WHERE b.type=...

сделал
Код: php-brief
$value_phone = "677";
$q->select(array('a.*', 'b.*'))
            ->from('#__objects AS a')
            ->join('INNER', '#__secret AS b ON (a.id = b.id_objects)')
            ->where('b.number LIKE "%'.$value_phone.'%"')
            ->group('b.id_objects'); // добавил группировку!

теперь работает как надо! Спасибо!
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #6 : 07.08.2016, 19:32:34 »
ну запрос по крайней мере похож на правильный. единственно что, если $value_phone у вас приходит извне, то так, как сейчас в запросе - это SQL injection. обратите на это внимание
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #7 : 07.08.2016, 23:09:18 »
ну запрос по крайней мере похож на правильный. единственно что, если $value_phone у вас приходит извне, то так, как сейчас в запросе - это SQL injection. обратите на это внимание

а как лучше сделать, без SQL injection?
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #8 : 07.08.2016, 23:54:08 »
а вы сами то как считаете, как лучше - с ней или без нее? вы понимаете что такое SQL injection? лучше да, без возможности SQL инъекции.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

zomby6888

  • Завсегдатай
  • 1473
  • 171 / 3
Re: Поиск на сайте - SQL запрос
« Ответ #9 : 08.08.2016, 00:57:34 »
Разработчикам расширений стоило бы для начала почитать как писать безопасные расширения:

https://cmscafe.ru/razrabotka/547-sozdaem-bezopasnye-rasshireniya-dlya-joomla
интернет-блог: http://websiteprog.ru
*

dmitry_stas

  • Легенда
  • 13151
  • 1234 / 8
Re: Поиск на сайте - SQL запрос
« Ответ #10 : 08.08.2016, 08:09:52 »
ну да, как то так... там даже с LIKE пример есть.
Тут дарят бакс просто за регистрацию! Успей получить!
Все советы на форуме раздаю бесплатно, то есть даром. Индивидуально бесплатно консультирую только по вопросам стоимости индивидуальных консультаций
*

john.deff

  • Захожу иногда
  • 115
  • 0 / 0
Re: Поиск на сайте - SQL запрос
« Ответ #11 : 08.08.2016, 10:08:29 »
Разработчикам расширений стоило бы для начала почитать как писать безопасные расширения:

https://cmscafe.ru/razrabotka/547-sozdaem-bezopasnye-rasshireniya-dlya-joomla

спасибо, изучаю!
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

SQL запрос с JOIN LEFT use IN

Автор platonische

Ответов: 12
Просмотров: 822
Последний ответ 20.10.2017, 10:57:08
от platonische
SQL запрос в оператором OR в where

Автор platonische

Ответов: 18
Просмотров: 1347
Последний ответ 30.11.2016, 18:26:47
от zomby6888
Sql запрос JOIN и LIMIT

Автор platonische

Ответов: 6
Просмотров: 1261
Последний ответ 06.04.2016, 14:31:09
от zomby6888
Внешняя БД и вывод в определенное место на сайте

Автор Pavel8289

Ответов: 5
Просмотров: 1062
Последний ответ 12.12.2015, 03:26:42
от Филипп Сорокин
Стандартный поиск по собственному компоненту

Автор platonische

Ответов: 1
Просмотров: 905
Последний ответ 03.11.2015, 20:41:25
от voland