source: branches/version-2_5-dev/data/class/pages/shopping/LC_Page_Shopping.php @ 19661

Revision 19661, 21.2 KB checked in by nanasess, 13 years ago (diff)

source:branches/camp/camp-2_5-E のマージ

  • スマートフォン対応(#787)
  • プラグイン機能(#494)
  • 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:LC_Page_Shopping.php 15532 2007-08-31 14:39:46Z nanasess $
33 */
34class LC_Page_Shopping extends LC_Page {
35
36    // {{{ properties
37
38    /** フォームパラメータ */
39    var $objFormParam;
40
41    /** 年 */
42    var $year;
43
44    // }}}
45    // {{{ functions
46
47    /**
48     * Page を初期化する.
49     *
50     * @return void
51     */
52    function init() {
53        parent::init();
54        $this->tpl_mainpage = 'shopping/index.tpl';
55        $this->tpl_column_num = 1;
56        $this->tpl_title = 'ログイン';
57        $masterData = new SC_DB_MasterData();
58        $this->arrPref = $masterData->getMasterData("mtb_pref", array("pref_id", "pref_name", "rank"));
59        $this->arrSex = $masterData->getMasterData("mtb_sex");
60        $this->arrJob = $masterData->getMasterData("mtb_job");
61        $this->tpl_onload = 'fnCheckInputDeliv();';
62        $this->httpCacheControl('nocache');
63    }
64
65    /**
66     * Page のプロセス.
67     *
68     * @return void
69     */
70    function process() {
71        parent::process();
72        $this->action();
73        $this->sendResponse();
74    }
75
76    /**
77     * Page のプロセス.
78     *
79     * @return void
80     */
81    function action() {
82        $objSiteSess = new SC_SiteSession();
83        $objCartSess = new SC_CartSession();
84        $objCustomer = new SC_Customer();
85        $objCookie = new SC_Cookie();
86        $objDb = new SC_Helper_DB_Ex();
87        $this->objFormParam = new SC_FormParam();            // フォーム用
88        $this->lfInitParam();                                // パラメータ情報の初期化
89        $this->objFormParam->setParam($_POST);            // POST値の取得
90
91        // ユーザユニークIDの取得と購入状態の正当性をチェック
92        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
93        $this->tpl_uniqid = $uniqid;
94
95        //ダウンロード商品判定
96        $this->cartdown = $objDb->chkCartDown($objCartSess);
97
98        // ログインチェック
99        if($objCustomer->isLoginSuccess()) {
100            // すでにログインされている場合
101            if ($this->cartdown == 2) {
102                // 会員情報の住所を受注一時テーブルに書き込む
103                $objDb->sfRegistDelivData($uniqid, $objCustomer);
104                // 正常に登録されたことを記録しておく
105                $objSiteSess->setRegistFlag();
106                //カート内が全てダウンロード商品の場合は支払方法設定画面に転送
107                $this->objDisplay->redirect($this->getLocation("./payment.php"), array());
108            } else {
109                // お届け先設定画面に転送
110                $this->objDisplay->redirect($this->getLocation("./deliv.php"), array());
111            }
112            exit;
113        }
114
115        if ($_SERVER["REQUEST_METHOD"] == "POST") {
116            if (!SC_Helper_Session_Ex::isValidToken()) {
117                SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, "", true);
118            }
119        }
120
121        if (!isset($_POST['mode'])) $_POST['mode'] = "";
122
123        switch($_POST['mode']) {
124        case 'nonmember_confirm':
125            $this->lfSetNonMember($this);
126            //非会員のダウンロード商品を含んだ買い物はNG
127            if($this->cartdown != 0){
128                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, $objSiteSess, false, "ダウンロード商品を含むお買い物は、会員登録が必要です。<br/>お手数ですが、会員登録をお願いします。");
129            }
130            // ※breakなし
131        case 'confirm':
132            // 入力値の変換
133            $this->objFormParam->convParam();
134            $this->objFormParam->toLower('order_mail');
135            $this->objFormParam->toLower('order_mail_check');
136
137            $this->arrErr = $this->lfCheckError();
138
139            // 入力エラーなし
140            if(count($this->arrErr) == 0) {
141                // DBへのデータ登録
142                $this->lfRegistData($uniqid);
143
144                // 正常に登録されたことを記録しておく
145                $objSiteSess->setRegistFlag();
146                // お支払い方法選択ページへ移動
147                $this->objDisplay->redirect($this->getLocation(URL_SHOP_PAYMENT));
148                exit;
149            }
150
151            break;
152        // 前のページに戻る
153        case 'return':
154            // 確認ページへ移動
155            $this->objDisplay->redirect($this->getLocation(URL_CART_TOP));
156            exit;
157            break;
158        case 'nonmember':
159            $this->lfSetNonMember($this);
160            //非会員のダウンロード商品を含んだ買い物はNG
161            if($this->cartdown != 0){
162                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, $objSiteSess, false, "ダウンロード商品を含むお買い物は、会員登録が必要です。<br/>お手数ですが、会員登録をお願いします。");
163            }
164            // ※breakなし
165        default:
166            if(isset($_GET['from']) && $_GET['from'] == 'nonmember') {
167                $this->lfSetNonMember($this);
168            }
169            // ユーザユニークIDの取得
170            $uniqid = $objSiteSess->getUniqId();
171            $objQuery = new SC_Query();
172            $where = "order_temp_id = ?";
173            $arrRet = $objQuery->select("*", "dtb_order_temp", $where, array($uniqid));
174            if (empty($arrRet)) $arrRet = array(
175                                                array('order_email' => "",
176                                                      'order_birth' => ""));
177
178            // DB値の取得
179            $this->objFormParam->setParam($arrRet[0]);
180            $this->objFormParam->setValue('order_email02', $arrRet[0]['order_email']);
181            $this->objFormParam->setDBDate($arrRet[0]['order_birth']);
182            break;
183        }
184
185        // クッキー判定
186        $this->tpl_login_email = $objCookie->getCookie('login_email');
187        if($this->tpl_login_email != "") {
188            $this->tpl_login_memory = "1";
189        }
190
191        // 生年月日選択肢の取得
192        $objDate = new SC_Date(START_BIRTH_YEAR, date("Y",strtotime("now")));
193        $this->arrYear = $objDate->getYear('', 1950, '');
194        $this->arrMonth = $objDate->getMonth(true);
195        $this->arrDay = $objDate->getDay(true);
196
197        // 入力値の取得
198        $this->arrForm = $this->objFormParam->getFormParamList();
199
200        $this->transactionid = SC_Helper_Session_Ex::getToken();
201    }
202
203    /**
204     * モバイルページを初期化する.
205     *
206     * @return void
207     */
208    function mobileInit() {
209        $this->init();
210        $this->tpl_mainpage = MOBILE_TEMPLATE_DIR . 'shopping/index.tpl';
211    }
212
213    /**
214     * Page のアクション(モバイル).
215     *
216     * @return void
217     */
218    function mobileProcess() {
219        parent::mobileProcess();
220        $this->mobileAction();
221        $this->endResponse();
222    }
223
224    /**
225     * Page のプロセス(モバイル).
226     *
227     * @return void
228     */
229    function mobileAction() {
230        $objView = new SC_MobileView();
231        $objSiteSess = new SC_SiteSession();
232        $objCartSess = new SC_CartSession();
233        $objCustomer = new SC_Customer();
234        $objCookie = new SC_Cookie();
235        $this->objFormParam = new SC_FormParam();            // フォーム用
236        $helperMobile = new SC_Helper_Mobile_Ex();
237        $objDb = new SC_Helper_DB_Ex();
238        $this->lfInitParam();                                // パラメータ情報の初期化
239        $this->objFormParam->setParam($_POST);            // POST値の取得
240
241        // ユーザユニークIDの取得と購入状態の正当性をチェック
242        $uniqid = SC_Utils_Ex::sfCheckNormalAccess($objSiteSess, $objCartSess);
243
244        $this->tpl_uniqid = $uniqid;
245
246        //ダウンロード商品判定
247        $this->cartdown = $objDb->chkCartDown($objCartSess);
248
249        // ログインチェック
250        if($objCustomer->isLoginSuccess(true)) {
251            // すでにログインされている場合
252            if ($this->cartdown == 2) {
253                // 会員情報の住所を受注一時テーブルに書き込む
254                $objDb->sfRegistDelivData($uniqid, $objCustomer);
255                // 正常に登録されたことを記録しておく
256                $objSiteSess->setRegistFlag();
257                //カート内が全てダウンロード商品の場合は支払方法設定画面に転送
258                $this->objDisplay->redirect($this->getLocation("./payment.php"), array());
259            } else {
260                // お届け先設定画面に転送
261                $this->objDisplay->redirect($this->getLocation("./deliv.php"), array());
262            }
263            exit;
264        }
265
266        // 携帯端末IDが一致する会員が存在するかどうかをチェックする。
267        $this->tpl_valid_phone_id = $objCustomer->checkMobilePhoneId();
268
269        // クッキー判定
270        $this->tpl_login_email = $objCookie->getCookie('login_email');
271        if($this->tpl_login_email != "") {
272            $this->tpl_login_memory = "1";
273        }
274    }
275
276    /**
277     * デストラクタ.
278     *
279     * @return void
280     */
281    function destroy() {
282        parent::destroy();
283    }
284
285    /* 非会員入力ページのセット */
286    function lfSetNonMember(&$objPage) {
287        $objPage->tpl_mainpage = 'shopping/nonmember_input.tpl';
288        $this->tpl_title = 'お客様情報入力';
289    }
290
291    /* パラメータ情報の初期化 */
292    function lfInitParam() {
293        $this->objFormParam->addParam("お名前(姓)", "order_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
294        $this->objFormParam->addParam("お名前(名)", "order_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
295        $this->objFormParam->addParam("お名前(フリガナ・姓)", "order_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
296        $this->objFormParam->addParam("お名前(フリガナ・名)", "order_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
297        $this->objFormParam->addParam("郵便番号1", "order_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
298        $this->objFormParam->addParam("郵便番号2", "order_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
299        $this->objFormParam->addParam("都道府県", "order_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
300        $this->objFormParam->addParam("住所1", "order_addr01", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
301        $this->objFormParam->addParam("住所2", "order_addr02", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
302        $this->objFormParam->addParam("電話番号1", "order_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
303        $this->objFormParam->addParam("電話番号2", "order_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
304        $this->objFormParam->addParam("電話番号3", "order_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
305        $this->objFormParam->addParam("FAX番号1", "order_fax01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
306        $this->objFormParam->addParam("FAX番号2", "order_fax02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
307        $this->objFormParam->addParam("FAX番号3", "order_fax03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
308        $this->objFormParam->addParam("メールアドレス", "order_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"));
309        $this->objFormParam->addParam("メールアドレス(確認)", "order_email02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "NO_SPTAB", "MAX_LENGTH_CHECK", "EMAIL_CHECK", "EMAIL_CHAR_CHECK"), "", false);
310        $this->objFormParam->addParam("年", "year", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
311        $this->objFormParam->addParam("月", "month", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
312        $this->objFormParam->addParam("日", "day", INT_LEN, "n", array("MAX_LENGTH_CHECK"), "", false);
313        $this->objFormParam->addParam("性別", "order_sex", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
314        $this->objFormParam->addParam("職業", "order_job", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
315        $this->objFormParam->addParam("別のお届け先", "deliv_check", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
316        $this->objFormParam->addParam("お名前(姓)", "deliv_name01", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
317        $this->objFormParam->addParam("お名前(名)", "deliv_name02", STEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
318        $this->objFormParam->addParam("お名前(フリガナ・姓)", "deliv_kana01", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
319        $this->objFormParam->addParam("お名前(フリガナ・名)", "deliv_kana02", STEXT_LEN, "KVCa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
320        $this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
321        $this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("NUM_CHECK", "NUM_COUNT_CHECK"));
322        $this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
323        $this->objFormParam->addParam("住所1", "deliv_addr01", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
324        $this->objFormParam->addParam("住所2", "deliv_addr02", MTEXT_LEN, "KVa", array("SPTAB_CHECK", "MAX_LENGTH_CHECK"));
325        $this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
326        $this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
327        $this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("MAX_LENGTH_CHECK" ,"NUM_CHECK"));
328        $this->objFormParam->addParam("メールマガジン", "mail_flag", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"), 1);
329    }
330
331    /* DBへデータの登録 */
332    function lfRegistData($uniqid) {
333        $arrRet = $this->objFormParam->getHashArray();
334        $sqlval = $this->objFormParam->getDbArray();
335        // 登録データの作成
336        $sqlval['order_birth'] = SC_Utils_Ex::sfGetTimestamp($arrRet['year'], $arrRet['month'], $arrRet['day']);
337        $sqlval['update_date'] = 'Now()';
338        $sqlval['customer_id'] = '0';
339
340        // お届け先を指定しない場合、
341        if ($sqlval['deliv_check'] != '1') {
342            // 受注一時テーブルに登録する顧客(お客様情報)をお届け先へコピーする
343            $this->lfCopyDeliv($sqlval);
344        }
345
346        // 既存データのチェック
347        $objQuery = new SC_Query();
348        $where = "order_temp_id = ?";
349        $cnt = $objQuery->count("dtb_order_temp", $where, array($uniqid));
350        // 既存データがない場合
351        if ($cnt == 0) {
352            $sqlval['order_temp_id'] = $uniqid;
353            $sqlval['create_date'] = 'Now()';
354            $objQuery->insert("dtb_order_temp", $sqlval);
355        } else {
356            $objQuery->update("dtb_order_temp", $sqlval, $where, array($uniqid));
357        }
358
359    }
360
361    /* 入力内容のチェック */
362    function lfCheckError() {
363        // 入力データを渡す。
364        $arrRet = $this->objFormParam->getHashArray();
365        $objErr = new SC_CheckError($arrRet);
366        $objErr->arrErr = $this->objFormParam->checkError();
367
368        // 別のお届け先チェック
369        if(isset($_POST['deliv_check']) && $_POST['deliv_check'] == "1") {
370            $objErr->doFunc(array("お名前(姓)", "deliv_name01"), array("EXIST_CHECK"));
371            $objErr->doFunc(array("お名前(名)", "deliv_name02"), array("EXIST_CHECK"));
372            $objErr->doFunc(array("お名前(フリガナ・姓)", "deliv_kana01"), array("EXIST_CHECK"));
373            $objErr->doFunc(array("お名前(フリガナ・名)", "deliv_kana02"), array("EXIST_CHECK"));
374            $objErr->doFunc(array("郵便番号1", "deliv_zip01"), array("EXIST_CHECK"));
375            $objErr->doFunc(array("郵便番号2", "deliv_zip02"), array("EXIST_CHECK"));
376            $objErr->doFunc(array("都道府県", "deliv_pref"), array("EXIST_CHECK"));
377            $objErr->doFunc(array("住所1", "deliv_addr01"), array("EXIST_CHECK"));
378            $objErr->doFunc(array("住所2", "deliv_addr02"), array("EXIST_CHECK"));
379            $objErr->doFunc(array("電話番号1", "deliv_tel01"), array("EXIST_CHECK"));
380            $objErr->doFunc(array("電話番号2", "deliv_tel02"), array("EXIST_CHECK"));
381            $objErr->doFunc(array("電話番号3", "deliv_tel03"), array("EXIST_CHECK"));
382        }
383
384        // 複数項目チェック
385        $objErr->doFunc(array("TEL", "order_tel01", "order_tel02", "order_tel03"), array("TEL_CHECK"));
386        $objErr->doFunc(array("FAX", "order_fax01", "order_fax02", "order_fax03"), array("TEL_CHECK"));
387        $objErr->doFunc(array("郵便番号", "order_zip01", "order_zip02"), array("ALL_EXIST_CHECK"));
388        $objErr->doFunc(array("TEL", "deliv_tel01", "deliv_tel02", "deliv_tel03"), array("TEL_CHECK"));
389        $objErr->doFunc(array("FAX", "deliv_fax01", "deliv_fax02", "deliv_fax03"), array("TEL_CHECK"));
390        $objErr->doFunc(array("郵便番号", "deliv_zip01", "deliv_zip02"), array("ALL_EXIST_CHECK"));
391        $objErr->doFunc(array("生年月日", "year", "month", "day"), array("CHECK_BIRTHDAY"));
392        $objErr->doFunc(array("メールアドレス", "メールアドレス(確認)", "order_email", "order_email02"), array("EQUAL_CHECK"));
393
394        //既存メールアドレスでの登録不可(購入時強制会員登録が有効の場合のみ)
395        if (PURCHASE_CUSTOMER_REGIST == '1' && strlen($arrRet["order_email"]) > 0) {
396            $array['email'] = strtolower($arrRet['order_email']);
397            $objQuery = new SC_Query();
398            $arrEmailCheck = $objQuery->select("email, update_date, del_flg", "dtb_customer","email = ? OR email_mobile = ? ORDER BY del_flg", array($array["email"], $array["email"]));
399
400            if(!empty($arrEmailCheck)) {
401                if($arrEmailCheck[0]['del_flg'] != '1') {
402                    // 会員である場合
403                    $objErr->arrErr["order_email"] .= "※ すでに会員登録で使用されているメールアドレスです。<br />";
404                } else {
405                    // 退会した会員である場合
406                    $leave_time = SC_Utils_Ex::sfDBDatetoTime($arrEmailCheck[0]['update_date']);
407                    $now_time = time();
408                    $pass_time = $now_time - $leave_time;
409                    // 退会から何時間-経過しているか判定する。
410                    $limit_time = ENTRY_LIMIT_HOUR * 3600;
411                    if($pass_time < $limit_time) {
412                        $objErr->arrErr["order_email"] .= "※ 退会から一定期間の間は、同じメールアドレスを使用することはできません。<br />";
413                    }
414                }
415            }
416        }
417
418        return $objErr->arrErr;
419    }
420
421    /**
422     * 受注一時テーブルに登録する顧客(お客様情報)をお届け先へコピーする
423     *
424     * @param array $sqlval
425     * @return void
426     */
427    function lfCopyDeliv(&$sqlval) {
428        $sqlval['deliv_name01'] = $sqlval['order_name01'];
429        $sqlval['deliv_name02'] = $sqlval['order_name02'];
430        $sqlval['deliv_kana01'] = $sqlval['order_kana01'];
431        $sqlval['deliv_kana02'] = $sqlval['order_kana02'];
432        $sqlval['deliv_pref']   = $sqlval['order_pref'];
433        $sqlval['deliv_zip01']  = $sqlval['order_zip01'];
434        $sqlval['deliv_zip02']  = $sqlval['order_zip02'];
435        $sqlval['deliv_addr01'] = $sqlval['order_addr01'];
436        $sqlval['deliv_addr02'] = $sqlval['order_addr02'];
437        $sqlval['deliv_tel01']  = $sqlval['order_tel01'];
438        $sqlval['deliv_tel02']  = $sqlval['order_tel02'];
439        $sqlval['deliv_tel03']  = $sqlval['order_tel03'];
440    }
441}
442?>
Note: See TracBrowser for help on using the repository browser.