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

Revision 23502, 20.3 KB checked in by shutta, 7 years ago (diff)

#2448 typo修正・ソース整形・ソースコメントの改善 for 2.13.3

  • 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
24require_once CLASS_EX_REALDIR . 'page_extends/LC_Page_Ex.php';
25
26/**
27 * ショッピングログインのページクラス.
28 *
29 * @package Page
30 * @author LOCKON CO.,LTD.
31 * @version $Id$
32 */
33class LC_Page_Shopping extends LC_Page_Ex
34{
35    /**
36     * Page を初期化する.
37     *
38     * @return void
39     */
40    public function init()
41    {
42        parent::init();
43        $this->tpl_title = 'ログイン';
44        $masterData = new SC_DB_MasterData_Ex();
45        $this->arrPref = $masterData->getMasterData('mtb_pref');
46        $this->arrCountry = $masterData->getMasterData('mtb_country');
47        $this->arrSex = $masterData->getMasterData('mtb_sex');
48        $this->arrJob = $masterData->getMasterData('mtb_job');
49        $this->tpl_onload = 'eccube.toggleDeliveryForm();';
50
51        $objDate = new SC_Date_Ex(BIRTH_YEAR, date('Y', strtotime('now')));
52        $this->arrYear = $objDate->getYear('', START_BIRTH_YEAR, '');
53        $this->arrMonth = $objDate->getMonth(true);
54        $this->arrDay = $objDate->getDay(true);
55
56        $this->httpCacheControl('nocache');
57    }
58
59    /**
60     * Page のプロセス.
61     *
62     * @return void
63     */
64    public function process()
65    {
66        parent::process();
67        $this->action();
68        $this->sendResponse();
69    }
70
71    /**
72     * Page のプロセス.
73     *
74     * @return void
75     */
76    public function action()
77    {
78        //決済処理中ステータスのロールバック
79        $objPurchase = new SC_Helper_Purchase_Ex();
80        $objPurchase->cancelPendingOrder(PENDING_ORDER_CANCEL_FLAG);
81
82        $objSiteSess = new SC_SiteSession_Ex();
83        $objCartSess = new SC_CartSession_Ex();
84        $objCustomer = new SC_Customer_Ex();
85        $objCookie = new SC_Cookie_Ex();
86        $objFormParam = new SC_FormParam_Ex();
87
88        $nonmember_mainpage = 'shopping/nonmember_input.tpl';
89        $nonmember_title = 'お客様情報入力';
90
91        $this->tpl_uniqid = $objSiteSess->getUniqId();
92        $objPurchase->verifyChangeCart($this->tpl_uniqid, $objCartSess);
93
94        $this->cartKey = $objCartSess->getKey();
95
96        // ログイン済みの場合は次画面に遷移
97        if ($objCustomer->isLoginSuccess(true)) {
98            SC_Response_Ex::sendRedirect(
99                    $this->getNextlocation($this->cartKey, $this->tpl_uniqid,
100                                           $objCustomer, $objPurchase,
101                                           $objSiteSess));
102            SC_Response_Ex::actionExit();
103        }
104        // 非会員かつ, ダウンロード商品の場合はエラー表示
105        else {
106            if ($this->cartKey == PRODUCT_TYPE_DOWNLOAD) {
107                $msg = 'ダウンロード商品を含むお買い物は、会員登録が必要です。<br/>'
108                     . 'お手数ですが、会員登録をお願いします。';
109                SC_Utils_Ex::sfDispSiteError(FREE_ERROR_MSG, $objSiteSess, false, $msg);
110                SC_Response_Ex::actionExit();
111            }
112        }
113
114        // 携帯端末IDが一致する会員が存在するかどうかをチェックする。
115        if (SC_Display_Ex::detectDevice() === DEVICE_TYPE_MOBILE) {
116            $this->tpl_valid_phone_id = $objCustomer->checkMobilePhoneId();
117        }
118
119        switch ($this->getMode()) {
120            // ログイン実行
121            case 'login':
122                $this->lfInitLoginFormParam($objFormParam);
123                $objFormParam->setParam($_POST);
124                $objFormParam->trimParam();
125                $objFormParam->convParam();
126                $objFormParam->toLower('login_email');
127                $this->arrErr = $objFormParam->checkError();
128
129                // ログイン判定
130                if (SC_Utils_Ex::isBlank($this->arrErr)
131                    && $objCustomer->doLogin($objFormParam->getValue('login_email'),
132                                             $objFormParam->getValue('login_pass'))) {
133                    // クッキー保存判定
134                    if ($objFormParam->getValue('login_memory') == '1' && strlen($objFormParam->getValue('login_email')) >= 1) {
135                        $objCookie->setCookie('login_email', $objFormParam->getValue('login_email'));
136                    } else {
137                        $objCookie->setCookie('login_email', '');
138                    }
139
140                    // モバイルサイトで携帯アドレスの登録が無い場合、携帯アドレス登録ページへ遷移
141                    if (SC_Display_Ex::detectDevice() == DEVICE_TYPE_MOBILE) {
142                        if (!$objCustomer->hasValue('email_mobile')) {
143                            SC_Response_Ex::sendRedirectFromUrlPath('entry/email_mobile.php');
144                            SC_Response_Ex::actionExit();
145                        }
146                    }
147                    // スマートフォンの場合はログイン成功を返す
148                    elseif (SC_Display_Ex::detectDevice() === DEVICE_TYPE_SMARTPHONE) {
149                        echo SC_Utils_Ex::jsonEncode(array('success' =>
150                                                     $this->getNextLocation($this->cartKey, $this->tpl_uniqid,
151                                                                            $objCustomer, $objPurchase,
152                                                                            $objSiteSess)));
153                        SC_Response_Ex::actionExit();
154                    }
155
156                    SC_Response_Ex::sendRedirect(
157                            $this->getNextLocation($this->cartKey, $this->tpl_uniqid,
158                                                   $objCustomer, $objPurchase,
159                                                   $objSiteSess));
160                    SC_Response_Ex::actionExit();
161                }
162                // ログインに失敗した場合
163                else {
164                    // 仮登録の場合
165                    if (SC_Helper_Customer_Ex::checkTempCustomer($objFormParam->getValue('login_email'))) {
166                        if (SC_Display_Ex::detectDevice() === DEVICE_TYPE_SMARTPHONE) {
167                            echo $this->lfGetErrorMessage(TEMP_LOGIN_ERROR);
168                            SC_Response_Ex::actionExit();
169                        } else {
170                            SC_Utils_Ex::sfDispSiteError(TEMP_LOGIN_ERROR);
171                            SC_Response_Ex::actionExit();
172                        }
173                    } else {
174                        if (SC_Display_Ex::detectDevice() === DEVICE_TYPE_SMARTPHONE) {
175                            echo $this->lfGetErrorMessage(SITE_LOGIN_ERROR);
176                            SC_Response_Ex::actionExit();
177                        } else {
178                            SC_Utils_Ex::sfDispSiteError(SITE_LOGIN_ERROR);
179                            SC_Response_Ex::actionExit();
180                        }
181                    }
182                }
183                break;
184            // お客様情報登録
185            case 'nonmember_confirm':
186                $this->tpl_mainpage = $nonmember_mainpage;
187                $this->tpl_title = $nonmember_title;
188                $this->lfInitParam($objFormParam);
189                $objFormParam->setParam($_POST);
190                $this->arrErr = $this->lfCheckError($objFormParam);
191
192                if (SC_Utils_Ex::isBlank($this->arrErr)) {
193                    $this->lfRegistData($this->tpl_uniqid, $objPurchase, $objCustomer, $objFormParam);
194
195                    $arrParams = $objFormParam->getHashArray();
196                    $shipping_id = $arrParams['deliv_check'] == '1' ? 1 : 0;
197                    $objPurchase->setShipmentItemTempForSole($objCartSess, $shipping_id);
198
199                    $objSiteSess->setRegistFlag();
200
201                    SC_Response_Ex::sendRedirect(SHOPPING_PAYMENT_URLPATH);
202                    SC_Response_Ex::actionExit();
203                }
204                break;
205
206            // 前のページに戻る
207            case 'return':
208                SC_Response_Ex::sendRedirect(CART_URL);
209                SC_Response_Ex::actionExit();
210                break;
211
212            // 複数配送ページへ遷移
213            case 'multiple':
214                // 複数配送先指定が無効な場合はエラー
215                if (USE_MULTIPLE_SHIPPING === false) {
216                    SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, '', true);
217                    SC_Response_Ex::actionExit();
218                }
219
220                $this->lfInitParam($objFormParam);
221                $objFormParam->setParam($_POST);
222                $this->arrErr = $this->lfCheckError($objFormParam);
223
224                if (SC_Utils_Ex::isBlank($this->arrErr)) {
225                    $this->lfRegistData($this->tpl_uniqid, $objPurchase, $objCustomer, $objFormParam, true);
226
227                    $objSiteSess->setRegistFlag();
228
229                    SC_Response_Ex::sendRedirect(MULTIPLE_URLPATH);
230                    SC_Response_Ex::actionExit();
231                }
232                $this->tpl_mainpage = $nonmember_mainpage;
233                $this->tpl_title = $nonmember_title;
234                break;
235
236            // お客様情報入力ページの表示
237            case 'nonmember':
238                $this->tpl_mainpage = $nonmember_mainpage;
239                $this->tpl_title = $nonmember_title;
240                $this->lfInitParam($objFormParam);
241                // ※breakなし
242
243            default:
244                // 前のページから戻ってきた場合は, お客様情報入力ページ
245                if (isset($_GET['from']) && $_GET['from'] == 'nonmember') {
246                    $this->tpl_mainpage = $nonmember_mainpage;
247                    $this->tpl_title = $nonmember_title;
248                    $this->lfInitParam($objFormParam);
249                } else {
250                    // 通常はログインページ
251                    $this->lfInitLoginFormParam($objFormParam);
252                }
253
254                $this->setFormParams($objFormParam, $objPurchase, $this->tpl_uniqid);
255                break;
256        }
257
258        // 入力値の取得
259        $this->arrForm = $objFormParam->getFormParamList();
260
261        // 記憶したメールアドレスを取得
262        $this->tpl_login_email = $objCookie->getCookie('login_email');
263        if (!SC_Utils_Ex::isBlank($this->tpl_login_email)) {
264            $this->tpl_login_memory = '1';
265        }
266    }
267
268    /**
269     * お客様情報入力時のパラメーター情報の初期化を行う.
270     *
271     * @param  SC_FormParam $objFormParam SC_FormParam インスタンス
272     * @return void
273     */
274    public function lfInitParam(&$objFormParam)
275    {
276        SC_Helper_Customer_Ex::sfCustomerCommonParam($objFormParam, 'order_');
277        SC_Helper_Customer_Ex::sfCustomerRegisterParam($objFormParam, false, false, 'order_');
278
279        // 不要なパラメーターの削除
280        // XXX: 共通化したことをうまく使えば、以前あった購入同時会員登録も復活出来そうですが
281        $objFormParam->removeParam('order_password');
282        $objFormParam->removeParam('order_password02');
283        $objFormParam->removeParam('order_reminder');
284        $objFormParam->removeParam('order_reminder_answer');
285        $objFormParam->removeParam('order_mailmaga_flg');
286
287        $objFormParam->addParam('別のお届け先', 'deliv_check', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
288
289        SC_Helper_Customer_Ex::sfCustomerCommonParam($objFormParam, 'shipping_');
290    }
291
292    /**
293     * ログイン時のパラメーター情報の初期化を行う.
294     *
295     * @param  SC_FormParam $objFormParam SC_FormParam インスタンス
296     * @return void
297     */
298    public function lfInitLoginFormParam(&$objFormParam)
299    {
300        $objFormParam->addParam('記憶する', 'login_memory', INT_LEN, 'n', array('MAX_LENGTH_CHECK', 'NUM_CHECK'));
301        $objFormParam->addParam('メールアドレス', 'login_email', '', 'a', array('EXIST_CHECK', 'EMAIL_CHECK', 'SPTAB_CHECK', 'EMAIL_CHAR_CHECK'));
302        $objFormParam->addParam('パスワード', 'login_pass', PASSWORD_MAX_LEN, '', array('EXIST_CHECK', 'MAX_LENGTH_CHECK', 'SPTAB_CHECK'));
303
304        if ($this->tpl_valid_phone_id) {
305            // 携帯端末IDが登録されている場合、メールアドレス入力欄が省略される
306            $arrCheck4login_email = $objFormParam->getParamSetting('login_email', 'arrCheck');
307            $key = array_search('EXIST_CHECK', $arrCheck4login_email);
308            unset($arrCheck4login_email[$key]);
309            $objFormParam->overwriteParam('login_email', 'arrCheck', $arrCheck4login_email);
310        }
311    }
312
313    /**
314     * ログイン済みの場合の遷移先を取得する.
315     *
316     * 商品種別IDが, ダウンロード商品の場合は, 会員情報を受注一時情報に保存し,
317     * 支払方法選択画面のパスを返す.
318     * それ以外は, お届け先選択画面のパスを返す.
319     *
320     * @param  integer            $product_type_id 商品種別ID
321     * @param  string             $uniqid          受注一時テーブルのユニークID
322     * @param  SC_Customer        $objCustomer     SC_Customer インスタンス
323     * @param  SC_Helper_Purchase $objPurchase     SC_Helper_Purchase インスタンス
324     * @param  SC_SiteSession     $objSiteSess     SC_SiteSession インスタンス
325     * @return string             遷移先のパス
326     */
327    public function getNextLocation($product_type_id, $uniqid, &$objCustomer, &$objPurchase, &$objSiteSess)
328    {
329        switch ($product_type_id) {
330            case PRODUCT_TYPE_DOWNLOAD:
331                $objPurchase->unsetAllShippingTemp(true);
332                $objPurchase->saveOrderTemp($uniqid, array(), $objCustomer);
333                $objSiteSess->setRegistFlag();
334
335                return 'payment.php';
336
337            case PRODUCT_TYPE_NORMAL:
338            default:
339                return 'deliv.php';
340        }
341    }
342
343    /**
344     * データの一時登録を行う.
345     *
346     * 非会員向けの処理
347     * @param integer            $uniqid       受注一時テーブルのユニークID
348     * @param SC_Helper_Purchase $objPurchase  SC_Helper_Purchase インスタンス
349     * @param SC_Customer        $objCustomer  SC_Customer インスタンス
350     * @param SC_FormParam       $objFormParam SC_FormParam インスタンス
351     * @param boolean            $isMultiple   複数配送の場合 true
352     */
353    public function lfRegistData($uniqid, &$objPurchase, &$objCustomer, &$objFormParam, $isMultiple = false)
354    {
355        $arrParams = $objFormParam->getHashArray();
356
357        // 注文者をお届け先とする配列を取得
358        $arrShippingOwn = array();
359        $objPurchase->copyFromOrder($arrShippingOwn, $arrParams);
360
361        // 都度入力されたお届け先
362        $arrShipping = $objPurchase->extractShipping($arrParams);
363
364        if ($isMultiple) {
365            $objPurchase->unsetOneShippingTemp(0);
366            $objPurchase->unsetOneShippingTemp(1);
367            $objPurchase->saveShippingTemp($arrShippingOwn, 0);
368            if ($arrParams['deliv_check'] == '1') {
369                $objPurchase->saveShippingTemp($arrShipping, 1);
370            }
371        } else {
372            $objPurchase->unsetAllShippingTemp(true);
373            if ($arrParams['deliv_check'] == '1') {
374                $objPurchase->saveShippingTemp($arrShipping, 1);
375            } else {
376                $objPurchase->saveShippingTemp($arrShippingOwn, 0);
377            }
378        }
379
380        $arrValues = $objFormParam->getDbArray();
381
382        // 登録データの作成
383        $arrValues['order_birth'] = SC_Utils_Ex::sfGetTimestamp($arrParams['order_year'], $arrParams['order_month'], $arrParams['order_day']);
384        $arrValues['update_date'] = 'CURRENT_TIMESTAMP';
385        $arrValues['customer_id'] = '0';
386        $objPurchase->saveOrderTemp($uniqid, $arrValues, $objCustomer);
387    }
388
389    /**
390     * 入力内容のチェックを行う.
391     *
392     * 追加の必須チェック, 相関チェックを行うため, SC_CheckError を使用する.
393     *
394     * @param  SC_FormParam $objFormParam SC_FormParam インスタンス
395     * @return array        エラー情報の配
396     */
397    public function lfCheckError(&$objFormParam)
398    {
399        $arrParams = $objFormParam->getHashArray();
400
401        $objErr = SC_Helper_Customer_Ex::sfCustomerCommonErrorCheck($objFormParam, 'order_');
402
403        // 別のお届け先チェック
404        if (isset($arrParams['deliv_check']) && $arrParams['deliv_check'] == '1') {
405            $objErr2 = SC_Helper_Customer_Ex::sfCustomerCommonErrorCheck($objFormParam, 'shipping_');
406            $objErr->arrErr = array_merge((array) $objErr->arrErr, (array) $objErr2->arrErr);
407        } else {
408            // shipping系のエラーは無視
409            foreach ($objErr->arrErr as $key => $val) {
410                if (substr($key, 0, strlen('shipping_')) == 'shipping_') {
411                    unset($objErr->arrErr[$key]);
412                }
413            }
414        }
415
416        // 複数項目チェック
417        $objErr->doFunc(array('生年月日', 'order_year', 'order_month', 'order_day'), array('CHECK_BIRTHDAY'));
418        $objErr->doFunc(array('メールアドレス', 'メールアドレス(確認)', 'order_email', 'order_email02'), array('EQUAL_CHECK'));
419
420        return $objErr->arrErr;
421    }
422
423    /**
424     * 入力済みの購入情報をフォームに設定する.
425     *
426     * 受注一時テーブル, セッションの配送情報から入力済みの購入情報を取得し,
427     * フォームに設定する.
428     *
429     * @param  SC_FormParam       $objFormParam SC_FormParam インスタンス
430     * @param  SC_Helper_Purchase $objPurchase  SC_Helper_Purchase インスタンス
431     * @param  integer            $uniqid       購入一時情報のユニークID
432     * @return void
433     */
434    public function setFormParams(&$objFormParam, &$objPurchase, $uniqid)
435    {
436        $arrOrderTemp = $objPurchase->getOrderTemp($uniqid);
437        if (SC_Utils_Ex::isBlank($arrOrderTemp)) {
438            $arrOrderTemp = array(
439                'order_email' => '',
440                'order_birth' => '',
441            );
442        }
443        $arrShippingTemp = $objPurchase->getShippingTemp();
444
445        $objFormParam->setParam($arrOrderTemp);
446        /*
447         * count($arrShippingTemp) > 1 は複数配送であり,
448         * $arrShippingTemp[0] は注文者が格納されている
449         */
450        if (count($arrShippingTemp) > 1) {
451            $objFormParam->setParam($arrShippingTemp[1]);
452        } else {
453            if ($arrOrderTemp['deliv_check'] == 1) {
454                $objFormParam->setParam($arrShippingTemp[1]);
455            } else {
456                $objFormParam->setParam($arrShippingTemp[0]);
457            }
458        }
459        $objFormParam->setValue('order_email02', $arrOrderTemp['order_email']);
460        $objFormParam->setDBDate($arrOrderTemp['order_birth'], 'order_year', 'order_month', 'order_day');
461    }
462
463    /**
464     * エラーメッセージを JSON 形式で返す.
465     *
466     * TODO リファクタリング
467     * この関数は主にスマートフォンで使用します.
468     *
469     * @param integer エラーコード
470     * @return string JSON 形式のエラーメッセージ
471     * @see LC_PageError
472     */
473    public function lfGetErrorMessage($error)
474    {
475        switch ($error) {
476            case TEMP_LOGIN_ERROR:
477                $msg = "メールアドレスもしくはパスワードが正しくありません。\n本登録がお済みでない場合は、仮登録メールに記載されているURLより本登録を行ってください。";
478                break;
479            case SITE_LOGIN_ERROR:
480            default:
481                $msg = 'メールアドレスもしくはパスワードが正しくありません。';
482        }
483
484        return SC_Utils_Ex::jsonEncode(array('login_error' => $msg));
485    }
486}
Note: See TracBrowser for help on using the repository browser.