source: branches/version-2_12-dev/data/class/pages/admin/LC_Page_Admin.php @ 21481

Revision 21481, 4.2 KB checked in by Seasoft, 12 years ago (diff)

#1613 (ソース整形・ソースコメントの改善)

  • Zend Framework PHP 標準コーディング規約への準拠を高めた
  • 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/LC_Page_Ex.php';
26
27/**
28 * 管理者ログイン のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin extends LC_Page_Ex {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        $this->template = MAIN_FRAME;
46
47        //IP制限チェック
48        $allow_hosts = unserialize(ADMIN_ALLOW_HOSTS);
49        if (is_array($allow_hosts) && count($allow_hosts) > 0) {
50            if (array_search($_SERVER['REMOTE_ADDR'],$allow_hosts) === FALSE) {
51                SC_Utils_Ex::sfDispError(AUTH_ERROR);
52            }
53        }
54
55        //SSL制限チェック
56        if (ADMIN_FORCE_SSL == TRUE) {
57            if (SC_Utils_Ex::sfIsHTTPS() === false) {
58                SC_Response_Ex::sendRedirect($_SERVER['REQUEST_URI'], $_GET, FALSE, TRUE);
59            }
60        }
61
62        $this->tpl_authority = $_SESSION['authority'];
63
64        // ディスプレイクラス生成
65        $this->objDisplay = new SC_Display_Ex();
66        if ($_SERVER['PHP_SELF'] !== ROOT_URLPATH . ADMIN_DIR . "system/plugin.php") {
67            // スーパーフックポイントを実行.
68            $objPlugin = SC_Helper_Plugin_Ex::getSingletonInstance();
69            $objPlugin->doAction('lc_page_preProcess', array($this));
70        }
71
72        // トランザクショントークンの検証と生成
73        $this->doValidToken(true);
74        $this->setTokenTo();
75    }
76
77    /**
78     * Page のプロセス.
79     *
80     * @return void
81     */
82    function process() {
83    }
84
85    /**
86     * Page のレスポンス送信.
87     *
88     * @return void
89     */
90    function sendResponse() {
91
92        if ($_SERVER['PHP_SELF'] !== ROOT_URLPATH . ADMIN_DIR . "system/plugin.php") {
93
94            // プラグインによってトランスフォームされたテンプレートがあればセットする
95            $objPlugin = SC_Helper_Plugin_Ex::getSingletonInstance();
96            $plugin_tmplpath = $objPlugin->getPluginTemplateCachePath($this);
97            if (file_exists($plugin_tmplpath)) $this->tpl_mainpage = $plugin_tmplpath;
98
99            // スーパーフックポイントを実行.
100            $objPlugin = SC_Helper_Plugin_Ex::getSingletonInstance();
101            $objPlugin->doAction('lc_page_process', array($this));
102
103            // HeadNaviにpluginテンプレートを追加する.
104            $objTemplateTransformList = SC_Plugin_Template_Transform_List::getSingletonInstance();
105            $objTemplateTransformList->setHeadNaviBlocs($this->arrPageLayout['HeadNavi']);
106        }
107
108        $this->objDisplay->prepare($this, true);
109        $this->objDisplay->response->write();
110    }
111
112    /**
113     * デストラクタ.
114     *
115     * @return void
116     */
117    function destroy() {
118        parent::destroy();
119    }
120
121    /**
122     * ログ出力を行う.
123     *
124     * ログイン中の管理者IDを含めてログ出力します.
125     *
126     * @access protected
127     * @param string $mess ログメッセージ
128     * @param string $log_level ログレベル('Info' or 'Debug')
129     * @return void
130     */
131    function log($mess, $log_level) {
132        $mess = $mess . " id=" . $_SESSION['login_id'] . "(" . $_SESSION['authority'] . ")" . "[" . session_id() . "]";
133
134        GC_Utils_Ex::gfAdminLog($mess, $log_level);
135    }
136
137}
Note: See TracBrowser for help on using the repository browser.