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

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Модифицировал VirtueMart, добавил дополнительные страницы.
Так вот на одной из них у меня загвоздка.

Как правильно сделать вложенный цикл и вывести данные?

То есть, на странице должна быть такая таблица:

Заказ    Дата                         Сумма             Скидка    Доставка    Сумма к оплате       Статус
№17      12 января 2009 года      18 711 руб.    15%          300 руб.   20 011 руб.                В обработке

А под ней подробные данные о заказе:

фото 1, характеристика товара 1, цена 1
фото 2, характеристика товара 2, цена 2

Если таких заказов два и больше, соответственно под этой таблицей должна появиться ещё одна такая же таблица для второго заказа.

Предполагаю, что здесь нужен вложенный цикл.
for {

     for{

         }
    }

Пытался сделать что-то в этом роде.


       $user =& JFactory::getUser();
       $db =& JFactory::getDBO();
       $query = 'SELECT order_id AS oid, cdate AS cd, order_subtotal AS ost, order_discount AS od, order_shipping AS osh, order_total AS ot, SUM( order_subtotal ) AS sum_ost, SUM( order_discount ) AS sum_od, SUM( order_shipping ) AS sum_osh, SUM( order_total ) AS sum_ot FROM `jos_vm_orders` WHERE `user_id` = "131" AND `order_status` =  "ЗО" OR  `order_status` =  "ОД" group by cdate';
       $db->setQuery($query);
       $rows = $db->loadObjectList();
 
       foreach ( $rows as $row )



Помогите реализовать данный цикл на php. Своими силами и знаниями не получается.
Заранее спасибо!
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
на выходе получается массив из строк, где повторяются данные номер заказа, дата, сумма и характеристики. При этом если в заказе два товара - строк 2, если три - 3 и так далее?
Если да, то я бы делал элементарно (недавно так в одном модуле прекрасно заработало)
делаем счетчиком
Код: php
$i = '0';
foreach ( $rows as $row ) {
 if ($i == '0') {
 echo 'Поля из запроса, которые отвечают за основную информацию о заказе';
 } else {
 echo 'фото 1, характеристика товара 1, цена 1';
 }
$I++;
}
То есть первой строкой мы показываем только основные информации и эта строка у нас будет на выходе одна, остальными выводим столько строк сколько и подробных данных
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Спасибо! Всё работает.  :D :D :D
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Поспешил я сказать, что всё работает.
Первое echo выводится как положено, а echo в else не выводится.
Здесь получается, если i будет не равно 0, только тогда срабатывает else.

Может что-то в этом роде сделать?
Код
<?php
$i = '0';
$k = '0';
foreach ( $rows as $row ) {
if ($i == '0') {
 echo $row->значения. 'Поля из запроса, которые отвечают за основную информацию о заказе';
    }
$I++;
elseif ($k == '0') {
 echo '$row->фото 1, характеристика товара 1, цена 1';
        break;
    }
}
endforeach;
?>

То есть два цикла получается.
1 выводит Поля из запроса, которые отвечают за основную информацию о заказе
2 фото 1, характеристика товара 1, цена 1
      фото 2, характеристика товара 2, цена 2

1 выводит Поля из запроса, которые отвечают за основную информацию о заказе2
2-й фото 1, характеристика товара 1, цена 1
      фото 2, характеристика товара 2, цена 2
« Последнее редактирование: 31.12.2009, 04:40:47 от dmonco »
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
Прошу прощения, оказывается соврал, в своем модуле делал немного по другому
Код: php
$i = 0;
foreach ( $rows as $row )
{
if ($i == '0') {
    echo 'Первая строка';
} else {}
$i++;
}
$ii = 0;
foreach ( $rows as $row2 )
{
if ($ii != '0') {
    echo 'прочие строки';
} else {}
$ii++;
}
Сейчас смотрю с ужасом и не понимаю зачем я так делал, но то что работало - помню точно. Суть аналогична, пример на сайте в модуле новостей, первый материал выводится полностью с картинкой и текстом, остальные 3-5 только заголовками, все это дело получается из одного запроса
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Я уже так пробовал. Не вышло.  >:(

Структура страницы такая:

Таблица 1 (которая не повторяется, а выводится один раз)

Таблица 2 //здесь общая информация заказа
(начало)

  Таблица 3 //подробные данные заказа

Таблица 2 //здесь продолжение общей информации о заказе
(конец)

..вроде должно было работать  :'(
*

dmonco

  • Осваиваюсь на форуме
  • 28
  • 0 / 0
  • http://dmitryboruk.com
Может дело в запросе в базу?

У меня на каждый foreach свой запрос:
1       
 
Код
$user =& JFactory::getUser();
$db =& JFactory::getDBO();
$query = 'SELECT order_id AS oid, cdate AS cd, order_subtotal AS ost, order_discount AS od, order_shipping AS osh, order_total AS ot, order_status AS ostat, SUM( order_subtotal ) AS sum_ost, SUM( order_discount ) AS sum_od, SUM( order_shipping ) AS sum_osh, SUM( order_total ) AS sum_ot FROM `jos_vm_orders` WHERE `user_id` = '.$auth['user_id'].' AND `order_status` =  "ЗО" OR  `order_status` =  "ОД" group by cdate';
$db->setQuery($query);
$rows = $db->loadObjectList();
     

2
Код
$user =& JFactory::getUser();
$db2 =& JFactory::getDBO();
$query2 = 'SELECT i.order_id, i.order_item_name AS item, o.order_id, o.user_id FROM jos_vm_order_item AS i INNER JOIN jos_vm_orders AS o ON i.order_id = o.order_id WHERE o.user_id = '.$auth['user_id'].' group by i.order_item_name';
$db2->setQuery($query2);
$rows2 = $db2->loadObjectList()
*

beliyadm

  • Легенда
  • 9758
  • 1665 / 66
  • Севастополь, Россия
мне трудно дать внятное решение не зная какие именно данные находятся в таблицах и выбираются запросами
Все истины, которые я хочу вам изложить, — бесстыдная ложь. Сделать всё хорошо
TLG: @Beliyadm
Чтобы оставить сообщение,
Вам необходимо Войти или Зарегистрироваться
 

Как заставить Joomla 1.5 работать на сервере с MySQL версии 5.7 и выше?

Автор Palomnik

Ответов: 14
Просмотров: 9686
Последний ответ 01.10.2024, 00:22:40
от jesus
перенесенная Joomla не видит MySQL - в логах MySQL старт нормальный

Автор ommy

Ответов: 23
Просмотров: 6341
Последний ответ 23.01.2018, 11:20:48
от altvvc
MAMP и MySQL

Автор boq

Ответов: 7
Просмотров: 6334
Последний ответ 08.01.2017, 02:25:47
от SeBun
The MySQL adapter "mysqli" is not available

Автор inko_gnito

Ответов: 13
Просмотров: 37821
Последний ответ 27.09.2016, 20:58:27
от lukinalek
[Решено] Unable to connect to the database:Could not connect to MySQL

Автор dircell

Ответов: 82
Просмотров: 171749
Последний ответ 22.01.2016, 19:22:10
от Template_user