Новости Joomla

👩‍💻 ИИ-админ для Joomla ближе, чем вы думаете: Joomla MCP.

👩‍💻 ИИ-админ для Joomla ближе, чем вы думаете: Joomla MCP.

В февральском номере Joomla Community Magazine в статье Evolving Joomla - Joomla CMS MCP Server: Opening the Door to AI-Powered Administration рассказывается о работе команды разработчиков над внедрением в ядро Joomla MCP-сервера.

Что такое MCP-сервер?
Последние годы всех захватывает бум ИИ-технологий. Появились ИИ-агенты - программы, устанавливаемые на сервер или компьютер, которые получают от вас запрос или задачу в человеческом виде и могут выполнять действия с файлами, ходить по сайтам, создавать сайты, программировать и т.д. Люди используют ИИ-агентов в самых разных ситуациях: от написания и проверки кода (даже там, где язык программирования не знаете совсем) до планирования путешествий и бронирования гостиницы.

ИИ-агенты могут использовать различные программные инструменты по протоколу Model Context Protocol (MCP). Для этого разработчик программы должен внедрить MCP в свой продукт или сервис. Так, например, ваш ИИ-агент может ходить по сайтам через браузер и собирать нужную информацию, управляя браузером через MCP-сервер. Или использовать функционал IDE PHP Storm для написания кода, сбора и отладки ошибок, использовать поиск PHP Storm по кодовой базе, а не простой текстовый поиск по файлам. MCP предоставляет набор функций для полноценного управления программным обеспечением.

В случае с Joomla, сервер MCP может предоставить администраторам следующие возможности:
- Автоматическое создание категорий, материалов и меню на основе карты сайта или PDF-файла.
- Создавайть SEO-оптимизированные заголовки и метаописания в пакетном режиме.
- Обновлять расширения на нескольких сайтах одновременно
- Создание посадочные страницы.

Важно отметить, что сервер MCP не задумывался как функция, доступная только «супер-администраторам». Цель инициативы — создать решение, которое будет простым в настройке, маломощным и доступным для широкого круга пользователей.

В процессе разработки точка входа Joomla (аналогично Site, Administrator, Api, Cli), которая будет работать с Streamable HTTP, необходимым для MCP. Аутентификация пока что предполагается на токенах, но затем планируется создание универсального OAuth-сервера для Joomla.
Фактические возможности MCP — инструменты, ресурсы и подсказки — реализованы в виде плагинов для обеспечения расширяемости. Таким образом ожидаем, что и сторонние разработчики смогут создавать MCP-плагины для внедрения поддержки своих расширений Joomla для работы с ИИ.

@joomlafeed

Вышли релизы безопасности Joomla 6.0.4 и Joomla 5.4.4

Релиз безопасности Joomla 6.0.4 и Joomla 5.4.4

Проект Joomla! рад сообщить о выходе Joomla 6.0.4 и Joomla 5.4.4. Это релизы безопасности и исправления ошибок для серий 5.x и 6.x.

0 Пользователей и 1 Гость просматривают эту тему.
  • 4 Ответов
  • 820 Просмотров
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Всем привет!
На Joomla 2.5.28 и JoomShopping 3.11.4 я делал порядок сортировки товаров на сайте по новому полю в Производителях (числовое поле). Но делал это через правку ядра. Все работало. Результатом всего этого было то, что, товары определенного производителя сортировались в зависимости от значения этого поля. То есть, я мог легко товары определенного производителя поднять на самый верх, либо выводить после товаров другого определенного производителя. Чем ниже значение, тем выше товары этого производителя. Что делал:

1. Создал поле "Порядок сортировки товаров" в шаблоне /administrator/components/com_jshopping/views/manufacturer/tmpl/edit.php
2. Создал поле в БД в таблице #__jshopping_manufacturers
2. В файле /administrator/components/com_jshopping/controllers/manufacturers.php в методе save(); дописал:
Код
$post['мое_новое_поле_'.$lang->language] = JRequest::getVar('мое_новое_поле'.$lang->id,'','post',"string", 2);
3. В файле /components/com_jshopping/tables/manufacturer.php в методе getDescription(); добавил:
Код
$мое_новое_поле = $lang->get('мое_новое_поле');
$this->мое_новое_поле= $this->$мое_новое_поле;
4. В файле /components/com_jshopping/lib/jtableauto.php в методе getBuildQueryOrderListProduct(); написал:
Код
$order_query = "ORDER BY `мое_новое_поле_ru-RU` ASC, man.`name_ru-RU`, pr_cat.product_ordering ASC";

Все отлично работало.

