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

Revision 18772, 19.0 KB checked in by nanasess, 11 years ago (diff)

r18700 の続き

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