Yii + WordPress = <3, или Увлекательный эксперимент получения Франкенштейна

в 13:48, , рубрики: php, tutorial, wordpress, yii, yii framework, Блог компании DataArt, эксперименты

Всем привет. Я — Денис Мельский. Работаю PHP Developer в DataArt. Область моих профессиональных интересов — Web Development и Linux. Сегодня я хотел бы поговорить с вами о «скрещивании ежа с ужом».

image

Intro

На первый взгляд может показаться, что это безумство и, в некотором роде, архитектурный костыль. Но, если посмотреть с другой стороны, это один из вариантов выхода из часто встречающейся тупиковой ситуации: заказчик хочет WordPress и ничего другого не признает. Скорее всего, что-то он такое услышал, нагуглил, увидел, посоветовал сосед гуру кодер Джон (ну, или Вася).
А программисты наотрез отказываются натягивать на движок блога, с, мягко говоря, не самой лучшей архитектурой, функционал, допустим, интернет-магазина, форума, и вдобавок — REST API для партнёров этого магазина, и сверху — еще пачку кронов с бизнес-логикой.

Давайте поставим задачу найти такой выход, чтобы удовлетворить всех участников проблемы, и чтобы наш продукт заводился и нормально работал.

Один из вариантов, который я нашел проводя исследование, на эту тему— скрещивание WordPress и Yii.

Let the party begin

Что же, давайте попробуем осилить что-то из этого в коде.

Начнем со скачивания Yii framework. Думаю, composer для таких экспериментов — перебор — из-за кастомизации путей и архитектуры всей сборки у нас без композера будет больше возможностей для экспериментов, т. ч. спокойно качаем с родного сайта.

Ту же нехитрую манипуляцию производим с WP.

Далее вооружаемся вспомогательными мануалами:
Раз
Два

Идем по первому мануалу, к которому хочу добавить несколько замечаний и комментариев.

Устанавливаем WP размещаем всё в такую архитектуру:
image

Для начала рассмотрим ключевые строки нашего index.php.

define(‘WP_USE_THEMES’, true);
$wp_did_header = true;
require_once(‘wordpress/wp-load.php’);

Тут мы можем наблюдать начало подключения WP в общую картину происходящего.

Создаем класс Exception Handler, суть которого на 404 exception yii framework — передавать власть WP.

Делаем дефолтный .htaccess для Yii, который дает возможность делать красивые URL.

RewriteEngine on
# if a directory or a file exists, use it directly
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
# otherwise forward it to index.php
RewriteRule . index.php

Прописываем в конфиге Yii ‘showScriptName’ => false и раскоментируем дефолтные правила стоковой поставки.

Далее по вышеуказанному мануалу создаем WpController и View к нему.

Еще интересный момент, который нельзя обойти стороной: в wordpress конфигах на уровне DB есть настройка в табличке `wp_options`— “siteurl”, ее нужно поменять на yourdomain/wordpress. Также это можно поменять в админке WP
Settings -> General -> WordPress Address (URL).

Не могу не упомянуть интересный момент: в main layout Yii размещаем структуру внутренности нашей темы из WP.

Yii + WordPress = &lt;3, или Увлекательный эксперимент получения Франкенштейна

Мы уже близки к победе: подключаем gii (кто не в курсе почитать можно тут).

В gii мы можем и создать модель CRUD, и получить на выходе собственно то, что хотели — скрещенный код Yii и WP.

Yii + WordPress = &lt;3, или Увлекательный эксперимент получения Франкенштейна

It's alive!

На этом скрине мы можем наблюдать красивый CRUD из Yii с использованием CGridView.

Для авторизации везде попробуем вот такой метод.

В корне создаем папку wordpress и переносим туда внутренности самого WP.

По итогу моего ресеча на тему получаем такие выводы:

  • Frontend WP пропускать через Yii очень даже можно с подстройкой темы и в итоге у нас могут получаться кастомные модули на Yii, которые гармонично будут жить вместе с WP. К тому же, есть возможность синхронизации юзеров из WP в Yii.
  • Backend WP соединить с Yii гармонично у меня не получилось, т. е. общая админка для стандартных модулей WP и кастомных модулей Yii — не самый лучший вариант реализации. Обусловлено это тем, что в backend-e WP очень нестандартная архитектура не сильно подходящая для интеграции. Но это — результаты моего ресёрча, не претендующие на истинность в последней инстанции.
  • По итогу мы можем разработать приложение где будет гармонично сочетаться frontend WP с кастомными модулями Yii. В backend WP мы можем разрабатывать кастомные плагины и как один из вариантов реализации подгружать Yii. И даже, не побоюсь этого варианта, рендерерить некоторые модули Yii через iframe внутри WP плагина.

P.S. Хочу пожелать всем правильного выбора инструментов для решения определённого спектра задач, для которого они созданы, но и не терять азарта эксперементаторства

P.P.S. Немного линков на тему:

Примеры схожих подходов для реализации задумки в некоторых так же используются немного другие кастомизации yii.

www.yiiframework.com/wiki/382/integrating-wordpress-and-yii-working-out-the-details/

www.yiiframework.com/wiki/322/integrating-wordpress-and-yii-still-another-approach-using-yii-as-the-router-controller/

www.yiiframework.com/wiki/213/integrating-wordpress-and-yii-yet-another-approach/

www.yiiframework.com/wiki/202/integrating-yii-with-wordpress/

www.yiiframework.com/wiki/144/run-an-yii-application-inside-an-wordpress-page/

Автор: DataArt

Источник

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js