EC-CUBEのDBを「流れるインターフェース」でらくらく操作できる「ActiveCube」を開発しました
投稿者: miztaka, カテゴリ: EC-CUBE, PHP, Teeple2, tags: ec-cube, php, teeple2概要
EC-CUBEはここ数年勢いを増していてかなり認知度があがってきています。2.11.4も登場してスマートフォン向けのデザインが強化されるなど、機能も充実の一途です。そんななかプログラマーを悩ませるのは、「コードが酷い」ということ。。もう少しきれいなコードだったらカスタマイズしやすいのになあ。。何度そういうため息を漏らしたことでしょう。
こういった状況を少しでも改善していきたいと、まずはDB操作のコードを楽にするためのプラグインを開発しました。
「開発した」といっても弊社で公開している Teeple2 というフレームワークのORマッパーである TeepleActiveRecord をEC-CUBE用に移植しただけなのでたいした工数はかからずにできました。
使い方はほぼ http://code.google.com/p/teeple2/wiki/DatabaseIntro こちらに書いてあるやり方と同じです。(こちらではPDOは使っていません。)
下のコードは同梱したテストケースからの抜粋ですがこんな感じでなにをやっているか一目瞭然のコードがかけます。
$productList = Entity_DtbProductCategories::get() ->join('dtb_category') ->join('dtb_products') ->contains('dtb_category.category_name', 'なべ') ->contains('dtb_products.name', 'なべ') ->order('dtb_products.product_id') ->limit(10) ->offset(0) ->select(); $this->assertEquals('おなべレシピ', $result[0]->dtb_products->name);
ダウンロード
こちら から。(無料でご自由にお使いいただけます。)
セットアップ方法
配布しているアーカイブは以下のようにEC-CUBEのディレクトリ構成と同じ形になっていますので、そのまま配置してください。
(実行に必要なのは data/plugin/activecube 以下のみです。)
data |- plugin |- activecube test |- class |- activecube
次に data/require_classes.php の末尾に
require_once DATA_REALDIR . 'plugin/activecube/config.php';
と記述を追加してください。これだけで使えるようになります。
しくみ、注意点など
- lowlevelでは EC-CUBEの SC_Query クラスを使用しています。トランザクションの制御などはこちらを使用して行なってください。本ライブラリはあくまでSC_Queryのラップであり、SQLを組み立てやすくしたり、結果セットの扱いをオブジェクト階層構造で扱えるようにしたりしています。
- MySQL, 2.11版のみ用意しています。(私がMySQLしか使わないため。。) Postgresへの対応は少しの修正でできるのではないかと思います。
- Entityクラスにjoinの設定があります。間違っていたり足りなかったりした場合はここを修正するとよいです。
- Entityクラスに自由にドメインロジックを追加することができます。そのような使い方をすると便利かと思います。
- ログはEC-CUBEのsite.logに出力されるようになっています。ログレベルを変更したい場合はActiveRecord.php の 48行目あたりを修正してください。
- 本ライブラリはフリーで提供していますので、不具合等によるいかなる損害についても弊社では責任を負いません。自己責任でご利用をお願いします。