source: branches/version-2_5-dev/data/class/pages/admin/basis/LC_Page_Admin_Basis.php @ 19856

Revision 19856, 15.3 KB checked in by tao, 12 years ago (diff)

refs #841 shopマスタでの変更機能を追加。あと凡ミスも修正。

  • 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_REALDIR . "pages/admin/LC_Page_Admin.php");
26
27/**
28 * 店舗基本情報 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Admin_Basis extends LC_Page_Admin {
35
36    // }}}
37    // {{{ functions
38
39    /**
40     * Page を初期化する.
41     *
42     * @return void
43     */
44    function init() {
45        parent::init();
46        $this->tpl_mainpage = 'basis/index.tpl';
47        $this->tpl_subnavi = 'basis/subnavi.tpl';
48        $this->tpl_subno = 'index';
49        $this->tpl_mainno = 'basis';
50        $masterData = new SC_DB_MasterData_Ex();
51        $this->arrPref = $masterData->getMasterData('mtb_pref');
52        $this->arrTAXRULE = $masterData->getMasterData("mtb_taxrule");
53        $this->tpl_subtitle = 'SHOPマスタ';
54
55        //定休日用配列
56        $this->arrRegularHoliday[0] = '日';
57        $this->arrRegularHoliday[1] = '月';
58        $this->arrRegularHoliday[2] = '火';
59        $this->arrRegularHoliday[3] = '水';
60        $this->arrRegularHoliday[4] = '木';
61        $this->arrRegularHoliday[5] = '金';
62        $this->arrRegularHoliday[6] = '土';
63    }
64
65    /**
66     * Page のプロセス.
67     *
68     * @return void
69     */
70    function process() {
71        $this->action();
72        $this->sendResponse();
73    }
74
75    /**
76     * Page のアクション.
77     *
78     * @return void
79     */
80    function action() {
81        $objSess = new SC_Session();
82        $objQuery = new SC_Query();
83
84        // 認証可否の判定
85        SC_Utils_Ex::sfIsSuccess($objSess);
86
87        $cnt = $objQuery->count("dtb_baseinfo");
88
89        if ($cnt > 0) {
90            $this->tpl_mode = "update";
91        } else {
92            $this->tpl_mode = "insert";
93        }
94
95        if(isset($_POST['mode']) && !empty($_POST["mode"])) {
96            // POSTデータの引き継ぎ
97            $this->arrForm = $_POST;
98
99            // 入力データの変換
100            $this->arrForm = $this->lfConvertParam($this->arrForm);
101            $this->arrForm['regular_holiday_ids'] = $_POST['regular_holiday_ids'];  // 定休日情報を付加
102            // 入力データのエラーチェック
103            $this->arrErr = $this->lfErrorCheck($this->arrForm);
104
105            if(count($this->arrErr) == 0) {
106                switch($_POST['mode']) {
107                case 'update':
108                    $this->lfUpdateData($this->arrForm);    // 既存編集
109                    break;
110                case 'insert':
111                    $this->lfInsertData($this->arrForm);    // 新規作成
112                    break;
113                default:
114                    break;
115                }
116                $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "'); window.alert('SHOPマスタの登録が完了しました。管理画面のURLを変更した場合は、新しいURLにアクセスしてください。');";
117            }
118            if( empty($this->arrForm['regular_holiday_ids']) ) {
119                $this->arrSel = array();
120            } else {
121                $this->arrSel = $this->arrForm['regular_holiday_ids'];
122            }
123        } else {
124            $arrCol = $this->lfGetCol();
125            $col    = SC_Utils_Ex::sfGetCommaList($arrCol);
126            $arrRet = $objQuery->select($col, "dtb_baseinfo");
127            $this->arrForm = $arrRet[0];
128
129            $regular_holiday_ids = explode('|', $this->arrForm['regular_holiday_ids']);
130            $this->arrForm['regular_holiday_ids'] = $regular_holiday_ids;
131            $admin_dir = str_replace("/","",ADMIN_DIR);
132            $this->arrForm += array("admin_dir"=>$admin_dir);
133            $this->arrForm += array("admin_force_ssl"=>ADMIN_FORCE_SSL);
134            if(defined("ADMIN_ALLOW_HOSTS")){
135                $allow_hosts = unserialize(ADMIN_ALLOW_HOSTS);
136                $this->arrForm += array("admin_allow_hosts"=>implode("\n",$allow_hosts));
137            }else{
138                $this->arrForm += array("admin_allow_hosts"=>"");
139            }
140            $this->tpl_onload = "fnCheckLimit('downloadable_days', 'downloadable_days_unlimited', '" . DISABLED_RGB . "');";
141        }
142    }
143
144    /**
145     * デストラクタ.
146     *
147     * @return void
148     */
149    function destroy() {
150        parent::destroy();
151    }
152
153    // 基本情報用のカラムを取り出す。
154    function lfGetCol() {
155        $arrCol = array(
156            "company_name",
157            "company_kana",
158            "shop_name",
159            "shop_kana",
160            "shop_name_eng",
161            "zip01",
162            "zip02",
163            "pref",
164            "addr01",
165            "addr02",
166            "tel01",
167            "tel02",
168            "tel03",
169            "fax01",
170            "fax02",
171            "fax03",
172            "business_hour",
173            "email01",
174            "email02",
175            "email03",
176            "email04",
177            "tax",
178            "tax_rule",
179            "free_rule",
180            "good_traded",
181            "message",
182            "regular_holiday_ids",
183            "latitude",
184            "longitude",
185            "downloadable_days",
186            "downloadable_days_unlimited"
187        );
188        return $arrCol;
189    }
190
191    function lfUpdateData($array) {
192        $objQuery = new SC_Query();
193        $arrCol = $this->lfGetCol();
194        foreach($arrCol as $val) {
195            //配列の場合は、パイプ区切りの文字列に変換
196            if(is_array($array[$val])) {
197                $sqlval[$val] = implode("|", $array[$val]);
198            } else {
199                $sqlval[$val] = $array[$val];
200            }
201        }
202        $sqlval['update_date'] = 'Now()';
203        $this->lfUpdateAdminData($array);
204        // UPDATEの実行
205        $ret = $objQuery->update("dtb_baseinfo", $sqlval);
206    }
207
208    function lfInsertData($array) {
209        $objQuery = new SC_Query();
210        $arrCol = $this->lfGetCol();
211        foreach($arrCol as $val) {
212            $sqlval[$val] = $array[$val];
213        }
214        $sqlval['update_date'] = 'Now()';
215        $this->lfUpdateAdminData($array);
216        // INSERTの実行
217        $ret = $objQuery->insert("dtb_baseinfo", $sqlval);
218    }
219   
220    function lfUpdateAdminData($array){
221        $admin_dir = trim($array['admin_dir'])."/";
222        $admin_force_ssl = "FALSE";
223        if($array['admin_force_ssl'] == 1){
224            $admin_force_ssl = "TRUE";
225        }
226        $admin_allow_hosts = explode("\n",$array['admin_allow_hosts']);
227        foreach($admin_allow_hosts as $key=>$host){
228            $host = trim($host);
229            if(strlen($host) >= 8){
230                $admin_allow_hosts[$key] = $host;
231            }else{
232                unset($admin_allow_hosts[$key]);
233            }
234        }
235        $admin_allow_hosts = serialize($admin_allow_hosts);
236        //権限チェック
237        if(!is_writable(DATA_REALDIR . "install.php")){
238            $this->arrErr["admin_force_ssl"] = DATA_REALDIR . "install.phpを変更する権限がありません。";
239        }
240        if(count($this->arrErr) > 0){
241            return false;
242        }
243        //install.phpの書き換え
244        $installData = file(DATA_REALDIR."install.php",FILE_IGNORE_NEW_LINES);
245        $diff = 0;
246        foreach($installData as $key=>$line){
247            if(strpos($line,"ADMIN_DIR") !== false and ADMIN_DIR != $admin_dir){
248                if(!is_writable(HTML_REALDIR . ADMIN_DIR)){
249                    $this->arrErr["admin_dir"] = URL_PATH.ADMIN_DIR."のディレクトリ名を変更する権限がありません。";
250                }
251                if(!is_writable(USER_TEMPLATE_REALDIR . ADMIN_DIR)){
252                    $this->arrErr["admin_dir"] = USER_TEMPLATE_REALDIR . ADMIN_DIR."のディレクトリ名を変更する権限がありません。";       
253                }
254                if(count($this->arrErr) > 0 ){
255                    return false;
256                }else{
257                    $installData[$key] = 'define("ADMIN_DIR","'.$admin_dir.'");';
258                    //管理画面ディレクトリのリネーム
259                    rename(HTML_REALDIR.ADMIN_DIR,HTML_REALDIR.$admin_dir);
260                    rename(USER_TEMPLATE_REALDIR.ADMIN_DIR,USER_TEMPLATE_REALDIR.$admin_dir);
261                    $diff ++;
262                }
263            }
264           
265            if(strpos($line,"ADMIN_FORCE_SSL") !== false and ADMIN_FORCE_SSL !== (boolean)$array['admin_force_ssl']){
266                $installData[$key] = 'define("ADMIN_FORCE_SSL",'.$admin_force_ssl.');';
267                $diff ++;
268            }
269            if(strpos($line,"ADMIN_ALLOW_HOSTS") !== false and ADMIN_ALLOW_HOSTS != $admin_allow_hosts) {
270                $installData[$key] = "define('ADMIN_ALLOW_HOSTS','".$admin_allow_hosts."');";
271                $diff ++;
272            }
273        }
274       
275        if($diff > 0) {
276            $fp = fopen(DATA_REALDIR . "install.php","wb");
277            $installData = implode("\n",$installData);
278            echo $installData;
279            fwrite($fp, $installData);
280            fclose($fp);
281        }
282        return true;
283    }
284
285    /* 取得文字列の変換 */
286    function lfConvertParam($array) {
287        /*
288         *  文字列の変換
289         *  K :  「半角(ハンカク)片仮名」を「全角片仮名」に変換
290         *  C :  「全角ひら仮名」を「全角かた仮名」に変換
291         *  V :  濁点付きの文字を一文字に変換。"K","H"と共に使用します
292         *  n :  「全角」数字を「半角(ハンカク)」に変換
293         *  a :  全角英数字を半角英数字に変換する
294         */
295        // 人物基本情報
296
297        // スポット商品
298        $arrConvList['company_name'] = "KVa";
299        $arrConvList['company_kana'] = "KVC";
300        $arrConvList['shop_name'] = "KVa";
301        $arrConvList['shop_kana'] = "KVC";
302        $arrConvList['shop_name_eng'] = "a";
303        $arrConvList['addr01'] = "KVa";
304        $arrConvList['addr02'] = "KVa";
305        $arrConvList['zip01'] = "n";
306        $arrConvList['zip02'] = "n";
307        $arrConvList['tel01'] = "n";
308        $arrConvList['tel02'] = "n";
309        $arrConvList['tel03'] = "n";
310        $arrConvList['fax01'] = "n";
311        $arrConvList['fax02'] = "n";
312        $arrConvList['fax03'] = "n";
313        $arrConvList['email01'] = "a";
314        $arrConvList['email02'] = "a";
315        $arrConvList['email03'] = "a";
316        $arrConvList['email04'] = "a";
317        $arrConvList['admin_dir'] = "a";
318        $arrConvList['admin_force_ssl'] = "n";
319        $arrConvList['admin_allow_hosts'] = "a";
320        $arrConvList['tax'] = "n";
321        $arrConvList['free_rule'] = "n";
322        $arrConvList['business_hour'] = "KVa";
323        $arrConvList['good_traded'] = "";
324        $arrConvList['message'] = "";
325        $arrConvList['downloadable_days'] = "n";
326        $arrConvList['downloadable_days_unlimited'] = "n";
327
328        return SC_Utils_Ex::mbConvertKanaWithArray($array, $arrConvList);
329    }
330
331    // 入力エラーチェック
332    function lfErrorCheck($array) {
333        $objErr = new SC_CheckError($array);
334
335        $objErr->doFunc(array("会社名", "company_name", STEXT_LEN), array("MAX_LENGTH_CHECK"));
336        $objErr->doFunc(array("会社名(カナ)", "company_kana", STEXT_LEN), array("KANA_CHECK","MAX_LENGTH_CHECK"));
337        $objErr->doFunc(array("店名", "shop_name", STEXT_LEN), array("EXIST_CHECK","MAX_LENGTH_CHECK"));
338        $objErr->doFunc(array("店名(カナ)", "shop_kana", STEXT_LEN), array("KANA_CHECK","MAX_LENGTH_CHECK"));
339        $objErr->doFunc(array("店名(英語表記)", "shop_name_eng", MTEXT_LEN), array("GRAPH_CHECK","MAX_LENGTH_CHECK"));
340        // 郵便番号チェック
341        $objErr->doFunc(array("郵便番号1","zip01",ZIP01_LEN ) ,array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
342        $objErr->doFunc(array("郵便番号2","zip02",ZIP02_LEN ) ,array("EXIST_CHECK", "NUM_CHECK","NUM_COUNT_CHECK"));
343        $objErr->doFunc(array("郵便番号", "zip01", "zip02"), array("ALL_EXIST_CHECK"));
344        // 住所チェック
345        $objErr->doFunc(array("都道府県", "pref"), array("EXIST_CHECK"));
346        $objErr->doFunc(array("住所1", "addr01", MTEXT_LEN), array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
347        $objErr->doFunc(array("住所2", "addr02", MTEXT_LEN), array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
348        // メールチェック
349        $objErr->doFunc(array('商品注文受付メールアドレス', "email01", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
350        $objErr->doFunc(array('問い合わせ受付メールアドレス', "email02", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
351        $objErr->doFunc(array('メール送信元メールアドレス', "email03", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK", "MAX_LENGTH_CHECK"));
352        $objErr->doFunc(array('送信エラー受付メールアドレス', "email04", STEXT_LEN) ,array("EXIST_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK","MAX_LENGTH_CHECK"));
353        //管理画面設定チェック
354        $objErr->doFunc(array('ディレクトリ名', "admin_dir", ID_MAX_LEN) ,array("EXIST_CHECK","SPTAB_CHECK", "ALNUM_CHECK"));
355        $objErr->doFunc(array('SSL制限', "admin_force_ssl", 1) ,array("NUM_CHECK", "MAX_LENGTH_CHECK"));
356        $objErr->doFunc(array('IP制限', "admin_allow_hosts", LTEXT_LEN) ,array("IP_CHECK", "MAX_LENGTH_CHECK"));
357       
358
359        // 電話番号チェック
360        $objErr->doFunc(array("TEL", "tel01", "tel02", "tel03"), array("TEL_CHECK"));
361        $objErr->doFunc(array("FAX", "fax01", "fax02", "fax03"), array("TEL_CHECK"));
362        // その他
363        $objErr->doFunc(array("消費税率", "tax", PERCENTAGE_LEN), array("EXIST_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
364        $objErr->doFunc(array("送料無料条件", "free_rule", PRICE_LEN), array("NUM_CHECK", "MAX_LENGTH_CHECK"));
365        $objErr->doFunc(array("店舗営業時間", "business_hour", STEXT_LEN), array("MAX_LENGTH_CHECK"));
366
367        $objErr->doFunc(array("取扱商品", "good_traded", LLTEXT_LEN), array("MAX_LENGTH_CHECK"));
368        $objErr->doFunc(array("メッセージ", "message", LLTEXT_LEN), array("MAX_LENGTH_CHECK"));
369        if(!isset($array['downloadable_days_unlimited']) && $array['downloadable_days_unlimited'] != "1") {
370            $objErr->doFunc(array("ダウンロード可能日数", "downloadable_days", DOWNLOAD_DAYS_LEN), array("EXIST_CHECK", "ZERO_CHECK", "NUM_CHECK", "MAX_LENGTH_CHECK"));
371        }
372        $objErr->doFunc(array("緯度", "latitude", STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
373        $objErr->doFunc(array("経度", "longitude", STEXT_LEN), array("NUM_POINT_CHECK", "MAX_LENGTH_CHECK"));
374        return $objErr->arrErr;
375    }
376}
377?>
Note: See TracBrowser for help on using the repository browser.