source: branches/camp/camp-2_13-plugin/data/class/pages/admin/ownersstore/LC_Page_Admin_OwnersStore.php @ 22684

Revision 22684, 41.0 KB checked in by adachi, 11 years ago (diff)

#2181 なにかを修正

  • 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-2013 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// {{{ requires
25require_once CLASS_EX_REALDIR . 'page_extends/admin/LC_Page_Admin_Ex.php';
26
27/**
28 * オーナーズストア:プラグイン管理 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin_OwnersStore extends LC_Page_Admin_Ex
35{
36
37    // }}}
38    // {{{ functions
39
40    /**
41     * Page を初期化する.
42     *
43     * @return void
44     */
45    function init()
46    {
47        parent::init();
48        $this->tpl_mainpage = 'ownersstore/plugin.tpl';
49        $this->tpl_subno    = 'index';
50        $this->tpl_mainno   = 'ownersstore';
51        $this->tpl_maintitle = 'オーナーズストア';
52        $this->tpl_subtitle = 'プラグイン管理';
53    }
54
55    /**
56     * Page のプロセス.
57     *
58     * @return void
59     */
60    function process()
61    {
62        $this->action();
63        $this->sendResponse();
64    }
65
66    /**
67     * Page のアクション.
68     *
69     * @return void
70     */
71    function action()
72    {
73        // パラメーター管理クラス
74        $objFormParam = new SC_FormParam_Ex();
75        $mode = $this->getMode();
76        // パラメーター情報の初期化
77        $this->initParam($objFormParam, $mode);
78        $objFormParam->setParam($_POST);
79
80        switch ($mode) {
81            // インストール
82            case 'install':
83                $file_key = 'plugin_file';
84                $this->arrErr = $this->checkUploadFile($file_key);
85                if ($this->isError($this->arrErr) === false) {
86                    $archive_file_name = $_FILES[$file_key]['name'];
87                    // インストール処理.
88                    $this->arrErr = $this->installPlugin($archive_file_name, 'plugin_file');
89                    if ($this->isError($this->arrErr) === false) {
90                        // コンパイルファイルのクリア処理
91                        SC_Utils_Ex::clearCompliedTemplate();
92                        $this->tpl_onload = "alert('プラグインをインストールしました。');";
93                    }
94                }
95                break;
96            // 削除
97            case 'uninstall':
98                // エラーチェック
99                $this->arrErr = $objFormParam->checkError();
100                if ($this->isError($this->arrErr) === false) {
101                    $plugin_id = $objFormParam->getValue('plugin_id');
102                    $plugin = SC_Plugin_Util_Ex::getPluginByPluginId($plugin_id);
103                    $this->arrErr = $this->uninstallPlugin($plugin);
104                    if ($this->isError($this->arrErr) === false) {
105                        // TODO 全プラグインのインスタンスを保持したまま後続処理が実行されるので、全てのインスタンスを解放する。
106                        unset($GLOBALS['_SC_Helper_Plugin_instance']);
107                        // コンパイルファイルのクリア処理
108                        SC_Utils_Ex::clearCompliedTemplate();
109                        $this->tpl_onload = "alert('" . $plugin['plugin_name'] ."を削除しました。');";
110                    }
111                }
112                break;
113            // 有効化
114            case 'enable':
115                // エラーチェック
116                $this->arrErr = $objFormParam->checkError();
117                if ($this->isError($this->arrErr) === false) {
118                    $plugin_id = $objFormParam->getValue('plugin_id');
119                    // プラグイン取得.
120                    $plugin = SC_Plugin_Util_Ex::getPluginByPluginId($plugin_id);
121                    $this->arrErr = $this->enablePlugin($plugin);
122                    if ($this->isError($this->arrErr) === false) {
123                        // TODO 全プラグインのインスタンスを保持したまま後続処理が実行されるので、全てのインスタンスを解放する。
124                        unset($GLOBALS['_SC_Helper_Plugin_instance']);
125                        // コンパイルファイルのクリア処理
126                        SC_Utils_Ex::clearCompliedTemplate();
127                        $this->tpl_onload = "alert('" . $plugin['plugin_name'] . "を有効にしました。');";
128                    }
129                }
130                break;
131            // 無効化
132            case 'disable':
133                // エラーチェック
134                $this->arrErr = $objFormParam->checkError();
135                if ($this->isError($this->arrErr) === false) {
136                    $plugin_id = $objFormParam->getValue('plugin_id');
137                    // プラグイン取得.
138                    $plugin = SC_Plugin_Util_Ex::getPluginByPluginId($plugin_id);
139                    $this->arrErr = $this->disablePlugin($plugin);
140                    if ($this->isError($this->arrErr) === false) {
141                        // TODO 全プラグインのインスタンスを保持したまま後続処理が実行されるので、全てのインスタンスを解放する。
142                        unset($GLOBALS['_SC_Helper_Plugin_instance']);
143                        // コンパイルファイルのクリア処理
144                        SC_Utils_Ex::clearCompliedTemplate();
145                        $this->tpl_onload = "alert('" . $plugin['plugin_name'] . "を無効にしました。');";
146                    }
147                }
148                break;
149            // アップデート.
150            case 'update':
151                // エラーチェック
152                $this->arrErr = $objFormParam->checkError();
153                if ($this->isError($this->arrErr) === false) {
154                    $plugin_id = $objFormParam->getValue('plugin_id');
155                    $plugin = SC_Plugin_Util_Ex::getPluginByPluginId($plugin_id);
156                    $target_plugin_code = $plugin['plugin_code']; // アップデート対象のプラグインコード
157                    $this->arrErr = $this->checkUploadFile($target_plugin_code);
158
159                    if ($this->isError($this->arrErr) === false) {
160                        $update_plugin_file = $_FILES[$target_plugin_code];
161                        $update_plugin_file_name = $update_plugin_file['name']; // アップデートファイルのファイル名.
162                        // インストール処理.
163                        $target_plugin = SC_Plugin_Util_Ex::getPluginByPluginCode($target_plugin_code);
164                        $this->arrErr = $this->updatePlugin($target_plugin, $update_plugin_file_name, $target_plugin_code);
165                        if ($this->isError($this->arrErr) === false) {
166                            // コンパイルファイルのクリア処理
167                            SC_Utils_Ex::clearCompliedTemplate();
168                            $this->tpl_onload = "alert('プラグインをアップデートしました。');";
169                        }
170                    }
171                }
172                break;
173            // 優先度.
174            case 'priority':
175                // エラーチェック
176                $arrErr = $objFormParam->checkError();
177                $plugin_id = $objFormParam->getValue('plugin_id');
178                if ($this->isError($arrErr) === false) {
179                    // 優先度の更新
180                    $priority = $objFormParam->getValue('priority');
181                    $this->updatePriority($plugin_id, $priority);
182                    // コンパイルファイルのクリア処理
183                    SC_Utils_Ex::clearCompliedTemplate();
184                } else {
185                    // エラーメッセージを詰め直す.
186                    $this->arrErr['priority'][$plugin_id] = $arrErr['priority'];
187                }
188
189                break;
190            default:
191                break;
192        }
193        // DBからプラグイン情報を取得
194        $plugins = SC_Plugin_Util_Ex::getAllPlugin();
195
196        foreach ($plugins as $key => $plugin) {
197            // ロゴファイルへのパスを生成(ロゴが無い場合はNO_IMAGEを表示)
198            if (file_exists(PLUGIN_HTML_REALDIR . $plugins[$key]['plugin_code'] . '/logo.png') === true){
199                $plugins[$key]['logo'] = ROOT_URLPATH . 'plugin/' . $plugins[$key]['plugin_code'] . '/logo.png';
200            } else {
201                $plugins[$key]['logo'] = IMAGE_SAVE_URLPATH . 'noimage_plugin_list.png';
202            }
203
204            // 設定ファイルがあるかを判定.
205            $plugins[$key]['config_flg'] = $this->isContainsFile(PLUGIN_UPLOAD_REALDIR . $plugin['plugin_code'], 'config.php');
206            if ($plugins[$key]['enable'] === PLUGIN_ENABLE_TRUE) {
207                // 競合するプラグインがあるかを判定.
208                //$plugins[$key]['conflict_message']= $this->checkConflictPlugin($plugin['plugin_id']);
209                $plugins[$key]['conflict_message'] = SC_Plugin_Util_Ex::checkConflictPlugin($plugin['plugin_id']);
210            }
211        }
212        $this->plugins = $plugins;
213    }
214
215    /**
216     * デストラクタ.
217     *
218     * @return void
219     */
220    function destroy()
221    {
222        parent::destroy();
223    }
224
225    /**
226     * パラメーター初期化.
227     *
228     * @param SC_FormParam_Ex $objFormParam
229     * @param string $mode モード
230     * @return void
231     */
232    function initParam(&$objFormParam, $mode)
233    {
234        $objFormParam->addParam('mode', 'mode', INT_LEN, '', array('ALPHA_CHECK', 'MAX_LENGTH_CHECK'));
235        $objFormParam->addParam('plugin_id', 'plugin_id', INT_LEN, '', array('NUM_CHECK', 'MAX_LENGTH_CHECK'));
236        if ($mode === 'priority') {
237            $objFormParam->addParam('優先度', 'priority', INT_LEN, '', array('EXIST_CHECK', 'NUM_CHECK', 'MAX_LENGTH_CHECK'));
238        }
239    }
240
241    /**
242     * ファイルパラメーター初期化.
243     *
244     * @param SC_UploadFile_Ex $objUpFile SC_UploadFileのインスタンス.
245     * @param string $key 登録するキー.
246     * @return void
247     */
248    function initUploadFile(&$objUpFile, $key)
249    {
250        $objUpFile->addFile('プラグインファイル', $key, explode(',', PLUGIN_EXTENSION), FILE_SIZE, true, 0, 0, false);
251    }
252
253    /**
254     * ファイルが指定されている事をチェックします.
255     *
256     * @param string $file ファイル
257     * @param string $file_key ファイルキー
258     * @return array エラー情報を格納した連想配列.
259     */
260    function checkUploadFile($file_key)
261    {
262        $objErr = new SC_CheckError_Ex();
263        // 拡張子チェック
264        $objErr->doFunc(array('プラグインファイル', $file_key, explode(',', PLUGIN_EXTENSION)), array('FILE_EXT_CHECK'));
265        // ファイルサイズチェック
266        $objErr->doFunc(array('プラグインファイル', $file_key, FILE_SIZE), array('FILE_SIZE_CHECK'));
267        // ファイル名チェック
268        $objErr->doFunc(array('プラグインファイル', $file_key), array('FILE_NAME_CHECK'));
269
270        return $objErr->arrErr;
271    }
272
273    /**
274     * 既にインストールされているプラグインかを判定します.
275     *
276     * @param string $plugin_code プラグインコード
277     * @return boolean インストール済の場合true インストールされていない場合false
278     */
279    function isInstalledPlugin($plugin_code)
280    {
281        $plugin = SC_Plugin_Util_Ex::getPluginByPluginCode($plugin_code);
282        if (!empty($plugin)) {
283            return true;
284        }
285        return false;
286    }
287
288    /**
289     * ファイル名からプラグインコードを取得する.
290     *
291     * ファイル名を「.」で配列に分解.
292     * 配列内から拡張子として格納される可能性のある「tar」「gz」を除外すし、再度結合する.
293     *
294     * @param string $file_name ファイル名
295     * @return string $plugin_code プラグインコード.
296     */
297    function getPluginCode($file_name)
298    {
299        // 分解
300        $array_ext = explode('.', $file_name);
301        $array_file_name = array_diff($array_ext, array('tar','gz'));
302        // 結合
303        $plugin_code = implode('.', $array_file_name);
304        return $plugin_code;
305    }
306
307    /**
308     * プラグイン保存ディレクトリのパスを取得する.
309     *
310     * @param string $plugin_code プラグインコード
311     * @return string $plugin_dir_path プラグイン保存ディレクトリのパス.
312     */
313    function getPluginDir($plugin_code)
314    {
315        $plugin_dir_path = PLUGIN_UPLOAD_REALDIR . $plugin_code . '/';
316        return $plugin_dir_path;
317    }
318
319    /**
320     * プラグインHTMLディレクトリのパスを取得する.
321     *
322     * @param string $plugin_code プラグインコード
323     * @return string $plugin_dir_path プラグイン保存ディレクトリのパス.
324     */
325    function getHtmlPluginDir($plugin_code)
326    {
327        $plugin_html_dir_path = PLUGIN_HTML_REALDIR . $plugin_code . '/';
328        return $plugin_html_dir_path;
329    }
330
331    /**
332     * プラグインファイルのパスを取得する.
333     *
334     * @param string $plugin_code プラグインコード
335     * @param string $plugin_class プラグインクラス名
336     * @return string $plugin_file_path クラスファイルのパス.
337     */
338    function getPluginFilePath($plugin_code , $plugin_class)
339    {
340        $plugin_file_path = $this->getPluginDir($plugin_code) . $plugin_class . '.php';
341        return $plugin_file_path;
342    }
343
344    /**
345     * プラグインをインストールします.
346     *
347     * @param string $archive_file_name アーカイブファイル名.
348     * @param string $key キー.
349     * @return array エラー情報を格納した連想配列.
350     */
351    function installPlugin($archive_file_name, $key)
352    {
353        $objQuery =& SC_Query_Ex::getSingletonInstance();
354        $objQuery->begin();
355       
356        // 一時展開ディレクトリにファイルがある場合は事前に削除.
357        $arrFileHash = SC_Helper_FileManager_Ex::sfGetFileList(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
358        if (count($arrFileHash) > 0) {
359            SC_Helper_FileManager_Ex::deleteFile(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR, false);
360        }
361
362        //シンタックスエラーがあるtar.gzをアップ後、削除するとたまにディレクトリが消えるので追加
363        $this->makeDir(PLUGIN_UPLOAD_REALDIR);
364
365        $arrErr = array();
366        // 必須拡張モジュールのチェック
367        $arrErr = SC_Plugin_Util_Ex::checkExtension($key);
368        if ($this->isError($arrErr) === true) {
369            return $arrErr;
370        }
371        // ファイルをチェックし一時展開用ディレクトリに展開します.
372        $arrErr = $this->unpackPluginFile($archive_file_name, DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR, $key);
373        if ($this->isError($arrErr) === true) {
374            return $arrErr;
375        }
376        // plugin_infoを読み込み.
377        $arrErr = $this->requirePluginFile(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR . 'plugin_info.php', $key);
378        if ($this->isError($arrErr) === true) {
379            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
380            return $arrErr;
381        }
382
383        // リフレクションオブジェクトを生成.
384        $objReflection = new ReflectionClass('plugin_info');
385        $arrPluginInfo = $this->getPluginInfo($objReflection);
386        // プラグインクラスに必須となるパラメータが正常に定義されているかチェックします.
387        $arrErr = $this->checkPluginConstants($objReflection, DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
388        if ($this->isError($arrErr) === true) {
389            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
390            return $arrErr;
391        }
392
393        // 既にインストールされていないかを判定.
394        if ($this->isInstalledPlugin($arrPluginInfo['PLUGIN_CODE']) === true) {
395            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
396            $arrErr['plugin_file'] = '※ ' . $arrPluginInfo['PLUGIN_NAME'] . 'は既にインストールされています。<br/>';
397            return $arrErr;
398        }
399
400        // プラグイン情報をDB登録
401        if ($this->registerData($arrPluginInfo) === false) {
402            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
403            $arrErr['plugin_file'] = '※ DB登録に失敗しました。<br/>';
404            return $arrErr;
405        }
406
407        // プラグイン保存ディレクトリを作成し、一時展開用ディレクトリから移動します.
408        $plugin_dir_path = $this->getPluginDir($arrPluginInfo['PLUGIN_CODE']);
409        $this->makeDir($plugin_dir_path);
410        SC_Utils_Ex::copyDirectory(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR, $plugin_dir_path);
411
412        // プラグイン情報を取得
413        $plugin = SC_Plugin_Util_Ex::getPluginByPluginCode($arrPluginInfo['PLUGIN_CODE']);
414
415        // クラスファイルを読み込み.
416        $plugin_class_file_path = $this->getPluginFilePath($plugin['plugin_code'], $plugin['class_name']);
417        $arrErr = $this->requirePluginFile($plugin_class_file_path, $key);
418        if ($this->isError($arrErr) === true) {
419            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR, $plugin['plugin_id']);
420            return $arrErr;
421        }
422        // プラグインhtmlディレクトリ作成
423        $plugin_html_dir_path = $this->getHtmlPluginDir($plugin['plugin_code']);
424        $this->makeDir($plugin_html_dir_path);
425
426        $arrErr = $this->execPlugin($plugin, $plugin['class_name'], 'install');
427        if ($this->isError($arrErr) === true) {
428            // エラー時, transactionがabortしてるのでロールバック
429            $objQuery->rollback();
430            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR, $plugin['plugin_id'], $plugin_html_dir_path);
431            return $arrErr;
432        }
433
434        $objQuery->commit();
435       
436        // 不要なファイルの削除
437        SC_Helper_FileManager_Ex::deleteFile(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR, false);
438        return $arrErr;
439    }
440
441    /**
442     * ロールバック処理
443     * インストール失敗時などに不要な一時ファイルを削除します.
444     *
445     * @param string $temp_dir インストール・アップデート時の一時展開用ディレクトリのパス.
446     * @param string $plugin_id プラグインID.
447     * @param string $plugin_html_dir_path プラグイン毎に生成されるhtmlディレクトリのパス.
448     */
449    function rollBack($temp_dir, $plugin_id = '', $plugin_html_dir_path ='')
450    {
451        // 一時ディレクトリを削除.
452        SC_Helper_FileManager_Ex::deleteFile($temp_dir, false);
453        // DBからプラグイン情報を削除
454        if (empty($plugin_id) === false) {
455            SC_Plugin_Util_Ex::deletePluginByPluginId($plugin_id);
456        }
457        // htmlディレクトリを削除
458        if (empty($plugin_html_dir_path) === false) {
459            SC_Helper_FileManager_Ex::deleteFile($plugin_html_dir_path, true);
460        }
461    }
462
463    /**
464     * プラグイン情報を取得します.
465     *
466     * @param ReflectionClass $objReflection
467     * @return array プラグイン情報の配列
468     */
469    function getPluginInfo(ReflectionClass $objReflection)
470    {
471        $arrStaticProps = $objReflection->getStaticProperties();
472        $arrConstants   = $objReflection->getConstants();
473
474        $arrPluginInfoKey = array(
475            'PLUGIN_CODE',
476            'PLUGIN_NAME',
477            'CLASS_NAME',
478            'PLUGIN_VERSION',
479            'COMPLIANT_VERSION',
480            'AUTHOR',
481            'DESCRIPTION',
482            'PLUGIN_SITE_URL',
483            'AUTHOR_SITE_URL',
484            'HOOK_POINTS',
485        );
486        $arrPluginInfo = array();
487        foreach ($arrPluginInfoKey as $key) {
488            // クラス変数での定義を優先
489            if (isset($arrStaticProps[$key])) {
490                $arrPluginInfo[$key] = $arrStaticProps[$key];
491            // クラス変数定義がなければ, クラス定数での定義を読み込み.
492            } elseif ($arrConstants[$key]) {
493                $arrPluginInfo[$key] = $arrConstants[$key];
494            } else {
495                $arrPluginInfo[$key] = null;
496            }
497        }
498        return $arrPluginInfo;
499    }
500
501    /**
502     * プラグインクラス内の定数をチェックします.
503     *
504     * @param ReflectionClass $objReflection リフレクションオブジェクト
505     * @param string $dir_path チェックするプラグインディレクトリ
506     * @return array エラー情報を格納した連想配列.
507     */
508    function checkPluginConstants(ReflectionClass $objReflection, $dir_path)
509    {
510        $arrErr = array();
511        // プラグイン情報を取得
512        $arrPluginInfo = $this->getPluginInfo($objReflection);
513
514        if (!isset($arrPluginInfo['PLUGIN_CODE'])) {
515            $arrErr['plugin_file'] = '※ PLUGIN_CODEが定義されていません。<br/>';
516            return $arrErr;
517        }
518        if (!isset($arrPluginInfo['PLUGIN_NAME'])) {
519            $arrErr['plugin_file'] = '※ PLUGIN_NAMEが定義されていません。<br/>';
520            return $arrErr;
521        }
522        if (!isset($arrPluginInfo['CLASS_NAME'])) {
523            $arrErr['plugin_file'] = '※ CLASS_NAMEが定義されていません。<br/>';
524            return $arrErr;
525        }
526        $plugin_class_file_path = $dir_path . $arrPluginInfo['CLASS_NAME'] . '.php';
527        if (file_exists($plugin_class_file_path) === false) {
528            $arrErr['plugin_file'] = '※ CLASS_NAMEが正しく定義されていません。<br/>';
529            return $arrErr;
530        }
531        if (!isset($arrPluginInfo['PLUGIN_VERSION'])) {
532            $arrErr['plugin_file'] = '※ PLUGIN_VERSIONが定義されていません。<br/>';
533            return $arrErr;
534        }
535        if (!isset($arrPluginInfo['COMPLIANT_VERSION'])) {
536            $arrErr['plugin_file'] = '※ COMPLIANT_VERSIONが定義されていません。<br/>';
537            return $arrErr;
538        }
539        if (!isset($arrPluginInfo['AUTHOR'])) {
540            $arrErr['plugin_file'] = '※ AUTHORが定義されていません。<br/>';
541            return $arrErr;
542        }
543        if (!isset($arrPluginInfo['DESCRIPTION'])) {
544            $arrErr['plugin_file'] = '※ DESCRIPTIONが定義されていません。<br/>';
545            return $arrErr;
546        }
547        $objErr = new SC_CheckError_Ex($arrPluginInfo);
548        $objErr->doFunc(array('PLUGIN_CODE', 'PLUGIN_CODE', STEXT_LEN), array('MAX_LENGTH_CHECK','GRAPH_CHECK'));
549        $objErr->doFunc(array('PLUGIN_NAME', 'PLUGIN_NAME', STEXT_LEN), array('MAX_LENGTH_CHECK'));
550        $objErr->doFunc(array('CLASS_NAME', 'CLASS_NAME', STEXT_LEN), array('MAX_LENGTH_CHECK','GRAPH_CHECK'));
551        $objErr->doFunc(array('PLUGIN_VERSION', 'PLUGIN_VERSION', STEXT_LEN), array('MAX_LENGTH_CHECK'));
552        $objErr->doFunc(array('COMPLIANT_VERSION', 'COMPLIANT_VERSION', STEXT_LEN), array('MAX_LENGTH_CHECK'));
553        $objErr->doFunc(array('AUTHOR', 'AUTHOR', STEXT_LEN), array('MAX_LENGTH_CHECK'));
554        $objErr->doFunc(array('DESCRIPTION', 'DESCRIPTION', MTEXT_LEN), array('MAX_LENGTH_CHECK'));
555        if (isset($arrPluginInfo['PLUGIN_SITE_URL'])) {
556            $objErr->doFunc(array('PLUGIN_SITE_URL', 'PLUGIN_SITE_URL', URL_LEN), array('MAX_LENGTH_CHECK','GRAPH_CHECK'));
557        }
558        if (isset($arrPluginInfo['AUTHOR_SITE_URL'])) {
559            $objErr->doFunc(array('AUTHOR_SITE_URL', 'AUTHOR_SITE_URL', URL_LEN), array('MAX_LENGTH_CHECK','GRAPH_CHECK'));
560        }
561        // エラー内容を出力用の配列にセットします.
562        if ($this->isError($objErr->arrErr)) {
563            $arrErr['plugin_file'] = '';
564            foreach ($objErr->arrErr as $error) {
565                    $arrErr['plugin_file'] .= $error;
566            }
567        }
568        return $arrErr;
569    }
570
571    /**
572     * プラグインをアップデートします.
573     *
574     * @param array $target_plugin アップデートするプラグイン情報の配列.
575     * @param string $upload_file_name アップロードファイル名.
576     * @return array エラー情報を格納した連想配列.
577     */
578    function updatePlugin($target_plugin, $upload_file_name)
579    {
580        // アップデート前に不要なファイルを消しておきます.
581        SC_Helper_FileManager_Ex::deleteFile(DOWNLOADS_TEMP_PLUGIN_UPDATE_DIR, false);
582
583        $arrErr = array();
584
585        // ファイルをチェックし展開します.
586        $arrErr = $this->unpackPluginFile($upload_file_name, DOWNLOADS_TEMP_PLUGIN_UPDATE_DIR, $target_plugin['plugin_code']);
587        if ($this->isError($arrErr) === true) {
588            return $arrErr;
589        }
590        // plugin_infoを読み込み.
591        $arrErr = $this->requirePluginFile(DOWNLOADS_TEMP_PLUGIN_UPDATE_DIR . 'plugin_info.php', $target_plugin['plugin_code']);
592        if ($this->isError($arrErr) === true) {
593            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_INSTALL_DIR);
594            return $arrErr;
595        }
596        // リフレクションオブジェクトを生成.
597        $objReflection = new ReflectionClass('plugin_info');
598        $arrPluginInfo = $this->getPluginInfo($objReflection);
599        if ($arrPluginInfo['PLUGIN_CODE'] != $target_plugin['plugin_code']) {
600            $arrErr[$target_plugin['plugin_code']] = '※ プラグインコードが一致しません。<br/>';
601            return $arrErr;
602        }
603
604        // plugin_update.phpを読み込み.
605        $arrErr = $this->requirePluginFile(DOWNLOADS_TEMP_PLUGIN_UPDATE_DIR . 'plugin_update.php', $target_plugin['plugin_code']);
606        if ($this->isError($arrErr) === true) {
607            $this->rollBack(DOWNLOADS_TEMP_PLUGIN_UPDATE_DIR);
608            return $arrErr;
609        }
610        // プラグインクラスファイルのUPDATE処理を実行.
611        $arrErr = $this->execPlugin($target_plugin, 'plugin_update', 'update');
612
613        // 保存ディレクトリの削除.
614        SC_Helper_FileManager_Ex::deleteFile(DOWNLOADS_TEMP_PLUGIN_UPDATE_DIR, false);
615
616        return $arrErr;
617    }
618
619    /**
620     * ファイルをアップロードし、解凍先のディレクトリに解凍します.
621     *
622     * @param string $unpack_file_name 解凍ファイル名
623     * @param string $unpack_dir_path 解凍先ディレクトリパス
624     * @param string $file_key ファイルキー
625     * @return array エラー情報を格納した連想配列.
626     */
627    function unpackPluginFile($unpack_file_name, $unpack_dir_path, $file_key)
628    {
629        $arrErr = array();
630        // 解凍ディレクトリディレクトリを作成し、一時ディレクトリからファイルを移動
631        $objUpFile = new SC_UploadFile_Ex(PLUGIN_TEMP_REALDIR, $unpack_dir_path);
632        $this->initUploadFile($objUpFile, $file_key);
633        $arrErr = $objUpFile->makeTempFile($file_key, false);
634        if ($this->isError($arrErr) === true) {
635            return $arrErr;
636        }
637
638        // 正常にアップロードされているかをチェック.
639        $arrErr = $objUpFile->checkExists($file_key);
640        if ($this->isError($arrErr) === true) {
641            return $arrErr;
642        }
643        $objUpFile->moveTempFile();
644        // 解凍
645        $unpack_file_path = $unpack_dir_path . $unpack_file_name;
646        if (!$this->unpackPluginArchive($unpack_file_path)) {
647            $arrErr['plugin_file'] = '※ 解凍に失敗しました。<br/>';
648            return $arrErr;
649        }
650        return $arrErr;
651    }
652
653    /**
654     * プラグインをアンインストールします.
655     *
656     * @param array $plugin プラグイン情報を確認した連想配列.
657     * @return array エラー情報を格納した連想配列.
658     */
659    function uninstallPlugin($plugin)
660    {
661        $arrErr = array();
662        // プラグインファイルを読み込みます.
663        $plugin_class_file_path = $this->getPluginFilePath($plugin['plugin_code'], $plugin['class_name']);
664        $arrErr = $this->requirePluginFile($plugin_class_file_path, 'plugin_error');
665        if ($this->isError($arrErr) === true) {
666            return $arrErr;
667        }
668
669        // プラグインが有効な場合に無効化処理を実行
670        if ($plugin['enable'] == PLUGIN_ENABLE_TRUE){
671            // 無効化処理を実行します.
672            $arrErr = $this->execPlugin($plugin, $plugin['class_name'], 'disable');
673            if ($this->isError($arrErr) === true) {
674                return $arrErr;
675            }
676            // プラグインを無効にします.
677            $this->updatePluginEnable($plugin['plugin_id'], PLUGIN_ENABLE_FALSE);
678        }
679
680        // アンインストール処理を実行します.
681        $arrErr = $this->execPlugin($plugin, $plugin['class_name'], 'uninstall');
682        // プラグインの削除処理.
683        $arrErr = $this->deletePlugin($plugin['plugin_id'], $plugin['plugin_code']);
684
685        return $arrErr;
686    }
687
688    /**
689     * プラグインを有効にします.
690     *
691     * @param array $plugin プラグイン情報を確認した連想配列.
692     * @return array $arrErr エラー情報を格納した連想配列.
693     */
694    function enablePlugin($plugin)
695    {
696        $arrErr = array();
697        // クラスファイルを読み込み.
698        $plugin_class_file_path = $this->getPluginFilePath($plugin['plugin_code'], $plugin['class_name']);
699        $arrErr = $this->requirePluginFile($plugin_class_file_path, 'plugin_error');
700        if ($this->isError($arrErr) === true) {
701            return $arrErr;
702        }
703        // 有効化処理を実行します.
704        $arrErr = $this->execPlugin($plugin, $plugin['class_name'], 'enable');
705        if ($this->isError($arrErr) === true) {
706            return $arrErr;
707        }
708        // プラグインを有効にします.
709        $this->updatePluginEnable($plugin['plugin_id'], PLUGIN_ENABLE_TRUE);
710
711        return $arrErr;
712    }
713
714    /**
715     * プラグインを無効にします.
716     *
717     * @param array $plugin プラグイン情報を確認した連想配列.
718     * @return array $arrErr エラー情報を格納した連想配列.
719     */
720    function disablePlugin($plugin)
721    {
722        $arrErr = array();
723        // クラスファイルを読み込み.
724        $plugin_class_file_path =$this->getPluginFilePath($plugin['plugin_code'], $plugin['class_name']);
725        $arrErr = $this->requirePluginFile($plugin_class_file_path, 'plugin_error');
726        if ($this->isError($arrErr) === true) {
727            return $arrErr;
728        }
729
730        // 無効化処理を実行します.
731        $arrErr = $this->execPlugin($plugin, $plugin['class_name'], 'disable');
732        if ($this->isError($arrErr) === true) {
733            return $arrErr;
734        }
735        // プラグインを無効にします.
736        $this->updatePluginEnable($plugin['plugin_id'], PLUGIN_ENABLE_FALSE);
737
738        return $arrErr;
739    }
740
741    /**
742     * 優先度を更新します.
743     *
744     * @param int $plugin_id プラグインID
745     * @param int $priority 優先度
746     * @return integer 更新件数
747     */
748    function updatePriority($plugin_id, $priority)
749    {
750        $objQuery =& SC_Query_Ex::getSingletonInstance();
751        // UPDATEする値を作成する。
752        $sqlval['priority'] = $priority;
753        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
754        $where = 'plugin_id = ?';
755        // UPDATEの実行
756        $ret = $objQuery->update('dtb_plugin', $sqlval, $where, array($plugin_id));
757        return $ret;
758    }
759
760    /**
761     * プラグイン情報をDB登録.
762     *
763     * @param array $arrPluginInfo プラグイン情報を格納した連想配列.
764     * @return array エラー情報を格納した連想配列.
765     */
766    function registerData($arrPluginInfo)
767    {
768
769        // プラグイン情報をDB登録.
770        $objQuery =& SC_Query_Ex::getSingletonInstance();
771        $arr_sqlval_plugin = array();
772        $plugin_id = $objQuery->nextVal('dtb_plugin_plugin_id');
773        $arr_sqlval_plugin['plugin_id'] = $plugin_id;
774        $arr_sqlval_plugin['plugin_name'] = $arrPluginInfo['PLUGIN_NAME'];
775        $arr_sqlval_plugin['plugin_code'] = $arrPluginInfo['PLUGIN_CODE'];
776        $arr_sqlval_plugin['class_name'] = $arrPluginInfo['CLASS_NAME'];
777        $arr_sqlval_plugin['author'] = $arrPluginInfo['AUTHOR'];
778        // AUTHOR_SITE_URLが定義されているか判定.
779        $author_site_url = $arrPluginInfo['AUTHOR_SITE_URL'];
780        if ($author_site_url !== null) {
781            $arr_sqlval_plugin['author_site_url'] = $arrPluginInfo['AUTHOR_SITE_URL'];
782        }
783        // PLUGIN_SITE_URLが定義されているか判定.
784        $plugin_site_url = $arrPluginInfo['PLUGIN_SITE_URL'];
785        if ($plugin_site_url !== null) {
786            $arr_sqlval_plugin['plugin_site_url'] = $plugin_site_url;
787        }
788        $arr_sqlval_plugin['plugin_version'] = $arrPluginInfo['PLUGIN_VERSION'];
789        $arr_sqlval_plugin['compliant_version'] = $arrPluginInfo['COMPLIANT_VERSION'];
790        $arr_sqlval_plugin['plugin_description'] = $arrPluginInfo['DESCRIPTION'];
791        $arr_sqlval_plugin['priority'] = 0;
792        $arr_sqlval_plugin['enable'] = PLUGIN_ENABLE_FALSE;
793        $arr_sqlval_plugin['update_date'] = 'CURRENT_TIMESTAMP';
794        $objQuery->insert('dtb_plugin', $arr_sqlval_plugin);
795
796        // フックポイントをDB登録.
797        $hook_point = $arrPluginInfo['HOOK_POINTS'];
798        if ($hook_point !== null) {
799            /**
800             * FIXME コードが重複しているため、要修正
801             */
802            // フックポイントが配列で定義されている場合
803            if (is_array($hook_point)) {
804                foreach ($hook_point as $h) {
805                    $arr_sqlval_plugin_hookpoint = array();
806                    $id = $objQuery->nextVal('dtb_plugin_hookpoint_plugin_hookpoint_id');
807                    $arr_sqlval_plugin_hookpoint['plugin_hookpoint_id'] = $id;
808                    $arr_sqlval_plugin_hookpoint['plugin_id'] = $plugin_id;
809                    $arr_sqlval_plugin_hookpoint['hook_point'] = $h[0];
810                    $arr_sqlval_plugin_hookpoint['callback'] = $h[1];
811                    $arr_sqlval_plugin_hookpoint['update_date'] = 'CURRENT_TIMESTAMP';
812                    $objQuery->insert('dtb_plugin_hookpoint', $arr_sqlval_plugin_hookpoint);
813                }
814            // 文字列定義の場合
815            } else {
816                $array_hook_point = explode(',', $hook_point);
817                foreach ($array_hook_point as $h) {
818                    $arr_sqlval_plugin_hookpoint = array();
819                    $id = $objQuery->nextVal('dtb_plugin_hookpoint_plugin_hookpoint_id');
820                    $arr_sqlval_plugin_hookpoint['plugin_hookpoint_id'] = $id;
821                    $arr_sqlval_plugin_hookpoint['plugin_id'] = $plugin_id;
822                    $arr_sqlval_plugin_hookpoint['hook_point'] = $h;
823                    $arr_sqlval_plugin_hookpoint['update_date'] = 'CURRENT_TIMESTAMP';
824                    $objQuery->insert('dtb_plugin_hookpoint', $arr_sqlval_plugin_hookpoint);
825                }
826            }
827        }
828    }
829
830    /**
831     * ファイルを読み込む.
832     *
833     * @param string $file_path クラスのpath
834     * @param string $key エラー情報のキー.
835     * @return array $arrErr エラー情報を格納した連想配列.
836     */
837    function requirePluginFile($file_path, $key)
838    {
839        $arrErr = array();
840        if (file_exists($file_path)) {
841            require_once $file_path;
842        } else {
843            $arrErr[$key] = '※ ' . $file_path .'の読み込みに失敗しました。<br/>';
844        }
845        return $arrErr;
846    }
847
848    /**
849     * インスタンスを生成し、指定のメソッドを実行する.
850     *
851     * @param object $obj インスタンス
852     * @param string $class_name クラス名
853     * @param string $exec_func 実行するメソッド名.
854     * @return array $arrErr エラー情報を格納した連想配列.
855     *
856     */
857    function execPlugin($obj, $class_name, $exec_func)
858    {
859        $objPluginInstaller = new SC_Plugin_Installer($exec_func, $obj);
860
861        $arrErr = array();
862        if (method_exists($class_name, $exec_func) === true) {
863            $ret = call_user_func_array(
864                    array($class_name, $exec_func),
865                    array($obj, $objPluginInstaller));
866            if (!(is_null($ret) || $ret === true)) {
867                $arrErr[$obj['plugin_code']] = $ret;
868            }
869            $arrInstallErr = $objPluginInstaller->execPlugin();
870            if ($arrInstallErr) {
871                $arrErr['plugin_file'] = "プラグインのインストールにしっぱいしました.<br/>";
872            }
873        } else {
874            $arrErr['plugin_file'] = '※ ' . $class_name . '.php に' . $exec_func . 'が見つかりません。<br/>';
875        }
876       
877        return $arrErr;
878    }
879
880    /**
881     * プラグインアーカイブを解凍する.
882     *
883     * @param string $path アーカイブパス
884     * @return boolean Archive_Tar::extractModify()のエラー
885     */
886    function unpackPluginArchive($path)
887    {
888        // 圧縮フラグTRUEはgzip解凍をおこなう
889        $tar = new Archive_Tar($path, true);
890
891        $dir = dirname($path);
892        $file_name = basename($path);
893
894        // 拡張子を切り取る
895        $unpacking_name = preg_replace("/(\.tar|\.tar\.gz)$/", '', $file_name);
896
897        // 指定されたフォルダ内に解凍する
898        $result = $tar->extractModify($dir. '/', $unpacking_name);
899        GC_Utils_Ex::gfPrintLog('解凍:' . $dir.'/'.$file_name.'->'.$dir.'/'.$unpacking_name);
900        // 解凍元のファイルを削除する.
901        unlink($path);
902
903        return $result;
904    }
905
906    /**
907     * plugin_idをキーにdtb_pluginのstatusを更新します.
908     *
909     * @param int $plugin_id プラグインID
910     * @param int $enable_flg 有効フラグ
911     * @return integer 更新件数
912     */
913    function updatePluginEnable($plugin_id, $enable_flg)
914    {
915        $objQuery =& SC_Query_Ex::getSingletonInstance();
916        // UPDATEする値を作成する。
917        $sqlval['enable'] = $enable_flg;
918        $sqlval['update_date'] = 'CURRENT_TIMESTAMP';
919        $where = 'plugin_id = ?';
920        // UPDATEの実行
921        $ret = $objQuery->update('dtb_plugin', $sqlval, $where, array($plugin_id));
922        return $ret;
923    }
924
925    /**
926     * plugin_idをキーにdtb_plugin, dtb_plugin_hookpointから物理削除します.
927     *
928     * @param int $plugin_id プラグインID.
929     * @param string $plugin_code プラグインコード.
930     * @return array $arrErr エラー情報を格納した連想配列.
931     */
932    function deletePlugin($plugin_id, $plugin_code)
933    {
934        $arrErr = array();
935        $objQuery =& SC_Query_Ex::getSingletonInstance();
936        $objQuery->begin();
937
938        SC_Plugin_Util_Ex::deletePluginByPluginId($plugin_id);
939
940        if (SC_Helper_FileManager_Ex::deleteFile($this->getPluginDir($plugin_code)) === false) {
941            // TODO エラー処理
942        }
943
944        if (SC_Helper_FileManager_Ex::deleteFile($this->getHtmlPluginDir($plugin_code)) === false) {
945            // TODO エラー処理
946        }
947
948        $objQuery->commit();
949
950        return $arrErr;
951    }
952
953    /**
954     * ファイルがあるかを判定します.
955     *
956     * @param string $plugin_dir 対象ディレクトリ.
957     * @param string $file_name ファイル名.
958     * @return boolean
959     */
960    function isContainsFile($plugin_dir, $file_name)
961    {
962        if (file_exists($plugin_dir) && is_dir($plugin_dir)) {
963            if ($handle = opendir($plugin_dir)) {
964                while (($item = readdir($handle)) !== false) {
965                    if ($item === $file_name) return true;
966                }
967            }
968            closedir($handle);
969        }
970        return false;
971    }
972
973    /**
974     * アーカイブ内に指定のファイルが存在するかを判定します.
975     *
976     * @param Archive_Tar $tar_obj
977     * @param string $file_path 判定するファイルパス
978     * @return boolean
979     */
980    function checkContainsFile($tar_obj, $file_path)
981    {
982        // ファイル一覧を取得
983        $arrayFile = $tar_obj->listContent();
984        foreach ($arrayFile as  $value) {
985            if ($value['filename'] === $file_path) return true;
986        }
987        return false;
988    }
989
990    /**
991     * ディレクトリを作成します.
992     *
993     * @param string $dir_path 作成するディレクトリのパス
994     * @return void
995     */
996    function makeDir($dir_path)
997    {
998        // ディレクトリ作成
999        if (!file_exists($dir_path)) {
1000            mkdir($dir_path);
1001        }
1002    }
1003
1004    /**
1005     * エラー情報が格納されているか判定します.
1006     *
1007     * @param array $arrErr エラー情報を格納した連想配列.
1008     * @return boolean.
1009     */
1010    function isError($error)
1011    {
1012        if (is_array($error) && count($error) > 0) {
1013            return true;
1014        }
1015        return false;
1016    }
1017
1018}
Note: See TracBrowser for help on using the repository browser.