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

Revision 20647, 14.1 KB checked in by t_yuo, 11 years ago (diff)

#1119 (ページ詳細編集 ヘッダー、フッターチェック値の読み込み不良)
修正しました。

  • 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-2010 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_Design_MainEdit extends LC_Page_Admin_Ex {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'design/main_edit.tpl';
47        $this->tpl_subnavi  = 'design/subnavi.tpl';
48        $this->text_row     = 13;
49        $this->tpl_subno = "main_edit";
50        $this->tpl_mainno = 'design';
51        $this->tpl_subtitle = 'ページ詳細設定';
52        $masterData = new SC_DB_MasterData_Ex();
53        $this->arrDeviceType = $masterData->getMasterData('mtb_device_type');
54    }
55
56    /**
57     * Page のプロセス.
58     *
59     * @return void
60     */
61    function process() {
62        $this->action();
63        $this->sendResponse();
64    }
65
66    /**
67     * Page のアクション.
68     *
69     * @return void
70     */
71    function action() {
72        $objView = new SC_AdminView_Ex();
73        $this->objLayout = new SC_Helper_PageLayout_Ex();
74
75        // ページIDを取得
76        if (isset($_REQUEST['page_id']) && is_numeric($_REQUEST['page_id'])) {
77            $page_id = $_REQUEST['page_id'];
78        }
79
80        $this->page_id = $page_id;
81
82        // 端末種別IDを取得
83        if (isset($_REQUEST['device_type_id'])
84            && is_numeric($_REQUEST['device_type_id'])) {
85            $device_type_id = $_REQUEST['device_type_id'];
86        } else {
87            $device_type_id = DEVICE_TYPE_PC;
88        }
89
90        //サブタイトルの追加
91        $this->tpl_subtitle .= ' - ' . $this->arrDeviceType[$device_type_id];
92
93        // ページ一覧を取得
94        $this->arrPageList = $this->objLayout->lfGetPageData("page_id <> 0 AND device_type_id = ?",
95                                                             array($device_type_id));
96
97        // メッセージ表示
98        if (isset($_GET['msg']) && $_GET['msg'] == 'on'){
99            $this->tpl_onload="alert('登録が完了しました。');";
100        }
101
102        // page_id が指定されている場合にはテンプレートデータの取得
103        if (is_numeric($page_id) && $page_id != '') {
104            $this->arrPageData = $this->lfGetPageData($page_id, $device_type_id, $objView);
105        }
106
107        switch ($this->getMode()) {
108        case 'delete':
109            if (!$this->objLayout->lfCheckBaseData($page_id, $device_type_id)) {
110                $this->lfDeletePageData($page_id, $device_type_id);
111                exit;
112            }
113            break;
114
115        case 'confirm':
116            $this->lfConfirmPageData($page_id, $device_type_id);
117        default:
118        }
119        $this->device_type_id = $device_type_id;
120    }
121
122    /**
123     * デストラクタ.
124     *
125     * @return void
126     */
127    function destroy() {
128        parent::destroy();
129    }
130
131    /**
132     * ページデータを取得する.
133     *
134     * @param integer $page_id ページID
135     * @param integer $device_type_id 端末種別ID
136     * @param object $objView ビューオブジェクト
137     * @return void
138     */
139    function lfGetPageData($page_id, $device_type_id, $objView){
140        $arrPageData = $this->objLayout->lfGetPageData("page_id = ? AND device_type_id = ?",
141                                                       array($page_id, $device_type_id));
142
143        if (strlen($arrPageData[0]['filename']) == 0) {
144            $this->arrErr['page_id_err'] = "※ 指定されたページは編集できません。";
145            // 画面の表示
146            $objView->assignobj($this);
147            $objView->display(MAIN_FRAME);
148            exit;
149        }
150
151        // テンプレートを読み込む
152        $templatePath = $this->objLayout->getTemplatePath($device_type_id);
153        $arrPageData[0]['tpl_data'] = file_get_contents($templatePath . $arrPageData[0]['filename'] . ".tpl");
154
155        // ディレクトリを画面表示用に編集
156        $arrPageData[0]['filename'] = preg_replace('|^' . preg_quote(USER_DIR) . '|', '', $arrPageData[0]['filename']);
157
158        return $arrPageData[0];
159    }
160
161    /**
162     * データ登録処理.
163     *
164     * @param integer $page_id ページID
165     * @param integer $device_type_id 端末種別ID
166     * @return void
167     */
168    function lfConfirmPageData($page_id, $device_type_id) {
169        // エラーチェック
170        $this->arrErr = $this->lfErrorCheck($_POST, $device_type_id);
171
172        // エラーがなければ更新処理を行う
173        if (count($this->arrErr) == 0) {
174            // DBへデータを更新する
175            $arrTmp = $this->lfEntryPageData(
176                $device_type_id,
177                $page_id,
178                $_POST['page_name'],
179                USER_DIR . $_POST['url'],
180                $_POST['header_chk'],
181                $_POST['footer_chk']
182            );
183            $page_id = $arrTmp['page_id'];
184
185            $arrTmp = $this->objLayout->lfGetPageData('page_id = ? AND device_type_id = ?', array($page_id, $device_type_id));
186            $arrData = $arrTmp[0];
187
188            // ベースデータでなければファイルを削除し、PHPファイルを作成する
189            if (!$this->objLayout->lfCheckBaseData($arrData['page_id'], $device_type_id)) {
190                // PHPファイル作成
191                $this->lfCreatePHPFile($_POST['url'], $device_type_id);
192            }
193
194            // TPLファイル作成
195            $cre_tpl = $this->objLayout->getTemplatePath($device_type_id) . $arrData['filename'] . '.tpl';
196            $this->lfCreateFile($cre_tpl, $_POST['tpl_data']);
197
198            $arrQueryString = array(
199                "page_id" => $arrData['page_id'],
200                "device_type_id" => $device_type_id,
201                'msg'     => 'on',
202            );
203            $this->objDisplay->reload($arrQueryString, true);
204            exit;
205        } else {
206            // エラーがあれば入力時のデータを表示する
207            $this->arrPageData = $_POST;
208            $this->arrPageData['header_chk'] = SC_Utils_Ex::sfChangeCheckBox(SC_Utils_Ex::sfChangeCheckBox($_POST['header_chk']), true);
209            $this->arrPageData['footer_chk'] = SC_Utils_Ex::sfChangeCheckBox(SC_Utils_Ex::sfChangeCheckBox($_POST['footer_chk']), true);
210            $this->arrPageData['directory'] = '';
211            $this->arrPageData['filename'] = $_POST['url'];
212        }
213    }
214
215    /**
216     * ブロック情報を更新する.
217     *
218     * @param integer $device_type_id
219     * @param integer $page_id
220     * @param string $page_name
221     * @param string $filename
222     * @param integer $header_chk
223     * @param integer $footer_chk
224     * @return array 実際に使用した更新データ
225     */
226    function lfEntryPageData($device_type_id, $page_id, $page_name, $filename, $header_chk, $footer_chk) {
227        $objQuery = new SC_Query_Ex();
228        $arrChk = array();          // 排他チェック用
229
230        // 更新用データの変換
231        $sqlval = $this->lfGetUpdData($device_type_id, $page_id, $page_name, $filename, $header_chk, $footer_chk);
232
233        // データが存在しているかチェックを行う
234        if ($page_id !== ''){
235            $arrChk = $this->objLayout->lfGetPageData("page_id = ? AND device_type_id = ?",
236                                                      array($page_id, $device_type_id));
237        }
238
239        // page_id が空 若しくは データが存在していない場合にはINSERTを行う
240        if ($page_id === '' || !isset($arrChk[0])) {
241            // FIXME device_type_id ごとの連番にする
242            $sqlval['page_id'] = $objQuery->nextVal('dtb_pagelayout_page_id');
243            $sqlval['device_type_id'] = $device_type_id;
244            $sqlval['create_date'] = 'now()';
245            $objQuery->insert('dtb_pagelayout', $sqlval);
246        }
247        // データが存在してる場合にはアップデートを行う
248        else {
249            $objQuery->update('dtb_pagelayout', $sqlval, 'page_id = ? AND device_type_id = ?',
250                              array($page_id, $device_type_id));
251            // 戻り値用
252            $sqlval['page_id'] = $page_id;
253        }
254        return $sqlval;
255    }
256
257    /**
258     * DBへ更新を行うデータを生成する.
259     *
260     * @param integer $device_type_id
261     * @param integer $page_id
262     * @param string $page_name
263     * @param string $filename
264     * @param integer $header_chk
265     * @param integer $footer_chk
266     * @return array 更新データ
267     */
268    function lfGetUpdData($device_type_id, $page_id, $page_name, $filename, $header_chk, $footer_chk) {
269        $arrUpdData = array(
270            'header_chk'    => SC_Utils_Ex::sfChangeCheckBox($header_chk),  // ヘッダー使用
271            'footer_chk'    => SC_Utils_Ex::sfChangeCheckBox($footer_chk),  // フッター使用
272            'update_url'    => $_SERVER['HTTP_REFERER'],                    // 更新URL
273            'update_date'   => 'now()',
274        );
275
276        // ベースデータの場合には変更しない。
277        if (!$this->objLayout->lfCheckBaseData($page_id, $device_type_id)) {
278            $arrUpdData['page_name']    = $page_name;
279            $arrUpdData['url']          = $filename . '.php';
280            $arrUpdData['filename']     = $filename; // 拡張子を付加しない
281        }
282
283        return $arrUpdData;
284    }
285
286    /**
287     * ページデータを削除する.
288     *
289     * @param integer $page_id ページID
290     * @return void
291     */
292    function lfDeletePageData($page_id, $device_type_id){
293        $this->objLayout->lfDelPageData($page_id, $device_type_id);
294        $this->objDisplay->reload(array("device_type_id" => $device_type_id), true);
295    }
296
297    /**
298     * 入力項目のエラーチェックを行う.
299     *
300     * @param array $arrData 入力データ
301     * @param integer $device_type_id 端末種別ID
302     * @return array エラー情報
303     */
304    function lfErrorCheck($array, $device_type_id) {
305        $objErr = new SC_CheckError_Ex($array);
306        $objErr->doFunc(array("名称", "page_name", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
307        $objErr->doFunc(array('URL', 'url', STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
308
309        // URLチェック
310        $okUrl = true;
311        foreach (explode('/', $array['url']) as $url_part) {
312            if (!ereg( '^[a-zA-Z0-9:_~\.-]+$', $url_part)) {
313                $okUrl = false;
314            }
315            if ($url_part == '.' || $url_part == '..') {
316                $okUrl = false;
317            }
318        }
319        if (!$okUrl) {
320            $objErr->arrErr['url'] = "※ URLを正しく入力してください。<br />";
321        }
322
323        // 同一のURLが存在している場合にはエラー
324        $params = array();
325
326        $sqlWhere = 'url = ?';
327        $params[] = $this->objLayout->getUserDir($device_type_id) . $array['url'] . '.php';
328
329        // プレビュー用のレコードは除外
330        $sqlWhere .= ' AND page_id <> 0';
331
332        // 変更の場合、自身のレコードは除外
333        if (strlen($array['page_id']) != 0) {
334            $sqlWhere .= ' AND page_id <> ?';
335            $params[] = $array['page_id'];
336        }
337
338        $arrChk = $this->objLayout->lfgetPageData($sqlWhere , $params);
339
340        if (count($arrChk) >= 1) {
341            $objErr->arrErr['url'] = '※ 同じURLのデータが存在しています。別のURLを付けてください。<br />';
342        }
343
344        return $objErr->arrErr;
345    }
346
347    /**
348     * ファイルを作成する.
349     *
350     * @param string $path テンプレートファイルのパス
351     * @param string $data テンプレートの内容
352     * @return void
353     */
354    function lfCreateFile($path, $data){
355
356        // ディレクトリが存在していなければ作成する
357        if (!is_dir(dirname($path))) {
358            mkdir(dirname($path), 0777, true); // FIXME (PHP4)
359        }
360
361        // ファイル作成
362        $fp = fopen($path,'w');
363        if ($fp === false) {
364            SC_Utils_Ex::sfDispException();
365        }
366        $ret = fwrite($fp, $data);
367        if ($ret === false) {
368            SC_Utils_Ex::sfDispException();
369        }
370        fclose($fp);
371    }
372
373    /**
374     * PHPファイルを作成する.
375     *
376     * @param string $path PHPファイルのパス
377     * @return void
378     */
379    function lfCreatePHPFile($url, $device_type_id){
380
381        $path = USER_REALDIR . $url . ".php";
382
383        // カスタマイズを考慮し、上書きしない。(#831)
384        if (file_exists($path)) {
385            return;
386        }
387
388        // php保存先ディレクトリが存在していなければ作成する
389        if (!is_dir(dirname($path))) {
390            mkdir(dirname($path), 0777, true); // FIXME (PHP4)
391        }
392
393        // ベースとなるPHPファイルの読み込み
394        if (file_exists(USER_DEF_PHP_REALFILE)){
395            $php_data = file_get_contents(USER_DEF_PHP_REALFILE);
396        }
397
398        // require.phpの場所を書き換える
399        $defaultStrings = "exit; // Don't rewrite. This line is rewritten by EC-CUBE.";
400        $replaceStrings = "require_once '" . str_repeat('../', substr_count($url, '/')) . "../require.php';";
401        $php_data = str_replace($defaultStrings, $replaceStrings, $php_data);
402
403        // phpファイルの作成
404        $fp = fopen($path,'w');
405        fwrite($fp, $php_data);
406        fclose($fp);
407    }
408
409}
410?>
Note: See TracBrowser for help on using the repository browser.