Теперь у меня Joomla! 3.9.23 и JoomShopping 4.18.5. На этот раз пытаюсь сделать через плагин, и ничего не выходит. Что делал?
1. Плагин при установке создает новую таблицу #__jshopping_manufacturers_extra_fields, где есть id производителя, название и значение этого нового поля
2. В шаблоне /administrator/templates/isis/html/com_jshopping/manufacturer/edit.php создал это поле
3. В плагине:
Код
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$order_query = "ORDER BY мое_новое_поле ASC, name, pr_cat.product_ordering ASC";
}
}
В базу поле сохраняется, в админке выводится, тут все ок. Но на сайте выдает ошибку: 1054 Unknown column 'мое_новое_поле' in 'order clause'

Что я делаю не так?
Заранее благодарен.
« Последнее редактирование: 26.12.2020, 11:21:13 от Ragnarok »
*

kit2m2

  • Живу я здесь
  • 3373
  • 276 / 0
  • Беру сайты на полное сопровождение
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
Расширения для JoomShopping | Ссылка на Телеграм-канал | Сайты и магазины под ключ: Дизайн, Верстка, Программирование (расширения на заказ), СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ (5+) и JoomShopping 5+
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Что это вообще такое pr_cat.product_ordering? Судя по псевдониму - pr_cat - это обращение к таблице #__jshopping_products_to_categories в которой нет "вашего поля".

В сообщении Вам ясно написано: Не соблюдено условие для сортировки
А откуда берутся эти псевдонимы? Как узнать, какой псевдоним у определенной таблицы?
*

kit2m2

  • Живу я здесь
  • 3373
  • 276 / 0
  • Беру сайты на полное сопровождение
А откуда берутся эти псевдонимы?
Они задаются в запросе к таблице при выборки данных для страницы (смотреть нужно в ядре компонента, как формируется запрос)

Подробнее о псевдонимах здесь
Расширения для JoomShopping | Ссылка на Телеграм-канал | Сайты и магазины под ключ: Дизайн, Верстка, Программирование (расширения на заказ), СЕО-оптимизация, Сопровождение, Перенос на Joomla 4+ (5+) и JoomShopping 5+
*

Ragnarok

  • Захожу иногда
  • 64
  • 1 / 0
Методом научного тыка решил вопрос следующим образом. В плагине:
Код
<?php
defined( '_JEXEC' ) or die;

class plgJshoppingproductsManufacturers_Extra_Fields extends JPlugin {

function __construct(&$subject, $config){
parent::__construct($subject, $config);
}

public function onBeforeEditManufacturers(&$view){
$мое_новое_поле = $man_extra[$view->manufacturer->manufacturer_id]->мое_новое_поле;
$view->manufacturer->мое_новое_поле = $мое_новое_поле;
}

public function onBeforeSaveManufacturer(&$post){
$мое_новое_поле = $post['мое_новое_поле'];

$db = JFactory::getDbo();
$query = "INSERT INTO `#__jshopping_manufacturers_extra_fields` (`man_id`, `man_name`, `мое_новое_поле`)
VALUES ('".$man_id."', '".$man_name."', '".$мое_новое_поле."')
ON DUPLICATE KEY UPDATE `man_id` = '".$man_id."', `man_name` = '".$man_name."', `мое_новое_поле` = '".$мое_новое_поле."'";
$db->setQuery($query);
$db->query();
}

public function onBuildQueryOrderListProduct($order, $orderby, &$adv_from, &$order_query, $order_original){
$adv_from = " LEFT JOIN `#__jshopping_manufacturers_extra_fields` AS mef ON prod.product_manufacturer_id = `man_id`";
$order_query = "ORDER BY mef.мое_новое_поле ASC, mef.man_name ASC, pr_cat.product_ordering ASC";
}
}
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Плагин уведомлений о заказах в телеграмм для JoomShopping

Автор thevaca

Ответов: 0
Просмотров: 2802
Последний ответ 10.11.2025, 14:11:40
от thevaca
WT JoomShopping Favorite - кнопки избранного в категории товаров и карточке тов

Автор sergeytolkachyov

Ответов: 26
Просмотров: 39152
Последний ответ 14.10.2025, 12:54:56
от sergeytolkachyov
Модуль карусели товаров JoomShopping на Swiper.js для Joomla

Автор sergeytolkachyov

Ответов: 2
Просмотров: 4057
Последний ответ 04.07.2025, 10:30:36
от sergeytolkachyov
[Решено] Сбросить счётчик ID товаров JoomShopping

Автор goga_pgasovav

Ответов: 3
Просмотров: 2517
Последний ответ 13.02.2025, 00:11:20
от goga_pgasovav
Плагин обновления цен и остатков товаров JoomShopping из CSV

Автор sergeytolkachyov

Ответов: 0
Просмотров: 2676
Последний ответ 24.12.2024, 14:50:42
от sergeytolkachyov