source: branches/version-2_13-dev/data/class/SC_Initial.php @ 22856

Revision 22856, 17.4 KB checked in by Seasoft, 11 years ago (diff)

#2043 (typo修正・ソース整形・ソースコメントの改善 for 2.13.0)

  • 主に空白・空白行の調整。もう少し整えたいが、一旦現状コミット。
  • 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
24/**
25 * アプリケーションの初期設定クラス.
26 *
27 * @author LOCKON CO.,LTD.
28 * @version $Id$
29 */
30class SC_Initial
31{
32    /**
33     * コンストラクタ.
34     */
35    function __construct()
36    {
37        /** EC-CUBEのバージョン */
38        define('ECCUBE_VERSION', '2.13.0-dev');
39    }
40
41    /**
42     * 初期設定を行う.
43     *
44     * @access protected
45     * @return void
46     */
47    function init()
48    {
49        $this->requireInitialConfig();
50        $this->defineDSN();                 // requireInitialConfig メソッドより後で実行
51        $this->defineDirectoryIndex();
52        $this->defineConstants();
53        $this->defineParameter();           // defineDirectoryIndex メソッドより後で実行
54        $this->complementParameter();       // defineConstants メソッドより後で実行
55        $this->phpconfigInit();             // defineConstants メソッドより後で実行
56        $this->createCacheDir();            // defineConstants メソッドより後で実行
57        $this->stripslashesDeepGpc();
58        $this->resetSuperglobalsRequest();  // stripslashesDeepGpc メソッドより後で実行
59        $this->setTimezone();               // 本当はエラーハンドラーより先に読みたい気も
60    }
61
62    /**
63     * 初期設定ファイルを読み込み, パスの設定を行う.
64     *
65     * @access protected
66     * @return void
67     */
68    function requireInitialConfig()
69    {
70        define('CONFIG_REALFILE', realpath(dirname(__FILE__)) . '/../config/config.php');
71        if (file_exists(CONFIG_REALFILE)) {
72            require_once CONFIG_REALFILE;
73        }
74    }
75
76    /**
77     * DSN を定義する.
78     *
79     * @access protected
80     * @return void
81     * @deprecated 下位互換用
82     */
83    function defineDSN()
84    {
85        if (defined('DB_TYPE') && defined('DB_USER') && defined('DB_PASSWORD')
86            && defined('DB_SERVER') && defined('DB_PORT') && defined('DB_NAME')
87        ) {
88            $dsn = DB_TYPE . '://' . DB_USER . ':' . DB_PASSWORD . '@' . DB_SERVER . ':' . DB_PORT . '/' . DB_NAME;
89            /** サイト用DB */
90            // ここで生成した DSN は使用せず, SC_Query のコンストラクタでパラメータを設定する.
91            define('DEFAULT_DSN', $dsn);
92        }
93    }
94
95    /**
96     * @deprecated
97     */
98    function setErrorReporting()
99    {
100        error_reporting(E_ALL & ~E_NOTICE);
101        // PHP 5.3.0対応
102        if (error_reporting() > 6143) {
103            error_reporting(E_ALL & ~E_NOTICE & ~E_DEPRECATED);
104        }
105    }
106
107    /**
108     * マルチバイト文字列設定を行う.
109     *
110     * TODO SJIS-win や, eucJP-win への対応
111     *
112     * @access protected
113     * @return void
114     */
115    function phpconfigInit()
116    {
117        ini_set('html_errors', '1');
118        ini_set('mbstring.http_input', CHAR_CODE);
119        ini_set('mbstring.http_output', CHAR_CODE);
120        ini_set('auto_detect_line_endings', 1);
121        ini_set('default_charset', CHAR_CODE);
122        ini_set('mbstring.detect_order', 'auto');
123        ini_set('mbstring.substitute_character', 'none');
124
125        mb_language('ja'); // mb_internal_encoding() より前に
126        // TODO .htaccess の mbstring.language を削除できないか検討
127
128        mb_internal_encoding(CHAR_CODE); // mb_language() より後で
129
130        ini_set('arg_separator.output', '&');
131
132        //ロケールを明示的に設定
133        $res = setlocale(LC_ALL, LOCALE);
134        if ($res === FALSE) {
135            // TODO: Windows上のロケール設定が正常に働かない場合があることに暫定的に対応
136            // ''を指定するとApache実行環境の環境変数が使われる
137            // See also: http://php.net/manual/ja/function.setlocale.php
138            setlocale(LC_ALL, '');
139        }
140
141        // #1849 (文字エンコーディングの検出を制御する)
142        mb_detect_order(array('UTF-8', 'SJIS-win', 'eucJP-win'));
143    }
144
145    /**
146     * 定数 DIR_INDEX_PATH を設定する.
147     *
148     * @access protected
149     * @return void
150     */
151    function defineDirectoryIndex()
152    {
153        // DirectoryIndex の実ファイル名
154        if (!defined('DIR_INDEX_FILE')) {
155            define('DIR_INDEX_FILE', 'index.php');
156        }
157
158        $useFilenameDirIndex = is_bool(USE_FILENAME_DIR_INDEX)
159            ? USE_FILENAME_DIR_INDEX
160            : (isset($_SERVER['SERVER_SOFTWARE']) ? substr($_SERVER['SERVER_SOFTWARE'], 0, 13) == 'Microsoft-IIS' : false)
161        ;
162
163        // DIR_INDEX_FILE にアクセスする時の URL のファイル名部を定義する
164        if ($useFilenameDirIndex === true) {
165            // ファイル名を使用する
166            define('DIR_INDEX_PATH', DIR_INDEX_FILE);
167        } else {
168            // ファイル名を使用しない
169            define('DIR_INDEX_PATH', '');
170        }
171    }
172
173    /**
174     * パラメータを設定する.
175     *
176     * mtb_constants.php を読み込んで定数として定義する.
177     * キャッシュディレクトリに存在しない場合は, 初期データからコピーする.
178     *
179     * @access protected
180     * @return void
181     */
182    function defineParameter()
183    {
184        $errorMessage
185            = '<div style="color: #F00; font-weight: bold; background-color: #FEB; text-align: center">'
186            . CACHE_REALDIR
187            . ' にユーザ書込み権限(777等)を付与して下さい。</div>';
188
189        // 定数を設定
190        if (is_file(CACHE_REALDIR . 'mtb_constants.php')) {
191            require_once CACHE_REALDIR . 'mtb_constants.php';
192
193            // キャッシュが無ければ, 初期データからコピー
194        } elseif (is_file(CACHE_REALDIR . '../mtb_constants_init.php')) {
195            $mtb_constants = file_get_contents(CACHE_REALDIR . '../mtb_constants_init.php');
196            if (is_writable(CACHE_REALDIR)) {
197                $handle = fopen(CACHE_REALDIR . 'mtb_constants.php', 'w');
198                if (!$handle) {
199                    die($errorMessage);
200                }
201                if (fwrite($handle, $mtb_constants) === false) {
202                    die($errorMessage);
203                }
204                fclose($handle);
205
206                require_once CACHE_REALDIR . 'mtb_constants.php';
207            } else {
208                die($errorMessage);
209            }
210        } else {
211            die(CACHE_REALDIR . '../mtb_constants_init.php が存在しません');
212        }
213    }
214
215    /**
216     * パラメーターの補完
217     *
218     * ソースのみ差し替えたバージョンアップを考慮したもの。
219     * $this->defineIfNotDefined() で定義することを想定
220     *
221     * @access protected
222     * @return void
223     */
224    function complementParameter()
225    {
226    }
227
228    /**
229     * 各種キャッシュディレクトリを生成する.
230     *
231     * Smarty キャッシュディレクトリを生成する.
232     *
233     * @access protected
234     * @return void
235     */
236    function createCacheDir()
237    {
238        if (defined('HTML_REALDIR')) {
239            umask(0);
240            if (!file_exists(COMPILE_REALDIR)) {
241                mkdir(COMPILE_REALDIR);
242            }
243
244            if (!file_exists(MOBILE_COMPILE_REALDIR)) {
245                mkdir(MOBILE_COMPILE_REALDIR);
246            }
247
248            if (!file_exists(SMARTPHONE_COMPILE_REALDIR)) {
249                mkdir(SMARTPHONE_COMPILE_REALDIR);
250            }
251
252            if (!file_exists(COMPILE_ADMIN_REALDIR)) {
253                mkdir(COMPILE_ADMIN_REALDIR);
254            }
255        }
256    }
257
258    /**
259     * 定数定義
260     *
261     * @access protected
262     * @return void
263     */
264    function defineConstants()
265    {
266        // LC_Page_Error用
267        /** 指定商品ページがない */
268        define('PRODUCT_NOT_FOUND', 1);
269        /** カート内が空 */
270        define('CART_EMPTY', 2);
271        /** ページ推移エラー */
272        define('PAGE_ERROR', 3);
273        /** 購入処理中のカート商品追加エラー */
274        define('CART_ADD_ERROR', 4);
275        /** 他にも購入手続きが行われた場合 */
276        define('CANCEL_PURCHASE', 5);
277        /** 指定カテゴリページがない */
278        define('CATEGORY_NOT_FOUND', 6);
279        /** ログインに失敗 */
280        define('SITE_LOGIN_ERROR', 7);
281        /** 会員専用ページへのアクセスエラー */
282        define('CUSTOMER_ERROR', 8);
283        /** 購入時の売り切れエラー */
284        define('SOLD_OUT', 9);
285        /** カート内商品の読込エラー */
286        define('CART_NOT_FOUND', 10);
287        /** ポイントの不足 */
288        define('LACK_POINT', 11);
289        /** 仮登録者がログインに失敗 */
290        define('TEMP_LOGIN_ERROR', 12);
291        /** URLエラー */
292        define('URL_ERROR', 13);
293        /** ファイル解凍エラー */
294        define('EXTRACT_ERROR', 14);
295        /** FTPダウンロードエラー */
296        define('FTP_DOWNLOAD_ERROR', 15);
297        /** FTPログインエラー */
298        define('FTP_LOGIN_ERROR', 16);
299        /** FTP接続エラー */
300        define('FTP_CONNECT_ERROR', 17);
301        /** DB作成エラー */
302        define('CREATE_DB_ERROR', 18);
303        /** DBインポートエラー */
304        define('DB_IMPORT_ERROR', 19);
305        /** 設定ファイル存在エラー */
306        define('FILE_NOT_FOUND', 20);
307        /** 書き込みエラー */
308        define('WRITE_FILE_ERROR', 21);
309        /** DB接続エラー */
310        define('DB_CONNECT_ERROR', 22);
311        /** ダウンロードファイル存在エラー */
312        define('DOWNFILE_NOT_FOUND', 22);
313        /** フリーメッセージ */
314        define('FREE_ERROR_MSG', 999);
315
316        // LC_Page_Error_DispError用
317        /** ログイン失敗 */
318        define('LOGIN_ERROR', 1);
319        /** アクセス失敗(タイムアウト等) */
320        define('ACCESS_ERROR', 2);
321        /** アクセス権限違反 */
322        define('AUTH_ERROR', 3);
323        /** 不正な遷移エラー */
324        define('INVALID_MOVE_ERRORR', 4);
325
326        // オーナーズストア通信関連
327        /** オーナーズストア通信ステータス */
328        define('OSTORE_STATUS_ERROR', 'ERROR');
329        /** オーナーズストア通信ステータス */
330        define('OSTORE_STATUS_SUCCESS', 'SUCCESS');
331        /** オーナーズストア通信エラーコード */
332        define('OSTORE_E_UNKNOWN', '1000');
333        /** オーナーズストア通信エラーコード */
334        define('OSTORE_E_INVALID_PARAM', '1001');
335        /** オーナーズストア通信エラーコード */
336        define('OSTORE_E_NO_CUSTOMER', '1002');
337        /** オーナーズストア通信エラーコード */
338        define('OSTORE_E_WRONG_URL_PASS', '1003');
339        /** オーナーズストア通信エラーコード */
340        define('OSTORE_E_NO_PRODUCTS', '1004');
341        /** オーナーズストア通信エラーコード */
342        define('OSTORE_E_NO_DL_DATA', '1005');
343        /** オーナーズストア通信エラーコード */
344        define('OSTORE_E_DL_DATA_OPEN', '1006');
345        /** オーナーズストア通信エラーコード */
346        define('OSTORE_E_DLLOG_AUTH', '1007');
347        /** オーナーズストア通信エラーコード */
348        define('OSTORE_E_C_ADMIN_AUTH', '2001');
349        /** オーナーズストア通信エラーコード */
350        define('OSTORE_E_C_HTTP_REQ', '2002');
351        /** オーナーズストア通信エラーコード */
352        define('OSTORE_E_C_HTTP_RESP', '2003');
353        /** オーナーズストア通信エラーコード */
354        define('OSTORE_E_C_FAILED_JSON_PARSE', '2004');
355        /** オーナーズストア通信エラーコード */
356        define('OSTORE_E_C_NO_KEY', '2005');
357        /** オーナーズストア通信エラーコード */
358        define('OSTORE_E_C_INVALID_ACCESS', '2006');
359        /** オーナーズストア通信エラーコード */
360        define('OSTORE_E_C_INVALID_PARAM', '2007');
361        /** オーナーズストア通信エラーコード */
362        define('OSTORE_E_C_AUTOUP_DISABLE', '2008');
363        /** オーナーズストア通信エラーコード */
364        define('OSTORE_E_C_PERMISSION', '2009');
365        /** オーナーズストア通信エラーコード */
366        define('OSTORE_E_C_BATCH_ERR', '2010');
367
368        // プラグイン関連
369        /** プラグインの状態:アップロード済み */
370        define('PLUGIN_STATUS_UPLOADED', '1');
371        /** プラグインの状態:インストール済み */
372        define('PLUGIN_STATUS_INSTALLED', '2');
373        /** プラグイン有効/無効:有効 */
374        define('PLUGIN_ENABLE_TRUE', '1');
375        /** プラグイン有効/無効:無効 */
376        define('PLUGIN_ENABLE_FALSE', '2');
377
378        // CSV入出力関連
379        /** CSV入出力列設定有効無効フラグ: 有効 */
380        define('CSV_COLUMN_STATUS_FLG_ENABLE', 1);
381        /** CSV入出力列設定有効無効フラグ: 無効 */
382        define('CSV_COLUMN_STATUS_FLG_DISABLE', 2);
383        /** CSV入出力列設定読み書きフラグ: 読み書き可能 */
384        define('CSV_COLUMN_RW_FLG_READ_WRITE', 1);
385        /** CSV入出力列設定読み書きフラグ: 読み込みのみ可能 */
386        define('CSV_COLUMN_RW_FLG_READ_ONLY', 2);
387        /** CSV入出力列設定読み書きフラグ: キー列 */
388        define('CSV_COLUMN_RW_FLG_KEY_FIELD', 3);
389
390        // 配置ID
391        /** 配置ID: 未使用 */
392        define('TARGET_ID_UNUSED', 0);
393        /** 配置ID: LeftNavi */
394        define('TARGET_ID_LEFT', 1);
395        /** 配置ID: MainHead */
396        define('TARGET_ID_MAIN_HEAD', 2);
397        /** 配置ID: RightNavi */
398        define('TARGET_ID_RIGHT', 3);
399        /** 配置ID: MainFoot */
400        define('TARGET_ID_MAIN_FOOT', 4);
401        /** 配置ID: TopNavi */
402        define('TARGET_ID_TOP', 5);
403        /** 配置ID: BottomNavi */
404        define('TARGET_ID_BOTTOM', 6);
405        /** 配置ID: HeadNavi */
406        define('TARGET_ID_HEAD', 7);
407        /** 配置ID: HeadTopNavi */
408        define('TARGET_ID_HEAD_TOP', 8);
409        /** 配置ID: FooterBottomNavi */
410        define('TARGET_ID_FOOTER_BOTTOM', 9);
411        /** 配置ID: HeaderInternalNavi */
412        define('TARGET_ID_HEADER_INTERNAL', 10);
413
414        // 他
415        /** アクセス成功 */
416        define('SUCCESS', 0);
417        /** 無制限フラグ: 無制限 */
418        define('UNLIMITED_FLG_UNLIMITED', '1');
419        /** 無制限フラグ: 制限有り */
420        define('UNLIMITED_FLG_LIMITED', '0');
421    }
422
423    /**
424     * クォートされた文字列のクォート部分を再帰的に取り除く.
425     *
426     * {@link http://jp2.php.net/manual/ja/function.get-magic-quotes-gpc.php PHP Manual} の記事を参考に実装。
427     * $_REQUEST は後続の処理で再構成されるため、本処理では外している。
428     * この関数は, PHP5以上を対象とし, PHP4 の場合は何もしない.
429     *
430     * @return void
431     */
432    function stripslashesDeepGpc()
433    {
434        // Strip magic quotes from request data.
435        if (get_magic_quotes_gpc()
436            && version_compare(PHP_VERSION, '5.0.0', '>=')) {
437            // Create lamba style unescaping function (for portability)
438            $quotes_sybase = strtolower(ini_get('magic_quotes_sybase'));
439            $unescape_function = (empty($quotes_sybase) || $quotes_sybase === 'off') ? 'stripslashes($value)' : 'str_replace("\'\'","\'",$value)';
440            $stripslashes_deep = create_function('&$value, $fn', '
441                if (is_string($value)) {
442                    $value = ' . $unescape_function . ';
443                } else if (is_array($value)) {
444                    foreach ($value as &$v) $fn($v, $fn);
445                }
446            ');
447
448            // Unescape data
449            $stripslashes_deep($_POST, $stripslashes_deep);
450            $stripslashes_deep($_GET, $stripslashes_deep);
451            $stripslashes_deep($_COOKIE, $stripslashes_deep);
452        }
453    }
454
455    /**
456     * スーパーグローバル変数「$_REQUEST」を再セット
457     *
458     * variables_order ディレクティブによる差を吸収する。
459     *
460     * @access protected
461     * @return void
462     */
463    function resetSuperglobalsRequest()
464    {
465        $_REQUEST = array_merge($_GET, $_POST);
466    }
467
468    /**
469     * 指定された名前の定数が存在しない場合、指定された値で定義
470     *
471     * @param string $name 定数の名前。
472     * @param mixed $value 定数の値。
473     * @return void
474     */
475    function defineIfNotDefined($name, $value = null)
476    {
477        if (!defined($name)) {
478            define($name, $value);
479        }
480    }
481
482    /**
483     * タイムゾーンを設定
484     *
485     * @return void
486     */
487    function setTimezone()
488    {
489        date_default_timezone_set('Asia/Tokyo');
490    }
491}
Note: See TracBrowser for help on using the repository browser.