/boke0ick_mecha

PHP製CMS

Primary LanguagePHP

ボケマリック機構

モダンなAPI実装を目指したPHP製CMSです。 Twig(PythonのJinjaと同じ文法のテンプレートエンジン)用のHTMLを用いてテーマを作成でき、 Markdownで記事を書くことができます。

設定ファイルを記述することでテーマやルーティングをページごとに細かく設定できる柔軟さが作者なりの売りです。

インストール方法

Composerを使う

# hogeディレクトリにプロジェクトを作成します
composer create-project boke0/boke0ick_mecha hoge

GitとComposerを使う

git clone https://github.com/boke0/boke0ick_mecha.git
cd boke0ick_mecha
composer install

ディレクトリ構造

.
├── Dockerfile
├── README.md
├── composer.json
├── composer.lock
├── contents ...記事のMarkdownや設定ファイルを置く場所
├── default.conf
├── docker-compose.yml
├── plugins ...プラグインをインストールする場所
├── public ...公開ディレクトリ
├── src ...本体ソースコード
├── static ...テーマに依存しない素材などを置く場所
├── themes ...テーマをインストールする場所
└── vendor

サイトの構造の設定

URL設計はcontents/struct.jsonに記述します。

[
    {
        "theme":"default",
        "routes":[
            {
                "path":"/",
                "type":"index"
            },
            {
                "path":"/about",
                "type":"about"
            }
        ]
    },
    {
        "theme":"hoge",
        "routes":[
            {
                "path":"/article/:id",
                "type":"article"
            },
            {
                "path":"/news/:id",
                "rule":"/n/files/:id"
                "type":"article"
            }
        ]
    }

]

上記の設定では、以下のようにルーティングされます

URLの例 テーマ 適用されるテンプレート 記事のパス
/ default index.tpl.html contents/__index.md
/about default about.tpl.html contents/about.md
/article/0001 hoge article.tpl.html contents/article/0001.md
/news/001 hoge article.tpl.html contents/n/files/001.md

例の用に、基本的にはURLと同じルールで記事ファイルを参照します。 例外的なルールを適用したい場合は、ruleディレクティブを指定してください。

contentsにおける参照先がディレクトリの場合は、そのディレクトリの__index.mdをロードします。

記事の投稿

記事はMarkdownを用いて記述してください。

このとき、HugoなどでもサポートされているYAML形式のFrontMatterを記述し、メタ情報を設定することができます。

---
title: タイトルhogehoge
date: 2020/1/24
---
こんちは

テーマのインストール

themes/ディレクトリにディレクトリごとコピーしてください。

プラグインのインストール

plugins/ ディレクトリにプラグインのディレクトリごとコピーしてください。 このとき、 plugins/<プラグイン名>/__construct.php というパスに __construct.php が設置されるようにしてください。

テーマ作成

テーマは themes/ ディレクトリ内にディレクトリを作成し、 その中にtwig用のHTMLテンプレートファイルを設置するだけで作成することができます。

テーマの公開

テーマのソースコードを公開したい場合は、 テーマのディレクトリごとGitで管理してしまうことをおすすめします。 そうすることで、利用者は themes/ ディレクトリ下でリポジトリをcloneするだけで利用を始めることができます。

テーマで独自の素材を利用したい場合は、テーマのディレクトリ内に素材を設置し、以下のURIを指定してください。

/asset?theme=<テーマ名>&filename=<ディレクトリ内のパス>

プラグイン開発

プラグインは plugins/ ディレクトリ内にディレクトリを作成し、 その中にPHPファイルを設置することで作成できます。

プラグインのディレクトリ内には、最低限 __construct.php を設置する必要があります。ボケマリック機構本体からはこのファイルが呼び出され、 このファイルに記述されている通りにプラグインの挙動を設定します。

デフォルトで設置されているSamplePluginを例に解説します。

<?php

