CMS. Админ-панель
12-02-2008Время чтения ~ 3 мин.PHP 30649
Потихонечку продвигаюсь со своей Maxsite CMS и уже занимаюсь админкой. Можно было бы наскоком прописать нужные функции и темплейт, но решил не спешить, и сделать так, чтобы админка была не вещью в себе, а выполняла лишь роль менеджера.
Подход, который я решил применить заключается в том, чтобы отказаться от тяжеловесных админских функций и перенести «физическую нагрузку» на плагины (или что-то аналогичное).
Получилась такая схема.
1. Вход в админку происходит по адресу http://site/admin/действие/параметры
2. «Действие» - это плагин или какая-то функция, которой передается управление. «Параметры» - с этим уже сама функция будет разбираться.
3. Сама же админка представляет собой html-темплейт, где прописаны четыре функции: mso_admin_header(), mso_admin_menu(), mso_admin_content(), mso_admin_footer(). Из названий понятно для чего они предназначены.
4. Теперь для того, чтобы вывести скажем настройки какого-либо плагина, мы просто вешаем (в плагине) хук на admin_content, а пункт меню добавлем как хук на admin_menu.
5. Таким образом подключить любой плагин к админке очень просто. Это буквально пара функций.
Конечно предстоит еще решить вопрос о дефолтных настройках/страницах, но в целом они ничем не будут отличаться от подключения тех же плагинов.
Следующая проблема с которой мне пришлось столкнуться - это админские функции по управлению базой. «Классический» подход заключается в том, чтобы наделать функций по управлению, создать html-формы и все это автоматом вызывать при входе в админ-панель.
Проблема здесь в том, что этих функций будет много и они будут между собой взаимосвязаны. Если нужно будет что-то изменить, то эта цепочка может протянуться очень далеко. В том же WordPress'е админка - это что-то невообразимое: огромное количество функций, которые не только переплетены между собой, но еще и тянутся к функциям в wp-include. Понятно, что изменить админку в WordPress очень и очень сложно. Всё, на что можно «позариться», так это смена css-стилей.
Лично мне такой подход не нравится, поскольку он очень сильно сужает рамки функциональности. Предположим нам нужно сделать страницу списка записей. В «классическом» варианте нам нужно было бы сделать отдельный php-файл, жестко его «прикрепить» к админке, написать все функции, выполнить SQL-запрос и выполнить форматирование полученных данных. Если пойти по такому пути, то неизбежно прийдем к «тяжелой» админке.
Теперь, предположим, появляется другой плагин, который выполняет примерно тоже самое, но выводит данные по-другому. В третьем случае мы хотим получить выборку данных для еще каких-то действий. Во всех этих случаях мы выполняем по сути одно и тоже действие - получение данных, а вот отображение может быть различным. Получается, что есть смысл унифицировать основные действия в системе, чтобы вызывать их одной функцией.
Таким механизмом является XML-RPC. В кратце я расскажу что это такое.
В XML-RPC есть две стороны: сервер и клиент. Сервер - это некий php-скрипт, который принимает входящие данные (запрос) и, согласно этому запросу, выполняет определенное действие (метод, функцию). Клиент в свою очередь - это обычный POST, только данные в нем передаются в виде XML-структуры. Например нам нужно получить список последних записей. В запросе мы указываем свой логин, пароль, название метода и количество записей. Отправляем этот запрос и в ответ получаем список последних записей.
Именно так работают оффлайн-клиенты (блог-клиенты). Как видите клиенту совершенно не обязательно знать все тонкости внутренней реализации методов. Все, что ему требуется, так это название метода и его параметры.
Теперь, перенеся эту технологию на нашу админку, мы получаем, что функция для админки должна просто-напросто сформировать XML-запрос к своему же серверу и получить необходимые данные.
Что же получается в итоге.
1. Админка не несет «тяжелых» функций.
2. Простое подключение любых плагинов к админке.
3. Перенос функций для визуального отображения данных в отдельные плагины.
4. Получение данных выполняется через универсальный XML-RPC.
5. В «комплекте» мы сразу же получили работу с блог-клиентами.
На долю самой админки выпадают помимо функции менеджера, еще и работа с разграничением доступа (роли, группы, права), базовые настройки плагинов (включение, отключение, деинсталяция), базовые настройки сайта (выбор шаблона, название, описание и т.п.), то есть только то, что входит в самый минимум: таблицы options и users.
а на чем пишете? простите за любопытство...
имхо, к вашему подходу хорошо подойдет такая вешь как CodeIgniter.
(это фреймворк такой на php)
Кстати, да. То, что ты описываешь - это же и есть фреймворк. Или даже Application Server :) Абстрагирование от физической структуры базы.
Господа, видимо, вы не читали предыдущих записей :). Максим как раз использует CodeIgniter.
Круто! Я тоже делаю CMS, но на своем ядре...:smile:
А меня интересует интерфейс. Фреймы используете? Ajax? Как справляетесь с модульностью и необходимостью что-нибудь интегрировать? :???:
а будет возможность систему потестить? Столько о ней пишите, что интересно стало посмотреть.
Довольно интересно, что админка умеет?
Почему бы тебе не выложить движок:smile:
КМСку в студию!:mad:
Версию, которая будут выложена, предназначена не для использования, а для разработчиков. Я вряд ли один справлюсь со всем (или это будет очень долго), поэтому сейчас занимаюсь прежде всего каркасом системы, как раз для того, чтобы сторонний разработчик мог без проблем подключить свой функционал. То же самое касается и админки. В ближайших планах доделать страницы плагинов, опций и авторизации и уже в таком виде выложу в открытый доступ.
Присоединяюсь к Артёму Курапову насчет интерфейса. Я пересмотрел кучу CMS-ок и пришел к выводу, что 90% из них не user-friendly. Если админка красивая и понятная, то это очень хорошо скажется на ее дальнейшем распространении. Реальный пример -- Wordpress.
Это все конечно интересно, но лично меня больше всего интересует насколько простой будет интеграция в готовые шаблоны, для человека далекого от php.
собственно да, хотелось бы посмотреть на итог работы
Максим, желаю успехов в твоем проекте! Уверен, получится отличная CMS.
Тёзка, я тоже жду, ну когда же... слюни то текут... уже до коленей. Я не сказал бы, что разработчик, но что знаю, тем помогу. Просто уже потестить хочеться.
Предлахаю принимать ставки на то скока боков будет выявлено после первого запуска. Выигравшему: бан))