source: branches/version-2_12-dev/data/class/helper/SC_Helper_Plugin.php @ 21681

Revision 21681, 9.8 KB checked in by h_yoshimoto, 12 years ago (diff)

#1692 SC_Helper_Pluginをエンジン部分とプラグイン用Util系クラスに分離

  • Property svn:eol-style set to LF
  • Property svn:keywords set to Id
  • Property svn:mime-type set to text/x-httpd-php; charset=UTF-8
Line 
1<?php
2/*
3 * This file is part of EC-CUBE
4 *
5 * Copyright(c) 2000-2012 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24/**
25 * プラグインのヘルパークラス.
26 *
27 * @package Helper
28 * @version $Id$
29 */
30class SC_Helper_Plugin {
31    // プラグインのインスタンスの配列.
32    var $arrPluginInstances = array();
33    // プラグインのアクションの配列.
34    var $arrRegistedPluginActions = array();
35    // プラグインのIDの配列.
36    var $arrPluginIds = array();
37    // HeadNaviブロックの配列
38    var $arrHeadNaviBlocsByPlugin = array();
39
40    /**
41     * 有効なプラグインのロード. プラグインエンジンが有効になっていない場合は
42     * プラグインエンジン自身のインストール処理を起動する
43     *
44     * @return void
45     */
46    function load($plugin_activate_flg = true) {
47
48        if (!defined('CONFIG_REALFILE') || !file_exists(CONFIG_REALFILE)) return; // インストール前
49        if (GC_Utils_Ex::isInstallFunction()) return; // インストール中
50        if ($plugin_activate_flg === false) return;
51        // 有効なプラグインを取得
52        $arrPluginDataList = SC_Plugin_Util_Ex::getEnablePlugin();
53        // pluginディレクトリを取得
54        $arrPluginDirectory = SC_Plugin_Util_Ex::getPluginDirectory();
55        foreach ($arrPluginDataList as $arrPluginData) {
56            // プラグイン本体ファイル名が取得したプラグインディレクトリ一覧にある事を確認
57            if (array_search($arrPluginData['plugin_code'], $arrPluginDirectory) !== false) {
58                // プラグイン本体ファイルをrequire.
59                require_once PLUGIN_UPLOAD_REALDIR . $arrPluginData['plugin_code'] . '/' . $arrPluginData['class_name'] . '.php';
60
61                // プラグインのインスタンス生成.
62                $objPlugin = new $arrPluginData['class_name']($arrPluginData);
63                // メンバ変数にプラグインのインスタンスを登録.
64                $this->arrPluginInstances[$arrPluginData['plugin_id']] = $objPlugin;
65                $this->arrPluginIds[] = $arrPluginData['plugin_id'];
66                // ローカルフックポイントの登録.
67                $this->registerLocalHookPoint($objPlugin, $arrPluginData['priority']);
68                // スーパーフックポイントの登録.
69                $this->registerSuperHookPoint($objPlugin, HOOK_POINT_PREPROCESS, 'preProcess', $arrPluginData['priority']);
70                $this->registerSuperHookPoint($objPlugin, HOOK_POINT_PROCESS, 'process', $arrPluginData['priority']);
71            }
72        }
73    }
74
75    /**
76     * SC_Helper_Plugin オブジェクトを返す(Singletonパターン)
77     *
78     * @return object SC_Helper_Pluginオブジェクト
79     */
80    function getSingletonInstance($plugin_activate_flg = true) {
81        if (!isset($GLOBALS['_SC_Helper_Plugin_instance']) || is_null($GLOBALS['_SC_Helper_Plugin_instance'])) {
82            $GLOBALS['_SC_Helper_Plugin_instance'] =& new SC_Helper_Plugin_Ex();
83            $GLOBALS['_SC_Helper_Plugin_instance']->load($plugin_activate_flg);
84        }
85        return $GLOBALS['_SC_Helper_Plugin_instance'];
86    }
87
88    /**
89     * プラグイン実行
90     *
91     * @param string $hook_point フックポイント
92     * @param array  $arrArgs    コールバック関数へ渡す引数
93     * @return void
94     */
95    function doAction($hook_point, $arrArgs = array()) {
96        if (is_array($arrArgs) === false) {
97            array(&$arrArgs);
98        }
99
100        if (array_key_exists($hook_point, $this->arrRegistedPluginActions)
101            && is_array($this->arrRegistedPluginActions[$hook_point])) {
102
103            krsort($this->arrRegistedPluginActions[$hook_point]);
104            foreach ($this->arrRegistedPluginActions[$hook_point] as $priority => $arrFuncs) {
105
106                foreach ($arrFuncs as $func) {
107                    if (!is_null($func['function'])) {
108                        call_user_func_array($func['function'], $arrArgs);
109                    }
110                }
111            }
112        }
113    }
114
115    /**
116     * スーパーフックポイントを登録します.
117     *
118     * @param Object $objPlugin プラグインのインスタンス
119     * @param string $hook_point スーパーフックポイント
120     * @param string $function_name 実行する関数名
121     * @param string $priority 実行順
122     */
123    function registerSuperHookPoint($objPlugin, $hook_point, $function_name, $priority) {
124        // スーパープラグイン関数を定義しているかを検証.
125        if (method_exists($objPlugin, $function_name) === true) {
126            // アクションの登録
127            $this->addAction($hook_point, array($objPlugin, $function_name), $priority);
128        }
129    }
130
131    /**
132     * ローカルフックポイントを登録します.
133     *
134     * @param Object $objPlugin プラグインのインスタンス
135     * @param string $priority 実行順
136     */
137    function registerLocalHookPoint($objPlugin, $priority) {
138        // ローカルプラグイン関数を定義しているかを検証.
139        if (method_exists($objPlugin, 'register') === true) {
140            // アクションの登録(プラグイン側に記述)
141            $objPluginHelper =& SC_Helper_Plugin::getSingletonInstance();
142            $objPlugin->register($objPluginHelper, $priority);
143        }
144    }
145
146    /**
147     * プラグイン コールバック関数を追加する
148     *
149     * @param string   $hook_point フックポイント名
150     * @param callback $function   コールバック関数名
151     * @param string   $priority   同一フックポイント内での実行優先度
152     * @return boolean 成功すればtrue
153     */
154    function addAction($hook_point, $function, $priority) {
155        if (!is_callable($function)) {
156            // TODO エラー処理; コール可能な形式ではありません
157        }
158        $idx = $this->makeActionUniqueId($hook_point, $function, $priority);
159        $this->arrRegistedPluginActions[$hook_point][$priority][$idx] = array('function' => $function);
160        return true;
161    }
162
163    /**
164     * コールバック関数を一意に識別するIDの生成
165     *
166     * @param string   $hook_point フックポイント名
167     * @param callback $function   コールバック関数名
168     * @param integer  $priority   同一フックポイント内での実行優先度
169     * @return string コールバック関数を一意に識別するID
170     */
171    function makeActionUniqueId($hook_point, $function, $priority) {
172        static $filter_id_count = 0;
173
174        if (is_string($function)) {
175            return $function;
176        }
177
178        if (is_object($function)) {
179            $function = array($function, '');
180        } else {
181            $function = (array) $function;
182        }
183
184        if (is_object($function[0])) {
185            if (function_exists('spl_object_hash')) {
186                return spl_object_hash($function[0]) . $function[1];
187            } else {
188                $obj_idx = get_class($function[0]).$function[1];
189                if ( false === $priority)
190                    return false;
191                $obj_idx .= isset($this->arrRegistedPluginActions[$hook_point][$priority])
192                         ? count((array)$this->arrRegistedPluginActions[$hook_point][$priority])
193                         : $filter_id_count;
194                $function[0]->wp_filter_id = $filter_id_count;
195                ++$filter_id_count;
196
197                return $obj_idx;
198            }
199        } else if (is_string($function[0])) {
200            return $function[0].$function[1];
201        }
202    }
203
204    /**
205     * ブロックの配列から有効でないpluginのブロックを除外して返します.
206     *
207     * @param array $arrBlocs プラグインのインストールディレクトリ
208     * @return array $arrBlocsサイトルートからメディアディレクトリへの相対パス
209     */
210    function getEnableBlocs($arrBlocs) {
211        foreach ($arrBlocs as $key => $value) {
212            // 有効なpluginのブロック以外.
213            if (!in_array($value['plugin_id'] , $this->arrPluginIds)) {
214                // 通常ブロック以外.
215                if ($value['plugin_id'] != '') {
216                    // ブロック配列から削除する
217                    unset ($arrBlocs[$key]);
218                }
219            }
220        }
221        return $arrBlocs;
222    }
223
224   /**
225     * テンプレートのヘッダに追加するPHPのURLをセットする
226     *
227     * @param string $url PHPファイルのURL
228     * @return void
229     */
230    function setHeadNavi($url) {
231        $this->arrHeadNaviBlocsByPlugin[$url] = TARGET_ID_HEAD;
232    }
233
234    /**
235     * PHPのURLをテンプレートのヘッダに追加する
236     *
237     * @param array|null $arrBlocs  配置情報を含めたブロックの配列
238     * @return void
239     */
240    function setHeadNaviBlocs(&$arrBlocs) {
241        foreach ($this->arrHeadNaviBlocsByPlugin as $key => $value) {
242            $arrBlocs[] = array(
243                'target_id' =>$value,
244                'php_path' => $key
245            );
246        }
247    }
248}
Note: See TracBrowser for help on using the repository browser.