С Drupal была стянута идея использовать узлы(nodes) и я применил весь комплект опыта оставшегося от хакинга ядра решившись начать писать свою систему. Сейчас RevolveR уже достиг версии 1.9 и из его отличительных особенностей можно выделить подход к программированию. Все создано на чистом PHP SPL и не использована даже jQuery для frontend(ее роль выполняет созданный на ES7 движок front-end с поддержкой всех функций, которые могут пригодится при разработке; от поддержки CSS3 анимаций до автоматических HTML форм на fetch).
Поскольку Windows теперь использует Chromium для встроенного в систему Fetch — я могу считать, что framework созрел для публики. Из новенького, что мешало сделать нормальный релиз была не полная поддержка CSS4 variables, которые у меня в паре с View Port Unit формирует хитрый в 10 строчек кода алгоритм для масштабирования HTML элементов сайта под мобильные устройства, а также по примеру приложения может получить, но не отображает в строке URL GET запросы.
С помощью JS я определяю браузер пользователя и формирую scale factor являющийся множителем, чтобы отмасштабировать ссылки, кнопки, параграфы и другие элементы требующие увеличенного размера для смартфонов, чтобы пользователю было удобнее. Я подошел к реализации Front-end с той же стороны, что и подходят разработчики приложений операционной системы: никаких Media Queries не используется вообще, а сайты выглядят крупнее или мельче в зависимости от размера окна браузера без всяких прокруток.
Я еще полирую SPAx(Single Pages Application eXtended) интерфейс на VPU и могу сказать, что сэкономил себе два три дня тестирования верстки для мобильных устройств за счет scale-factor, который работает через CSS calc.
В идеале хочется получить возможность автоматического выпуска APK приложения использующего Web View для обращения к любому домену, где установлен фреймворк так, как SPAx интерфейс — это уже и есть фактически приложение для больших и маленьких экранов.
Что есть в системе сейчас?
Создана поддержка инсталлятора для хостинга (можно использовать Open Server минимальный). Поскольку это не совсем набор классов и futures для создания и нужды много программировать, CMF из коробки предлагает поддержку кабинета пользователя и ролей групп пользователей.
Contents Management Framework подразумевает также поддержку создания пользователем страниц и категоризация их включена в функционал. Фреймворк многоязычный (сейчас два языка интерфейса доступны Russian & English).
Реализована простая, но очень надежная captcha, которая работает для любых POST данных путем получения ключа и паттерна из набора рисунков независимо на каждый ROUTE специальным сервисом secure route через javascript fetch и https cookie. Рисунок создается в canvas и обвешан рядом isTrusted проверок.
Я добавил поддержку комментирования и возможность подписаться по Email на обновления контента и комментариев, если пользователь зарегистрировался — есть возможность установить себе аватарку, заполнить профиль, выбрать язык интерфейса индивидуально и писать личные сообщения.
Все формы и элементы навигации сайтов на RevolveR CMF работают в автоматическом Fetch режиме из последних релизов ECMA Script. API подразумевает удобный сборщик HTML форм и центральный валидатор данных, который связан с типом input указанном в HTML формы. Загружаемые пользователем файлы проходят на UNIX системах дополнительную проверку маски через xxd.
Вообще, если в RevolveR добавить комплекс поискового оснащения(переход по ссылкам и запись контента в базу данных) можно написать за пару дней простенький поисковик(все функции парсинга и поиска по БД уже реализованы). Нужно только указать модели в каких таблицах и каких столбцах осуществлять поиск по MySQL RegExp или тупо по статических кэшам запросов БД чтобы не грузить сервер сильно(сниппет сделан по мотивам поисковой выдачи Google), также вся система поддерживает BigInt данные.
В систему добавлен терминал, позволяющий выполнять bash команды операционной системы или консоли Windows(в планах научиться использовать Power Shell из PHP).
Оптимизация
Поскольку весь код писался на низкоуровневых функциях без сторонних библиотек и великолепно оптимизирован с участием кэша трех уровней:
- Сжатые CSS и JavaScript;
- Кэш шаблонизатора (свой шаблонизатор на Cache Conclude);
- Кэш запросов базы данных (если RevolveR не пишет статистику посетителей, то framework работает в режиме partial Kernel run и к базе для анонимного посетителя происходит 0 запросов).
Мне удалось достичь просто отличных цифр оптимизации: все ядром с шаблонами выполняется за доли секунды при этом тратиться памяти на сайт из 10 страниц порядка 3х мегабайт. Кроме того, front-end оптимизирован так, что позволяет в 240кб упакованного трансфера кода уместить и скрипты и рендер c бэкенда и даже остается место для иконок флагов всех стран на SVG и картинок интерфейса(подходит быстрой загрузки и отдачи в условиях с плохим интернетом).
Что в заключение?
Я написал пока только одно расширение для системы — модуль обратной связи, который прописывается в системные URL и позволяет отправлять feedback гостям с вложениями файлов, но планирую также создать модули форума и интернет магазина.
Если не учитывать базы данных IP адресов, которые используются для ведения статистики посещаемости сайта от Max Mind(БД весят 60Mb), то весь код весит 1.93 мегабайта(сравните с Drupal или Wordpress при схожем функционале). Писать на strict PHP SPL для меня было как вызов по супероптимизации кода.
Еще 2 мегабайта и я создам модули каталогизации страниц на подобие Wikipedia, форум и модуль интернет магазина.
Не спрашивайте почему я не использую composer и объекты в качестве сущностей для доставки данных к front-end. Я не могу объяснить мою ненависть к ООП, когда объекты жрут в 4 раза больше памяти и процессора, чем ассоциативные массивы. Возможно, они появятся позже в более высокоуровневых классах, а пока мой код выполняется за тысячные доли секунды даже на самом дешевом Linux хостинге и мне это поднимает самооценку.
Скорее всего данная система превратиться в CRM для магазина дверей и окон c модулем интернет магазина, где я работаю (уж очень мне не нравится 1C).
Прощу пощупать мою систему и высказаться по поводу программирования для себя, Open Source, простых людей людей, который нужен интерфейс и продвинутым, которые захотят программировать сами.
Стоит ли продолжать писать CRM на базе RevolveR CMF и сколько мне понадобится разработчиков через 5 лет (сейчас все тяну один)?
Ссылка репозитория на GitHub.
Для установки просто распакуйте последний release на хостинг или localhost и заполните данные админа, а также подключения к базе данных. При использовании Open Server достаточно создать базу данных с именем revolver и ввести в форму инсталлятора данные аккаунта администратора. RevolveR CMF поддерживает только PHP 7.4 и выше.
Будущие обновления до версии 2.0 подразумевают ручной alter таблиц базы данных если структуры базы данных будет расширена каким-то опциями (Чекбокс dashboard -> performance -> auto alter DB tables).
В версии 2.0 планируются визуальный конструктор структуры БД c созданием пользовательских HTML форм, которые будут автоматически связаны с моделями (там будет больше объектов для использования в шаблонизаторе), а пока применен свой паттерн псевдо-объектов на ассоциативных массивах и генераторах для получения максимальной производительности.
Об обновлениях можно будет узнать в группе Facebook так как пока до версии 2.0 самостоятельный update через админку не доступен (в 2.0 будет также вмонтирована документация по созданию своих расширений и использованию API моделей в админку).
NikitchenkoSergey
Ну если вам нужна обратная связь, держите немного критики:
Сейчас в вашем велосипеде никто не сможет никогда разобраться, да и не захочет.
Почему вы не взяли тот же Laravel и не сделали CMS на нем? Если бы вы реализовали крутую админку с готовыми модулями, может кому-то бы и пригодилось.
Я вам крайне рекомендую прекратить ненавидеть ОПП, ознакомиться с PSR, попробовать какой-нибудь хороший фреймворк типа Laravel, иначе вы так и останетесь в 2010 году.
Простите, если грубо написал.
Full-R Автор
А вы бы с проститутками сели кушать за один стол? Мне кажется ваша непритязательность и тяга к халяве лишь намекает о квалификации.
NikitchenkoSergey
Ну-ка, раскройте мысль про проституток. Мне даже интересно стало, как это все связано.
Full-R Автор
Раскрываю.
> не использовать composer в 2020, из этого вытекает следующий пункт
Чтобы в ядро не толкали код не соответствующий стандарту и не нарушали концепцию минимализма я не допускаю использование сомнительного парсера namespace и последующего шаринга по папкам. Код ваших автолоадов зачастую полное говно и не поддерживает strict types, что не допустимо в RevolveR.
В следующей версии появится API сборщика ядра. Это будет разбор config файла циклом и проход по указанным путям для регистрации частей Kernel c require. Это никогда не будет autoload в силу причин, которые я указал выше.
> Вы просто игнорируете опыт всего PHP сообщества не используя готовые, хорошо отлаженные компоненты. У вас даже QueryBuilder свой, если это вообще можно так назвать. 90% вашей CMS можно собрать из готовых пакетов, и это будет в 100 раз полезнее и удобнее.
Я также лишил framework ошибок всего сообщества PHP.
> У вас даже QueryBuilder
А это хорошо или плохо? Я использую модели для получения из базы и они кэшируют вместе с DataBaseX. Я вообще позволил разработчикам не писать SQL так как это решает модель на 100%.
> Почему вы не взяли тот же Laravel и не сделали CMS на нем?
Вы бы сели кушать с проститутками за один стол?
> смотря на ваш код, начал ностальгировать по 2010 году — никаких тебе PSR, никакого автолоада, куча непонятных массивов, магия. Действительно похоже на Drupal 7. Только ничего хорошего в этом нет.
Мой код новее, чем в D7 и в Laravel. Привыкайте. На носу 2020, а вы гнобите своих отечественных разработчиков по привычке, что они работать не умеют. Это вы живете в чужих парадигмах и работаете по чужой записке сами ни чего мне создавая.
Документация будет интегрирована с такой опцией, как визуальный конструктор моделей, который будет создавать и модель для доступа к данным и структуру базы данных и даже связывать с формами HTML. То есть вы сможете создать ноду, сервис к ней и просто создать трансфер необходимых данных с готовым интерфейсом в пару кликов по гайду. Документация в данном случае не пишется сразу из-за того, что Kernel меняется. Справка будет прямо в админке.
По поводу вашей квалификации уточняю:
> никаких тебе PSR, никакого автолоада, куча непонятных массивов, магия.
Если для вас 2 мегабайта оптимизированного под OpCode(RevolveR CMF реально не ускоряется опкодами потому что создан почти на опкодах) программирования магия — мне вас жаль. Продолжайте жрать память и процессор вместе с деньгами потребителя.
Я могу и на RPI запустится и в отпуске с NetBook на Intel Atom работать и мне все что нужно — это Sublime Text 3 и Open Server.
Так вот я вас спрашиваю — почему вы унижаете меня словами про Laravel. Вы просто как тролль залезли и хотели испортить мне настроение, а после этого еще сказали, что есть Французское но лучше и надо работать на нем. Я написал что создаю новый contents management framework, а не беру готовое у кого либо.
grayfolk
Наконец-то.
Наконец-то, появился разработчик, пишущий идеальный код, для которого даже не нужны тесты, подтверждающие это. Теперь заживем!
Странно, почему вы тогда берете готовый ЯП, а не пишете свой? Тяга к халяве?
grayfolk
Простите, не удержался.
Full-R Автор
И что вы со мной сделаете, когда будет в 20 раз круче чем у вас, но проще и новее? (: Будете шаблонные вопли про PSR, объекты, тесты и восхваления Laravel использовать?
grayfolk
Вопли пока что только у вас. Круче? Удачи вам. Я только за, чтобы создавалось что-либо, более крутое, чем есть.
P.S. Да, «Простите, не удержался.» — не вам, Full-R, адресовалось.