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

Aeliot

  • Захожу иногда
  • 107
  • 2 / 0
Как зная имя права на определенное действие (например, "core.edit" - указывается в файле access.xml)
найти все группы, имеющие право на совершение данного действия в компоненте.
« Последнее редактирование: 20.10.2013, 19:58:43 от Aeliot »
*

Aleks.Denezh

  • Живу я здесь
  • 3401
  • 428 / 4
Можно спросить зачем это понадобилось?
*

Aeliot

  • Захожу иногда
  • 107
  • 2 / 0
Можно спросить зачем это понадобилось?
Можно.
Есть компонент. В нем материалы. И есть пользователи, имеющие право (и обязанные) совершать определенные действия над материалами. Пользователи имеют доступ не ко всем материалам, а только к материалам, имеющим определенный уровень доступа. И есть другие пользователи, имеющие доступ к тем же материалам, но обязанные совершать над материалами другие действия (после того, как первые выполнили свою работу).
Нужно настроить автоматическую рассылку уведомлений пользователям о появлении материалов определенного рода.

Поскольку ИД-ы групп и уровней доступа на сайте нам не известны заранее. Единственное, что нам доподлинно известно - это имя действия, то, зная его, хочу построить всю иерархию доступа к материалам и отправить уведомления только тем, кому действительно нужно их отправлять.

Надеюсь, что не слишком сложно объяснил :)
*

Aeliot

  • Захожу иногда
  • 107
  • 2 / 0
Кстати, покопавшись в Joomla, уже навоял функцию (см. ниже), но возможно есть более простой способ
Код
	/**
* Получаем массив групп, имеющих право на совершение действия.
*
* @param string $action Action in component
* @param string $component Name of component
* @return array
*/
private static function getGroupsWithAccess($action, $component)
{
// Получаем список действий для компонента.
$actions = JAccess::getActionsFromFile(
JPATH_ADMINISTRATOR . '/components/'.$component.'/access.xml',
'/access/section[@name=\'component\']/');

$match = false;

// проверяем есть ли искомое действие у компонента
foreach ($actions as $act)
{
// Устанавливаем доступы пользователя для действий.
if ($act->name = $action){
$match = true;
break;
}
}

if(!$match) return null;

$db = self::getDbo();
$query = $db->getQuery(true);

// Need to find the asset id by the name of the component.
$query->select($db->quoteName('id'));
$query->from($db->quoteName('#__assets'));
$query->where($db->quoteName('name'). ' = ' . $db->quote('com_workteam'));

// Get the asset id of the content.
$assetId = (int) $db->setQuery($query)->loadResult();

// Get the rules for just this asset (non-recursive).
$assetRules = JAccess::getAssetRules($assetId);

$query->clear();
$query->select('a.id AS value, a.title AS text, COUNT(DISTINCT b.id) AS level, a.parent_id');
$query->from('#__usergroups AS a');
$query->leftJoin($db->quoteName('#__usergroups'). ' AS b ON a.lft > b.lft AND a.rgt < b.rgt');
$query->group('a.id, a.title, a.lft, a.rgt, a.parent_id');
$query->order('a.lft ASC');

// Get a list of the user groups.
$groups =  $db->setQuery($query)->loadObjectList();

$groupsAllowed = array();

// обходим группы
foreach ($groups as $group)
{
// проверяем наследование прав на действие
$inheritedRule = JAccess::checkGroup($group->value, $action, $assetId);

// Get the actual setting for the action for this group.
$assetRule = $assetRules->allow($action, $group->value);

// This is where we show the current effective settings considering currrent group, path and cascade.
// Check whether this is a component or global. Change the text slightly.
if (JAccess::checkGroup($group->value, 'core.admin', $assetId)!== true)
{
if ($inheritedRule === null) {
// NOT_ALLOWED
}
elseif ($inheritedRule === true){
// ALLOWED
$groupsAllowed[] = $group->value;
}
elseif ($inheritedRule === false){
if ($assetRule === false) {
// NOT_ALLOWED
}
elseif ($assetRule === true) {
// ALLOWED
$groupsAllowed[] = $group->value;
}
else {
// NOT_ALLOWED_LOCKED
}
}
}
else {
// ALLOWED_ADMIN
$groupsAllowed[] = $group->value;
}
}

return $groupsAllowed;
}
« Последнее редактирование: 20.10.2013, 22:13:49 от Aeliot »
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Вывести иконки в списке пользователей

Автор Aeliot

Ответов: 0
Просмотров: 1158
Последний ответ 01.02.2014, 00:06:44
от Aeliot
[Решено] Как получить имя группы пользователей по id?

Автор nonamez

Ответов: 1
Просмотров: 2405
Последний ответ 23.10.2012, 10:19:14
от smart
Добавление нового пользователя в группы

Автор nonamez

Ответов: 2
Просмотров: 1511
Последний ответ 22.10.2012, 14:55:03
от nonamez