source: branches/feature-module-update/data/class/pages/admin/design/LC_Page_Admin_Design_MainEdit.php @ 15686

Revision 15686, 14.5 KB checked in by nanasess, 17 years ago (diff)

ページ削除処理の修正

  • Property svn:keywords set to "Id Revision Date"
Line 
1<?php
2/*
3 * Copyright(c) 2000-2007 LOCKON CO.,LTD. All Rights Reserved.
4 *
5 * http://www.lockon.co.jp/
6 */
7
8// {{{ requires
9require_once(CLASS_PATH . "pages/LC_Page.php");
10
11/**
12 * メイン編集 のページクラス.
13 *
14 * @package Page
15 * @author LOCKON CO.,LTD.
16 * @version $Id$
17 */
18class LC_Page_Admin_Design_MainEdit extends LC_Page {
19
20    // }}}
21    // {{{ functions
22
23    /**
24     * Page を初期化する.
25     *
26     * @return void
27     */
28    function init() {
29        parent::init();
30        $this->tpl_mainpage = 'design/main_edit.tpl';
31        $this->tpl_subnavi  = 'design/subnavi.tpl';
32        $this->user_URL     = USER_URL;
33        $this->text_row     = 13;
34        $this->tpl_subno = "main_edit";
35        $this->tpl_mainno = "design";
36        $this->tpl_subtitle = 'ページ詳細設定';
37
38    }
39
40    /**
41     * Page のプロセス.
42     *
43     * @return void
44     */
45    function process() {
46        $objView = new SC_AdminView();
47        $this->objLayout = new SC_Helper_PageLayout_Ex();
48
49        // 認証可否の判定
50        $objSess = new SC_Session();
51        SC_Utils_Ex::sfIsSuccess($objSess);
52
53        // ページ一覧を取得
54        $this->arrPageList = $this->objLayout->lfgetPageData();
55
56        // ブロックIDを取得
57        if (isset($_POST['page_id'])) {
58            $page_id = $_POST['page_id'];
59        }else if (isset($_GET['page_id'])){
60            $page_id = $_GET['page_id'];
61        }else{
62            $page_id = '';
63        }
64
65        $this->page_id = $page_id;
66
67        // メッセージ表示
68        if (isset($_GET['msg']) && $_GET['msg'] == "on"){
69            $this->tpl_onload="alert('登録が完了しました。');";
70        }
71
72        // page_id が指定されている場合にはテンプレートデータの取得
73        if (is_numeric($page_id) and $page_id != '') {
74            $arrPageData = $this->objLayout->lfgetPageData(" page_id = ? " , array($page_id));
75
76            if ($arrPageData[0]['tpl_dir'] === "") {
77                $this->arrErr['page_id_err'] = "※ 指定されたページは編集できません。";
78                // 画面の表示
79                $objView->assignobj($this);
80                $objView->display(MAIN_FRAME);
81                exit;
82            }
83
84            // テンプレートファイルが存在していれば読み込む
85            $tpl_file = HTML_PATH . $arrPageData[0]['tpl_dir'] . $arrPageData[0]['filename'] . ".tpl";
86            if (file_exists($tpl_file)){
87                $arrPageData[0]['tpl_data'] = file_get_contents($tpl_file);
88            }
89
90            // チェックボックスの値変更
91            $arrPageData[0]['header_chk'] = SC_Utils_Ex::sfChangeCheckBox($arrPageData[0]['header_chk'], true);
92            $arrPageData[0]['footer_chk'] = SC_Utils_Ex::sfChangeCheckBox($arrPageData[0]['footer_chk'], true);
93
94            // ディレクトリを画面表示用に編集
95            $arrPageData[0]['directory'] = str_replace( USER_DIR,'', $arrPageData[0]['php_dir']);
96
97            $this->arrPageData = $arrPageData[0];
98        }
99
100        // プレビュー処理
101        if (!isset($_POST['mode'])) $_POST['mode'] = "";
102
103        if ($_POST['mode'] == 'preview') {
104
105            $page_id_old = $page_id;
106            $page_id = "0";
107            $url = uniqid("");
108
109            $_POST['page_id'] = $page_id;
110            $_POST['url'] = $url;
111
112            $arrPreData = $this->objLayout->lfgetPageData(" page_id = ? " , array($page_id));
113
114            // tplファイルの削除
115            $del_tpl = USER_PATH . "templates/" . $arrPreData[0]['filename'] . '.tpl';
116            if (file_exists($del_tpl)){
117                unlink($del_tpl);
118            }
119
120            // DBへデータを更新する
121            $this->lfEntryPageData($_POST);
122
123            // TPLファイル作成
124            $cre_tpl = USER_PATH . "templates/" . $url . '.tpl';
125            $this->lfCreateFile($cre_tpl);
126
127            // blocposition を削除
128            $objDBConn = new SC_DbConn;     // DB操作オブジェクト
129            $sql = 'delete from dtb_blocposition where page_id = 0';
130            $ret = $objDBConn->query($sql);
131
132            if ($page_id_old != "") {
133                // 登録データを取得
134                $sql = "SELECT 0, target_id, bloc_id, bloc_row FROM dtb_blocposition WHERE page_id = ?";
135                $ret = $objDBConn->getAll($sql,array($page_id_old));
136
137                if (count($ret) > 0) {
138
139                    // blocposition を複製
140                    $sql = " insert into dtb_blocposition (";
141                    $sql .= "     page_id,";
142                    $sql .= "     target_id,";
143                    $sql .= "     bloc_id,";
144                    $sql .= "     bloc_row";
145                    $sql .= "     )values(?, ?, ?, ?)";
146
147                    // 取得件数文INSERT実行
148                    foreach($ret as $key => $val){
149                        $ret = $objDBConn->query($sql,$val);
150                    }
151                }
152
153            }
154
155            $_SESSION['preview'] = "ON";
156            $this->sendRedirect($this->getLocation(URL_DIR . "preview/index.php"));
157        }
158
159        // データ登録処理
160        if ($_POST['mode'] == 'confirm') {
161
162            // エラーチェック
163            $this->arrErr = $this->lfErrorCheck($_POST);
164
165            // エラーがなければ更新処理を行う
166            if (count($this->arrErr) == 0) {
167
168                // DBへデータを更新する
169                $this->lfEntryPageData($_POST);
170
171                // ベースデータでなければファイルを削除し、PHPファイルを作成する
172                if (!$this->objLayout->lfCheckBaseData($page_id)) {
173                    // ファイル削除
174                    $this->objLayout->lfDelFile($arrPageData[0]);
175
176                    // PHPファイル作成
177                    $cre_php = USER_PATH . $_POST['url'] . ".php";
178                    $this->lfCreatePHPFile($cre_php);
179                }
180
181                // TPLファイル作成
182                $cre_tpl = dirname(USER_PATH . "templates/" . $_POST['url']) . "/" . basename($_POST['url']) . '.tpl';
183
184                $this->lfCreateFile($cre_tpl);
185
186                // 編集可能ページの場合にのみ処理を行う
187                if ($arrPageData[0]['edit_flg'] != 2) {
188                    // 新規作成した場合のために改にページIDを取得する
189                    $arrPageData = $this->objLayout->lfgetPageData(" url = ? " , array(USER_URL.$_POST['url'].".php"));
190                    $page_id = $arrPageData[0]['page_id'];
191                }
192                $this->sendRedirect($this->getLocation("./main_edit.php",
193                                        array("page_id" => $page_id,
194                                              "msg"     => "on")));
195            }else{
196                // エラーがあれば入力時のデータを表示する
197                $this->arrPageData = $_POST;
198                $this->arrPageData['header_chk'] = SC_Utils_Ex::sfChangeCheckBox(SC_Utils_Ex::sfChangeCheckBox($_POST['header_chk']), true);
199                $this->arrPageData['footer_chk'] = SC_Utils_Ex::sfChangeCheckBox(SC_Utils_Ex::sfChangeCheckBox($_POST['footer_chk']), true);
200                $this->arrPageData['directory'] = $_POST['url'];
201                $this->arrPageData['filename'] = "";
202            }
203        }
204
205        // データ削除処理 ベースデータでなければファイルを削除
206        if ($_POST['mode'] == 'delete' and  !$this->objLayout->lfCheckBaseData($page_id)) {
207            $this->objLayout->lfDelPageData($_POST['page_id']);
208            $this->sendRedirect($this->getLocation("./main_edit.php"));
209        }
210
211        // 画面の表示
212        $objView->assignobj($this);
213        $objView->display(MAIN_FRAME);
214    }
215
216    /**
217     * デストラクタ.
218     *
219     * @return void
220     */
221    function destroy() {
222        parent::destroy();
223    }
224
225    /**
226     * ブロック情報を更新する.
227     *
228     * @param array $arrData 更新データ
229     * @return integer 更新結果
230     */
231    function lfEntryPageData($arrData){
232        $objDBConn = new SC_DbConn;     // DB操作オブジェクト
233        $sql = "";                      // データ更新SQL生成用
234        $ret = "";                      // データ更新結果格納用
235        $arrUpdData = array();          // 更新データ生成用
236        $arrChk = array();              // 排他チェック用
237
238        // 更新データ生成
239        $arrUpdData = $this->lfGetUpdData($arrData);
240
241        // データが存在しているかチェックを行う
242        if($arrData['page_id'] !== ''){
243            $arrChk = $this->objLayout->lfgetPageData(" page_id = ?", array($arrData['page_id']));
244        }
245
246        // page_id が空 若しくは データが存在していない場合にはINSERTを行う
247        if ($arrData['page_id'] === '' or !isset($arrChk[0])) {
248            // SQL生成
249            $sql = " INSERT INTO dtb_pagelayout ";
250            $sql .= " ( ";
251            $sql .= "     page_name";
252            $sql .= "     ,url";
253            $sql .= "     ,php_dir";
254            $sql .= "     ,tpl_dir";
255            $sql .= "     ,filename";
256            $sql .= "     ,header_chk";
257            $sql .= "     ,footer_chk";
258            $sql .= "     ,update_url";
259            $sql .= "     ,create_date";
260            $sql .= "     ,update_date";
261            $sql .= " ) VALUES ( ?,?,?,?,?,?,?,?,now(),now() )";
262            $sql .= " ";
263        }else{
264            // データが存在してる場合にはアップデートを行う
265            // SQL生成
266            $sql = " UPDATE dtb_pagelayout ";
267            $sql .= " SET";
268            $sql .= "     page_name = ? ";
269            $sql .= "     ,url = ? ";
270            $sql .= "     ,php_dir = ? ";
271            $sql .= "     ,tpl_dir = ? ";
272            $sql .= "     ,filename = ? ";
273            $sql .= "     ,header_chk = ? ";
274            $sql .= "     ,footer_chk = ? ";
275            $sql .= "     ,update_url = ? ";
276            $sql .= "     ,update_date = now() ";
277            $sql .= " WHERE page_id = ?";
278            $sql .= " ";
279
280            // 更新データにブロックIDを追加
281            array_push($arrUpdData, $arrData['page_id']);
282        }
283
284        // SQL実行
285        $ret = $objDBConn->query($sql,$arrUpdData);
286
287        return $ret;
288    }
289
290    /**
291     * DBへ更新を行うデータを生成する.
292     *
293     * @param array $arrData 更新データ
294     * @return array 更新データ
295     */
296    function lfGetUpdData($arrData){
297
298        // ベースデータの場合には変更しない。
299        if ($this->objLayout->lfCheckBaseData($arrData['page_id'])) {
300            $arrPageData = $this->objLayout->lfgetPageData( ' page_id = ? ' , array($arrData['page_id']));
301
302            $name = $arrPageData[0]['page_name'] ;
303            $url = $arrPageData[0]['url'];
304            $php_dir = $arrPageData[0]['php_dir'];
305            $tpl_dir = $arrPageData[0]['tpl_dir'];
306            $filename = $arrPageData[0]['filename'];
307        }else{
308            $name = $arrData['page_name'] ;
309            $url = USER_URL.$arrData['url'].".php";
310            $php_dir = dirname(USER_DIR.$arrData['url'])."/";
311            $tpl_dir = dirname(USER_DIR."templates/".$arrData['url'])."/";
312            $filename = basename($arrData['url']);
313        }
314
315        // 更新データ配列の作成
316        $arrUpdData = array(
317                            $name                                       // 名称
318                            ,$url                                       // URL
319                            ,$php_dir                                   // PHPディレクトリ
320                            ,$tpl_dir                                   // TPLディレクトリ
321                            ,$filename                                  // ファイル名
322                            ,SC_Utils_Ex::sfChangeCheckBox($arrData['header_chk'])  // ヘッダー使用
323                            ,SC_Utils_Ex::sfChangeCheckBox($arrData['footer_chk'])  // フッター使用
324                            ,$_SERVER['HTTP_REFERER']                   // 更新URL
325                            );
326
327        return $arrUpdData;
328    }
329
330    /**
331     * 入力項目のエラーチェックを行う.
332     *
333     * @param array $arrData 入力データ
334     * @return array エラー情報
335     */
336    function lfErrorCheck($array) {
337        $objErr = new SC_CheckError($array);
338        $objErr->doFunc(array("名称", "page_name", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
339        $objErr->doFunc(array("URL", "url", STEXT_LEN), array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
340
341        // URLチェック
342        if (substr(strrev(trim($array['url'])),0,1) == "/") {
343            $objErr->arrErr['url'] = "※ URLを正しく入力してください。<br />";
344        }
345
346        $check_url = USER_URL . $array['url'] . ".php";
347        if( strlen($array['url']) > 0 && !ereg( "^https?://+($|[a-zA-Z0-9:_~=&\?\.\/-])+$", $check_url ) ) {
348            $objErr->arrErr['url'] = "※ URLを正しく入力してください。<br />";
349        }
350
351        // 同一のURLが存在している場合にはエラー
352        if(!isset($objErr->arrErr['url']) and $array['url'] !== ''){
353            $arrChk = $this->objLayout->lfgetPageData(" url = ? " , array(USER_URL . $array['url'].".php"));
354
355            if (count($arrChk[0]) >= 1 and $arrChk[0]['page_id'] != $array['page_id']) {
356                $objErr->arrErr['url'] = '※ 同じURLのデータが存在しています。別のURLを付けてください。';
357            }
358        }
359
360        return $objErr->arrErr;
361    }
362
363    /**
364     * ファイルを作成する.
365     *
366     * @param string $path テンプレートファイルのパス
367     * @return void
368     */
369    function lfCreateFile($path){
370
371        // ディレクトリが存在していなければ作成する
372        if (!is_dir(dirname($path))) {
373            mkdir(dirname($path));
374        }
375
376        // ファイル作成
377        $fp = fopen($path,"w");
378        fwrite($fp, $_POST['tpl_data']); // FIXME いきなり POST はちょっと...
379        fclose($fp);
380    }
381
382    /**
383     * PHPファイルを作成する.
384     *
385     * @param string $path PHPファイルのパス
386     * @return void
387     */
388    function lfCreatePHPFile($path){
389
390        // php保存先ディレクトリが存在していなければ作成する
391        if (!is_dir(dirname($path))) {
392            mkdir(dirname($path));
393        }
394
395        // ベースとなるPHPファイルの読み込み
396        if (file_exists(USER_DEF_PHP)){
397            $php_data = file_get_contents(USER_DEF_PHP);
398        }
399
400        // require.phpの場所を書き換える
401        $php_data = str_replace("###require###", HTML_PATH . "require.php", $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.