source: branches/version-2_11-dev/data/class/pages/admin/design/LC_Page_Admin_Design_MainEdit.php @ 20847

Revision 20847, 14.3 KB checked in by nanasess, 11 years ago (diff)

#972 (リファクタリング開発:[管理画面]デザイン管理)

  • ページ詳細設定
  • 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-2011 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';
26require_once CLASS_EX_REALDIR . 'helper_extends/SC_Helper_FileManager_Ex.php';
27
28/**
29 * メイン編集 のページクラス.
30 *
31 * @package Page
32 * @author LOCKON CO.,LTD.
33 * @version $Id$
34 */
35class LC_Page_Admin_Design_MainEdit extends LC_Page_Admin_Ex {
36
37    // }}}
38    // {{{ functions
39
40    /**
41     * Page を初期化する.
42     *
43     * @return void
44     */
45    function init() {
46        parent::init();
47        $this->tpl_mainpage = 'design/main_edit.tpl';
48        $this->tpl_subnavi  = 'design/subnavi.tpl';
49        $this->text_row     = 13;
50        $this->tpl_subno = "main_edit";
51        $this->tpl_mainno = 'design';
52        $this->tpl_subtitle = 'ページ詳細設定';
53        $masterData = new SC_DB_MasterData_Ex();
54        $this->arrDeviceType = $masterData->getMasterData('mtb_device_type');
55    }
56
57    /**
58     * Page のプロセス.
59     *
60     * @return void
61     */
62    function process() {
63        $this->action();
64        $this->sendResponse();
65    }
66
67    /**
68     * Page のアクション.
69     *
70     * @return void
71     */
72    function action() {
73        $objLayout = new SC_Helper_PageLayout_Ex();
74        $objFormParam = new SC_FormParam_Ex();
75        $this->lfInitParam($objFormParam);
76        $objFormParam->setParam($_REQUEST);
77        $objFormParam->convParam();
78        $this->arrErr = $objFormParam->checkError();
79        $is_error = (!SC_Utils_Ex::isBlank($this->arrErr));
80
81        $this->device_type_id = $objFormParam->getValue('device_type_id', DEVICE_TYPE_PC);
82        $this->page_id = $objFormParam->getValue('page_id');
83
84        switch ($this->getMode()) {
85        case 'delete':
86            if (!$is_error) {
87                if ($objLayout->isEditablePage($this->device_type_id, $this->page_id)) {
88                    $objLayout->lfDelPageData($this->page_id, $this->device_type_id);
89                    SC_Response_Ex::reload(array("device_type_id" => $this->device_type_id,
90                                                 "msg" => "on"), true);
91                    exit;
92                }
93            }
94            break;
95
96        case 'confirm':
97            if (!$is_error) {
98                $this->arrErr = $this->lfCheckError($objFormParam, $this->arrErr);
99                if (SC_Utils_Ex::isBlank($this->arrErr)) {
100                    $result = $this->doRegister($objFormParam, $objLayout);
101                    if ($result !== false) {
102                        SC_Response_Ex::reload(array("device_type_id" => $this->device_type_id,
103                                                     "page_id" => $result,
104                                                     "msg" => "on"), true);
105                    exit;
106                    }
107                }
108            }
109        default:
110            if (isset($_GET['msg']) && $_GET['msg'] == 'on'){
111                $this->tpl_onload = "alert('登録が完了しました。');";
112            }
113        }
114
115        if (!$is_error) {
116            $this->arrPageList = $objLayout->getPageProperties($this->device_type_id, null);
117            // page_id が指定されている場合にはテンプレートデータの取得
118            if (!SC_Utils_Ex::isBlank($this->page_id)) {
119                $arrPageData = $this->getTplMainpage($this->device_type_id, $this->page_id, $objLayout);
120                $objFormParam->setParam($arrPageData);
121            }
122        } else {
123            // 画面にエラー表示しないため, ログ出力
124            GC_Utils_Ex::gfPrintLog('Error: ' . print_r($this->arrErr, true));
125        }
126        $this->tpl_subtitle .= ' - ' . $this->arrDeviceType[$this->device_type_id];
127        $this->arrForm = $objFormParam->getFormParamList();
128    }
129
130    /**
131     * デストラクタ.
132     *
133     * @return void
134     */
135    function destroy() {
136        parent::destroy();
137    }
138
139    /**
140     * パラメータ情報の初期化
141     *
142     * XXX URL のフィールドは, 実際は filename なので注意
143     *
144     * @param object $objFormParam SC_FormParamインスタンス
145     * @return void
146     */
147    function lfInitParam(&$objFormParam) {
148        $objFormParam->addParam("ページID", "page_id", INT_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
149        $objFormParam->addParam("端末種別ID", "device_type_id", INT_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
150        $objFormParam->addParam("名称", "page_name", STEXT_LEN, 'KVa', array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
151        $objFormParam->addParam("URL", "filename", STEXT_LEN, 'a', array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
152        $objFormParam->addParam("ヘッダチェック", "header_chk", INT_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
153        $objFormParam->addParam("フッタチェック", "footer_chk", INT_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
154        $objFormParam->addParam("修正フラグ", "edit_flg", INT_LEN, 'n', array("NUM_CHECK", "MAX_LENGTH_CHECK"));
155        $objFormParam->addParam("TPLデータ", "tpl_data");
156     }
157
158    /**
159     * ページデータを取得する.
160     *
161     * @param integer $device_type_id 端末種別ID
162     * @param integer $page_id ページID
163     * @param SC_Helper_PageLayout $objLayout SC_Helper_PageLayout インスタンス
164     * @return array ページデータの配列
165     */
166    function getTplMainpage($device_type_id, $page_id, &$objLayout){
167        $arrPageData = $objLayout->getPageProperties($device_type_id, $page_id);
168
169        $templatePath = $objLayout->getTemplatePath($device_type_id);
170        $filename = $templatePath . $arrPageData[0]['filename'] . ".tpl";
171        if (file_exists($filename)) {
172            $arrPageData[0]['tpl_data'] = file_get_contents($filename);
173        }
174        // ファイル名を画面表示用に加工しておく
175        $arrPageData[0]['filename'] = preg_replace('|^' . preg_quote(USER_DIR) . '|', '', $arrPageData[0]['filename']);
176        return $arrPageData[0];
177    }
178
179    /**
180     * 登録を実行する.
181     *
182     * ファイルの作成に失敗した場合は, エラーメッセージを出力し,
183     * データベースをロールバックする.
184     *
185     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
186     * @param SC_Helper_PageLayout $objLayout SC_Helper_PageLayout インスタンス
187     * @return integer|boolean 登録が成功した場合, 登録したページID;
188     *                         失敗した場合 false
189     */
190    function doRegister($objFormParam, &$objLayout) {
191        $filename = $objFormParam->getValue('filename');
192        $arrParams['device_type_id'] = $objFormParam->getValue('device_type_id');
193        $arrParams['page_id'] = $objFormParam->getValue('page_id');
194        $arrParams['header_chk'] = intval($objFormParam->getValue('header_chk')) === 1 ? 1 : 2;
195        $arrParams['footer_chk'] = intval($objFormParam->getValue('footer_chk')) === 1 ? 1 : 2;
196        $arrParams['tpl_data'] = $objFormParam->getValue('tpl_data');
197        $arrParams['page_name'] = $objFormParam->getValue('page_name');
198        $arrParams['url'] = USER_DIR . $filename . '.php';
199        $arrParams['filename'] = USER_DIR . $filename;
200
201        $objQuery =& SC_Query_Ex::getSingletonInstance();
202        $objQuery->begin();
203
204        $page_id = $this->registerPage($arrParams, $objLayout);
205
206        /*
207         * 新規登録時
208         * or 編集可能な既存ページ編集時かつ, PHP ファイルが存在しない場合に,
209         * PHP ファイルを作成する.
210         */
211        if (SC_Utils_Ex::isBlank($arrParams['page_id'])
212            || $objLayout->isEditablePage($arrParams['device_type_id'], $arrParams['page_id'])) {
213            if (!$this->createPHPFile($filename)) {
214                $this->arrErr['err'] = '※ PHPファイルの作成に失敗しました<br />';
215                $objQuery->rollback();
216                return false;
217            }
218            // 新規登録時のみ $page_id を代入
219            $arrParams['page_id'] = $page_id;
220        }
221
222        if ($objLayout->isEditablePage($arrParams['device_type_id'], $page_id)) {
223            $tpl_path = $objLayout->getTemplatePath($arrParams['device_type_id']) . $arrParams['filename'] . '.tpl';
224        } else {
225            $tpl_path = $objLayout->getTemplatePath($arrParams['device_type_id']) . $filename . '.tpl';
226        }
227
228        if (!SC_Helper_FileManager_Ex::sfWriteFile($tpl_path, $arrParams['tpl_data'])) {
229            $this->arrErr['err'] = '※ TPLファイルの書き込みに失敗しました<br />';
230            $objQuery->rollback();
231            return false;
232        }
233
234        $objQuery->commit();
235        return $arrParams['page_id'];
236    }
237
238    /**
239     * 入力内容をデータベースに登録する.
240     *
241     * @param array $arrParams フォームパラメータの配列
242     * @param SC_Helper_PageLayout $objLayout SC_Helper_PageLayout インスタンス
243     * @return integer ページID
244     */
245    function registerPage($arrParams, &$objLayout) {
246        $objQuery =& SC_Query_Ex::getSingletonInstance();
247
248        // ページIDが空の場合は新規登録
249        $is_new = SC_Utils_Ex::isBlank($arrParams['page_id']);
250        // 既存ページの存在チェック
251        if (!$is_new) {
252            $arrExists = $objLayout->getPageProperties($arrParams['device_type_id'], $arrParams['page_id']);
253        }
254
255        $table = 'dtb_pagelayout';
256        $arrValues = $objQuery->extractOnlyColsOf($table, $arrParams);
257        $arrValues['update_url'] = $_SERVER['HTTP_REFERER'];
258        $arrValues['update_date'] = 'now()';
259
260        // 新規登録
261        if ($is_new || SC_Utils_Ex::isBlank($arrExists)) {
262            $objQuery->setOrder('');
263            $arrValues['page_id'] = 1 + $objQuery->max('page_id', $table, 'device_type_id = ?',
264                                                       array($arrValues['device_type_id']));
265            $arrValues['create_date'] = 'now()';
266            $objQuery->insert($table, $arrValues);
267        }
268        // 更新
269        else {
270            // 編集不可ページは更新しない
271            if (!$objLayout->isEditablePage($arrValues['device_type_id'], $arrValues['page_id'])) {
272                unset($arrValues['page_name']);
273                unset($arrValues['filename']);
274                unset($arrValues['url']);
275            }
276
277            $objQuery->update('dtb_pagelayout', $arrValues, 'page_id = ? AND device_type_id = ?',
278                              array($arrValues['page_id'], $arrValues['device_type_id']));
279        }
280        return $arrValues['page_id'];
281    }
282
283    /**
284     * エラーチェックを行う.
285     *
286     * @param SC_FormParam $objFormParam SC_FormParam インスタンス
287     * @return array エラーメッセージの配列
288     */
289    function lfCheckError(&$objFormParam, &$arrErr) {
290        $arrParams = $objFormParam->getHashArray();
291        $objErr = new SC_CheckError_Ex($arrParams);
292        $objErr->arrErr =& $arrErr;
293        $objErr->doFunc(array("名称", "page_name", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
294        $objErr->doFunc(array('URL', 'filename', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
295
296        /*
297         * URL チェック
298         * ここでチェックするのは, パスのみなので SC_CheckError::URL_CHECK()
299         * は使用しない
300         */
301        $valid_url = true;
302        foreach (explode('/', $arrParams['filename']) as $val) {
303            if (!preg_match('/^[a-zA-Z0-9:_~\.\-]+$/', $val)) {
304                $valid_url = false;
305            }
306            if ($val == '.' || $val == '..') {
307                $valid_url = false;
308            }
309        }
310        if (!$valid_url) {
311            $objErr->arrErr['filename'] = "※ URLを正しく入力してください。<br />";
312        }
313        // 同一URLの存在チェック
314        $where = 'page_id <> 0 AND device_type_id = ? AND filename = ?';
315        $arrValues = array($arrParams['device_type_id'],
316                           SC_Helper_PageLayout_Ex::getUserDir($arrParams['device_type_id']) . $arrParams['filename'] . '.php');
317        // 変更の場合は自 URL を除外
318        if (!SC_Utils_Ex::isBlank($arrParams['page_id'])) {
319            $where .= ' AND page_id <> ?';
320            $arrValues[] = $arrParams['page_id'];
321        }
322
323        $objQuery =& SC_Query_Ex::getSingletonInstance();
324        $count = $objQuery->count('dtb_pagelayout', $where, $arrValues);
325        if ($count > 0) {
326            $objErr->arrErr['filename'] = '※ 同じURLのデータが存在しています。別のURLを入力してください。<br />';
327        }
328        return $objErr->arrErr;
329    }
330
331    /**
332     * PHP ファイルを生成する.
333     *
334     * 既に同名の PHP ファイルが存在する場合は何もせず true を返す.(#831)
335     *
336     * @param string $filename フォームパラメータの filename
337     * @return boolean 作成に成功した場合 true
338     */
339    function createPHPFile($filename) {
340        $path = USER_REALDIR . $filename . '.php';
341
342        if (file_exists($path)) {
343            return true;
344        }
345
346        if (file_exists(USER_DEF_PHP_REALFILE)) {
347            $php_contents = file_get_contents(USER_DEF_PHP_REALFILE);
348        } else {
349            return false;
350        }
351
352        // require.php の PATH を書き換える
353        $defaultStrings = "exit; // Don't rewrite. This line is rewritten by EC-CUBE.";
354        $replaceStrings = "require_once '" . str_repeat('../', substr_count($filename, '/')) . "../require.php';";
355        $php_contents = str_replace($defaultStrings, $replaceStrings, $php_contents);
356
357        return SC_Helper_FileManager_Ex::sfWriteFile($path, $php_contents);
358    }
359}
360?>
Note: See TracBrowser for help on using the repository browser.