namespace Boke0\Mechanism\Plugins\SamplePlugin;

use \Boke0\Mechanism\Api\Plugin;

$plugin=new Plugin();
$plugin->endpoint(SampleEndpoint::class);
$plugin->templateExtension(SampleTemplateExtension::class);

return $plugin;

プラグインの名前空間はPsr-4に従い、 Boke0\Mechanism\Plugins<プラグイン名> としてください。

このプログラム内で一つの Boke0\Mechanism\Api\Plugin クラスを継承したオブジェクトを作成し、 拡張機能を設定してオブジェクトを返却してください。

API使用

ボケマリック機構から提供されているAPIを紹介します。初版では、

  • 独自のエンドポイントの作成
  • テンプレートエンジンの拡張

の2つの機能が搭載されています。

エンドポイントの作成

任意のURLにおいて特定のクラスメソッドを実行するように設定することができます。

<?php

namespace Boke0\Mechanism\Plugins\SamplePlugin;
use \Boke0\Mechanism\Api\Endpoint;

/**
 * @path /sampleendpoint
 */
class SampleEndpoint extends Endpoint{
    public function handle($req,$args){
        $res=$this->createResponse();
        $body=$res->getBody();
        $body->write("Hello world!");
        return $res->withBody($body);
    }
}

エンドポイントを作成するときは、 Boke0\Mechanism\Api\Endpoint を継承したクラスを定義してください。

例のように、ドキュメントコメントでパスを設定しましょう。 パスだけでなく、リクエスト時のメソッドも設定することができます。

/**
 * @path /sampleendpoint/insert
 * @method POST
 */

クラスはPSR-15で定められているRequestHandlerインターフェースを実装している必要があります。 EndpointクラスにはPSR-7準拠のレスポンスオブジェクトを生成するメソッド Endpoint::createResponse($status_code,$reason); が定義されているので、これを呼び出してレスポンスを返却してください。

また、Endpoint::twig($filename,$placeholder,$status_code,$reason)メソッドを用いることで、Twigでテンプレートを描画したレスポンスを直接取得することができます。 ここで用いられるTwigはプラグインのディレクトリのtpl/ディレクトリを参照します。 また、csrf_field()関数をコールすることで、ボケマリック機構本体に適用されているCSRF対策を利用することができます。

プラグインのエンドポイントで独自の素材を利用したい場合は、/assetsディレクトリ内に素材を設置し、以下のURIを指定してください。

/asset?plugin=<プラグイン名>&filename=<assetsディレクトリ以下のパス>
<?php

namespace Boke0\Mechanism\Plugins\SamplePlugin;
use \Boke0\Mechanism\Api\Endpoint;

/**
 * @path /sampleendpoint
 */
class SampleEndpoint extends Endpoint{
    public function handle($req,$args){
        return $this->twig("sample.tpl.html");
    }
}

テンプレートはプラグインのディレクトリ内のtpl/ディレクトリのファイルを参照します。

テンプレートエンジンの拡張

ボケマリック機構内でレンダリング時に使用されるTwigに対し、 拡張機能(TwigExtension)を設定できます。 Twigでサポートされている拡張方法であればここでも適用することができます。 以下に、

{{ sample() }}

と実行すると

sample function this is

と表示されるテンプレートエンジン拡張の例を示します。

<?php

namespace Boke0\Mechanism\Plugins\SamplePlugin;
use \Boke0\Mechanism\Api\TemplateExtension;

class SampleTemplateExtension extends TemplateExtension{
    public function getFunctions(){
        return [
            new \Twig\TwigFunction("sample",function(){
                echo "sample function this is";
            })
        ];
    }
}

Twigの拡張を行うときは、 Boke0\Mechanism\Api\TemplateExtension クラスを継承したクラスを定義してください。

プラグインの公開

テーマのソースコードを公開したい場合は、 こちらもテーマと同様にGitを使用することをおすすめします。