source: branches/comu-ver2/data/class/pages/admin/design/LC_Page_Admin_Design_MainEdit.php @ 18701

Revision 18701, 17.1 KB checked in by nanasess, 12 years ago (diff)

Copyright の更新(#601)

  • Property svn:eol-style set to LF
  • Property svn:keywords set to "Id Revision Date"
  • 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_PATH . "pages/LC_Page.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 {
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->user_URL     = USER_URL;
49        $this->text_row     = 13;
50        $this->tpl_subno = "main_edit";
51        $this->tpl_mainno = "design";
52        $this->tpl_subtitle = 'ページ詳細設定';
53    }
54
55    /**
56     * Page のプロセス.
57     *
58     * @return void
59     */
60    function process() {
61        $objView = new SC_AdminView();
62        $this->objLayout = new SC_Helper_PageLayout_Ex();
63
64        // 認証可否の判定
65        $objSess = new SC_Session();
66        SC_Utils_Ex::sfIsSuccess($objSess);
67
68        // ページ一覧を取得
69        $this->arrPageList = $this->objLayout->lfgetPageData();
70       
71        // ブロックIDを取得
72        if (isset($_POST['page_id'])) {
73            $page_id = $_POST['page_id'];
74        }else if (isset($_GET['page_id'])){
75            $page_id = $_GET['page_id'];
76        }else{
77            $page_id = '';
78        }
79
80        $this->page_id = $page_id;
81
82        // メッセージ表示
83        if (isset($_GET['msg']) && $_GET['msg'] == "on"){
84            $this->tpl_onload="alert('登録が完了しました。');";
85        }
86
87        // page_id が指定されている場合にはテンプレートデータの取得
88        if (is_numeric($page_id) and $page_id != '') {
89            $this->lfGetPageData($page_id, $objView);
90        }
91
92        if (!isset($_POST['mode'])) $_POST['mode'] = "";
93       
94        // プレビュー処理
95        if ($_POST['mode'] == 'preview') {
96            $this->lfPreviewPageData($page_id);
97            exit;
98        }
99
100        // データ登録処理
101        if ($_POST['mode'] == 'confirm') {
102            $this->lfConfirmPageData($page_id);
103        }
104
105        // データ削除処理 ベースデータでなければファイルを削除
106        if ($_POST['mode'] == 'delete' and !$this->objLayout->lfCheckBaseData($page_id)) {
107            $this->lfDeletePageData($page_id);
108            exit;
109        }
110
111        // 画面の表示
112        $objView->assignobj($this);
113        $objView->display(MAIN_FRAME);
114    }
115
116    /**
117     * デストラクタ.
118     *
119     * @return void
120     */
121    function destroy() {
122        parent::destroy();
123    }
124
125    /**
126     * ページデータを取得する.
127     *
128     * @param integer $page_id ページID
129     * @param object $objView ビューオブジェクト
130     * @return void
131     */
132    function lfGetPageData($page_id, $objView){
133        $arrPageData = $this->objLayout->lfgetPageData(" page_id = ? " , array($page_id));
134
135        if (strlen($arrPageData[0]['filename']) == 0) {
136            $this->arrErr['page_id_err'] = "※ 指定されたページは編集できません。";
137            // 画面の表示
138            $objView->assignobj($this);
139            $objView->display(MAIN_FRAME);
140            exit;
141        }
142
143        // テンプレートファイルが存在していれば読み込む
144        $tpl_file =  USER_TEMPLATE_PATH . "/" . TEMPLATE_NAME . "/" . $arrPageData[0]['filename'] . ".tpl";
145        if (file_exists($tpl_file)){
146            $arrPageData[0]['tpl_data'] = file_get_contents($tpl_file);
147        // 存在してなければ, 指定されたテンプレートのファイルを読み込む
148        } else {
149            $arrPageData[0]['tpl_data'] = file_get_contents(TEMPLATE_DIR . $arrPageData[0]['filename'] . ".tpl");
150        }
151
152        // チェックボックスの値変更
153        $arrPageData[0]['header_chk'] = SC_Utils_Ex::sfChangeCheckBox($arrPageData[0]['header_chk'], true);
154        $arrPageData[0]['footer_chk'] = SC_Utils_Ex::sfChangeCheckBox($arrPageData[0]['footer_chk'], true);
155
156        // ディレクトリを画面表示用に編集
157        $arrPageData[0]['directory'] = str_replace(USER_DIR, '', $arrPageData[0]['php_dir']);
158
159        $this->arrPageData = $arrPageData[0];
160    }
161
162    /**
163     * プレビュー画面を表示する.
164     *
165     * @param integer $page_id ページID
166     * @return void
167     */
168    function lfPreviewPageData($page_id){
169
170        $page_id_old = $page_id;
171        // プレビューの場合ページIDを0にセットする。
172        $page_id = "0";
173        $url = basename($_POST['url']);
174       
175        $tmpPost = $_POST;
176        $tmpPost['page_id'] = $page_id;
177        $tmpPost['url'] = $url;
178        $tmpPost['tpl_dir'] = USER_PATH . "templates/preview/";
179       
180        $arrPreData = $this->objLayout->lfgetPageData("page_id = ?" , array($page_id));
181       
182        // tplファイルの削除 (XXX: 処理の意図が不明。存在していると都合が悪いファイル?)
183        $del_tpl = USER_PATH . "templates/" . $arrPreData[0]['filename'] . '.tpl';
184        if (file_exists($del_tpl)){
185            unlink($del_tpl);
186        }
187
188        // DBへデータを更新する
189        $this->lfEntryPageData($tmpPost);
190
191        // TPLファイル作成
192        $preview_tpl = USER_PATH . "templates/preview/" . TEMPLATE_NAME . "/" . $url . '.tpl';
193        $this->lfCreateFile($preview_tpl, $_POST['tpl_data']);
194       
195        // blocposition を削除
196        $objDBConn = new SC_DbConn;     // DB操作オブジェクト
197        $sql = 'delete from dtb_blocposition where page_id = 0';
198        $ret = $objDBConn->query($sql);
199
200        if ($page_id_old != "") {
201            // 登録データを取得
202            $sql = "SELECT 0, target_id, bloc_id, bloc_row FROM dtb_blocposition WHERE page_id = ?";
203            $ret = $objDBConn->getAll($sql,array($page_id_old));
204
205            if (count($ret) > 0) {
206
207                // blocposition を複製
208                $sql = " insert into dtb_blocposition (";
209                $sql .= "     page_id,";
210                $sql .= "     target_id,";
211                $sql .= "     bloc_id,";
212                $sql .= "     bloc_row";
213                $sql .= "     )values(?, ?, ?, ?)";
214
215                // 取得件数文INSERT実行
216                foreach($ret as $key => $val){
217                    $ret = $objDBConn->query($sql,$val);
218                }
219            }
220        }
221        $_SESSION['preview'] = "ON";
222        $this->sendRedirect($this->getLocation(URL_DIR . "preview/" . DIR_INDEX_URL, array("filename" => $arrPageData[0]["filename"])));
223
224    }
225
226    /**
227     * データ登録処理.
228     *
229     * @param integer $page_id ページID
230     * @return void
231     */
232    function lfConfirmPageData($page_id){
233        // エラーチェック
234        $this->arrErr = $this->lfErrorCheck($_POST);
235
236        // エラーがなければ更新処理を行う
237        if (count($this->arrErr) == 0) {
238            // DBへデータを更新する
239            $this->lfEntryPageData($_POST);
240
241            // ベースデータでなければファイルを削除し、PHPファイルを作成する
242            if (!$this->objLayout->lfCheckBaseData($page_id)) {
243                // ファイル削除
244                $this->objLayout->lfDelFile($this->arrPageData);
245                // PHPファイル作成
246                $this->lfCreatePHPFile($_POST['url']);
247            }
248
249            // TPLファイル作成
250            $cre_tpl = USER_TEMPLATE_PATH . "/" . TEMPLATE_NAME . "/" . basename($_POST['url']) . '.tpl';
251            $this->lfCreateFile($cre_tpl, $_POST['tpl_data']);
252
253            // 新規作成の場合、
254            if ($page_id == '') {
255                // ページIDを取得する
256                $arrPageData = $this->objLayout->lfgetPageData(" url = ? AND page_id <> 0" , array(USER_DIR . $_POST['url'] . '.php'));
257                $page_id = $arrPageData[0]['page_id'];
258            }
259            $this->sendRedirect($this->getLocation("./main_edit.php",
260                                    array("page_id" => $page_id,
261                                          "msg"     => "on")));
262            exit;
263        } else {
264            // エラーがあれば入力時のデータを表示する
265            $this->arrPageData = $_POST;
266            $this->arrPageData['header_chk'] = SC_Utils_Ex::sfChangeCheckBox(SC_Utils_Ex::sfChangeCheckBox($_POST['header_chk']), true);
267            $this->arrPageData['footer_chk'] = SC_Utils_Ex::sfChangeCheckBox(SC_Utils_Ex::sfChangeCheckBox($_POST['footer_chk']), true);
268            $this->arrPageData['directory'] = '';
269            $this->arrPageData['filename'] = $_POST['url'];
270        }
271    }
272
273    /**
274     * ブロック情報を更新する.
275     *
276     * @param array $arrData 更新データ
277     * @return integer 更新結果
278     */
279    function lfEntryPageData($arrData){
280        $objDBConn = new SC_DbConn;     // DB操作オブジェクト
281        $sql = "";                      // データ更新SQL生成用
282        $ret = "";                      // データ更新結果格納用
283        $arrUpdData = array();          // 更新データ生成用
284        $arrChk = array();              // 排他チェック用
285
286        // 更新データの変換
287        $arrUpdData = $this->lfGetUpdData($arrData);
288
289        // データが存在しているかチェックを行う
290        if($arrData['page_id'] !== ''){
291            $arrChk = $this->objLayout->lfgetPageData("page_id = ?", array($arrData['page_id']));
292        }
293       
294        // page_id が空 若しくは データが存在していない場合にはINSERTを行う
295        if ($arrData['page_id'] === '' or !isset($arrChk[0])) {
296            // SQL生成
297            $sql = " INSERT INTO dtb_pagelayout ";
298            $sql .= " ( ";
299            $sql .= "     page_name";
300            $sql .= "     ,url";
301            $sql .= "     ,php_dir";
302            $sql .= "     ,tpl_dir";
303            $sql .= "     ,filename";
304            $sql .= "     ,header_chk";
305            $sql .= "     ,footer_chk";
306            $sql .= "     ,update_url";
307            $sql .= "     ,create_date";
308            $sql .= "     ,update_date";
309            $sql .= " ) VALUES ( ?,?,?,?,?,?,?,?,now(),now() )";
310            $sql .= " ";
311        } else {
312            // データが存在してる場合にはアップデートを行う
313            // SQL生成
314            $sql = " UPDATE dtb_pagelayout ";
315            $sql .= " SET";
316            $sql .= "     page_name = ? ";
317            $sql .= "     ,url = ? ";
318            $sql .= "     ,php_dir = ? ";
319            $sql .= "     ,tpl_dir = ? ";
320            $sql .= "     ,filename = ? ";
321            $sql .= "     ,header_chk = ? ";
322            $sql .= "     ,footer_chk = ? ";
323            $sql .= "     ,update_url = ? ";
324            $sql .= "     ,update_date = now() ";
325            $sql .= " WHERE page_id = ?";
326            $sql .= " ";
327
328            // 更新データにブロックIDを追加
329            array_push($arrUpdData, $arrData['page_id']);
330        }
331
332        // SQL実行
333        $ret = $objDBConn->query($sql,$arrUpdData);
334
335        return $ret;
336    }
337
338    /**
339     * DBへ更新を行うデータを生成する.
340     *
341     * @param array $arrData 更新データ
342     * @return array 更新データ
343     */
344    function lfGetUpdData($arrData){
345        // ベースデータの場合には変更しない。
346        if ($this->objLayout->lfCheckBaseData($arrData['page_id'])) {
347            $arrPageData = $this->objLayout->lfgetPageData( ' page_id = ? ' , array($arrData['page_id']));
348           
349            $name = $arrPageData[0]['page_name'] ;
350            $url = $arrPageData[0]['url'];
351            $php_dir = $arrPageData[0]['php_dir'];
352            $filename = $arrPageData[0]['filename'];
353        } else {
354            $name = $arrData['page_name'] ;
355            $url = USER_DIR . $arrData['url'] . '.php';
356            $php_dir = dirname($url);
357            if ($php_dir == '.') {
358                $php_dir = '';
359            } else {
360                $php_dir .= '/';
361            }
362            $tpl_dir = substr(TPL_DIR, strlen(URL_DIR));
363            $filename = basename($arrData['url']); // 拡張子を付加しない
364        }
365       
366        // 更新データ配列の作成
367        $arrUpdData = array(
368            $name                                                   // 名称
369            ,$url                                                   // URL
370            ,$php_dir                                               // PHPディレクトリ
371            ,$tpl_dir                                               // TPLディレクトリ
372            ,$filename                                              // ファイル名
373            ,SC_Utils_Ex::sfChangeCheckBox($arrData['header_chk'])  // ヘッダー使用
374            ,SC_Utils_Ex::sfChangeCheckBox($arrData['footer_chk'])  // フッター使用
375            ,$_SERVER['HTTP_REFERER']                               // 更新URL
376        );
377
378        return $arrUpdData;
379    }
380
381    /**
382     * ページデータを削除する.
383     *
384     * @param integer $page_id ページID
385     * @return void
386     */
387    function lfDeletePageData($page_id){
388        $this->objLayout->lfDelPageData($_POST['page_id']);
389        $this->sendRedirect($this->getLocation("./main_edit.php"));
390    }
391
392    /**
393     * 入力項目のエラーチェックを行う.
394     *
395     * @param array $arrData 入力データ
396     * @return array エラー情報
397     */
398    function lfErrorCheck($array) {
399        $objErr = new SC_CheckError($array);
400        $objErr->doFunc(array("名称", "page_name", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
401        $objErr->doFunc(array("URL", "url", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
402       
403        // URLチェック
404        $okUrl = true;
405        foreach (explode('/', $array['url']) as $url_part) {
406            if (!ereg( '^[a-zA-Z0-9:_~\.-]+$', $url_part)) {
407                $okUrl = false;
408            }
409            if ($url_part == '.' || $url_part == '..') {
410                $okUrl = false;
411            }
412        }
413        if (!$okUrl) {
414            $objErr->arrErr['url'] = "※ URLを正しく入力してください。<br />";
415        }
416       
417        // 同一のURLが存在している場合にはエラー
418        $sqlWhere = '';
419        $params = array();
420       
421        $sqlWhere .= ' (url = ? OR url = ?)';
422        $params[] = USER_DIR . $array['url'] . '.php';
423        $params[] = USER_URL . $array['url'] . '.php'; // 従来形式
424       
425        // プレビュー用のレコードは除外
426        $sqlWhere .= ' AND page_id <> 0';
427       
428        // 変更の場合、自身のレコードは除外
429        if (strlen($array['page_id']) != 0) {
430            $sqlWhere .= ' AND page_id <> ?';
431            $params[] = $array['page_id'];
432        }
433       
434        $arrChk = $this->objLayout->lfgetPageData($sqlWhere , $params);
435       
436        if (count($arrChk) >= 1) {
437            $objErr->arrErr['url'] = '※ 同じURLのデータが存在しています。別のURLを付けてください。<br />';
438        }
439       
440        return $objErr->arrErr;
441    }
442
443    /**
444     * ファイルを作成する.
445     *
446     * @param string $path テンプレートファイルのパス
447     * @param string $data テンプレートの内容
448     * @return void
449     */
450    function lfCreateFile($path, $data){
451
452        // ディレクトリが存在していなければ作成する
453        if (!is_dir(dirname($path))) {
454            mkdir(dirname($path));
455        }
456
457        // ファイル作成
458        $fp = fopen($path,"w");
459        fwrite($fp, $data); // FIXME いきなり POST はちょっと...
460        fclose($fp);
461    }
462
463    /**
464     * PHPファイルを作成する.
465     *
466     * @param string $path PHPファイルのパス
467     * @return void
468     */
469    function lfCreatePHPFile($url){
470
471        $path = USER_PATH . $url . ".php";
472       
473        // php保存先ディレクトリが存在していなければ作成する
474        if (!is_dir(dirname($path))) {
475            mkdir(dirname($path));
476        }
477
478        // ベースとなるPHPファイルの読み込み
479        if (file_exists(USER_DEF_PHP)){
480            $php_data = file_get_contents(USER_DEF_PHP);
481        }
482
483        // require.phpの場所を書き換える
484        $php_data = str_replace("###require###", str_repeat('../', substr_count($url, '/')) . '../require.php', $php_data);
485
486        // phpファイルの作成
487        $fp = fopen($path,"w");
488        fwrite($fp, $php_data);
489        fclose($fp);
490    }
491
492}
493?>
Note: See TracBrowser for help on using the repository browser.