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

Revision 23124, 15.3 KB checked in by kimoto, 11 years ago (diff)

#2043 typo修正・ソース整形・ソースコメントの改善 for 2.13.0
PHP4的な書き方の修正

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