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

Revision 19891, 15.1 KB checked in by kotani, 13 years ago (diff)

#880(mobile/sphoneディレクトリを削除)に対応。まずmobileのみ意図通りの動作になるように一部コミット(shopping/お届け先の指定ページ)

  • 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/LC_Page.php");
26
27/**
28 * お届け先の指定 のページクラス.
29 *
30 * @package Page
31 * @author LOCKON CO.,LTD.
32 * @version $Id$
33 */
34class LC_Page_Shopping_Deliv extends LC_Page {
35
36    // {{{ properties
37
38    /** フォームパラメータの配列 */
39    var $objFormParam;
40
41    /** ログインフォームパラメータ配列 */
42    var $objLoginFormParam;
43
44    // }}}
45    // {{{ functions
46
47    /**
48     * Page を初期化する.
49     *
50     * @return void
51     */
52    function init() {
53        parent::init();
54        $masterData = new SC_DB_MasterData();
55        $this->arrPref = $masterData->getMasterData('mtb_pref');
56        $this->tpl_title = "お届け先の指定";
57        $this->httpCacheControl('nocache');
58    }
59
60    /**
61     * Page のプロセス.
62     *
63     * @return void
64     */
65    function process() {
66        $this->action();
67        $this->sendResponse();
68    }
69
70    /**
71     * Page のプロセス.
72     *
73     * @return void
74     */
75    function action() {
76        $objSiteSess = new SC_SiteSession();
77        $objCartSess = new SC_CartSession();
78        $objCustomer = new SC_Customer();
79        $objPurchase = new SC_Helper_Purchase_Ex();
80        $objQuery = SC_Query::getSingletonInstance();;
81        // クッキー管理クラス
82        $objCookie = new SC_Cookie(COOKIE_EXPIRE);
83        // パラメータ管理クラス
84        $this->objFormParam = new SC_FormParam();
85        // パラメータ情報の初期化
86        $this->lfInitParam();
87        // POST値の取得
88        $this->objFormParam->setParam($_POST);
89
90        $this->objLoginFormParam = new SC_FormParam();  // ログインフォーム用
91        $this->lfInitLoginFormParam();
92        //パスワード・Eメールにある空白をトリム
93        $this->lfConvertEmail($_POST["login_email"]);
94        $this->lfConvertLoginPass($_POST["login_pass"]);
95        $this->objLoginFormParam->setParam($_POST);     // POST値の取得
96
97        // ユーザユニークIDの取得と購入状態の正当性をチェック
98        $uniqid = $objSiteSess->getUniqId();
99        $objPurchase->verifyChangeCart($uniqid, $objCartSess);
100
101        $this->tpl_uniqid = $uniqid;
102
103        $this->cartKey = $objCartSess->getKey();
104
105        if (!isset($_POST['mode'])) $_POST['mode'] = "";
106
107        // ログインチェック
108        if($_POST['mode'] != 'login' && !$objCustomer->isLoginSuccess(true)) {
109            // 不正アクセスとみなす
110            SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
111        }
112
113        switch($_POST['mode']) {
114        case 'login':
115            $this->objLoginFormParam->toLower('login_email');
116            $this->arrErr = $this->objLoginFormParam->checkError();
117            $arrForm =  $this->objLoginFormParam->getHashArray();
118            // クッキー保存判定
119            if($arrForm['login_memory'] == "1" && $arrForm['login_email'] != "") {
120                $objCookie->setCookie('login_email', $_POST['login_email']);
121            } else {
122                $objCookie->setCookie('login_email', '');
123            }
124
125            if(count($this->arrErr) > 0) {
126                SC_Utils_Ex::sfDispSiteError(TEMP_LOGIN_ERROR);
127            }
128            // ログイン判定
129            $loginFailFlag = false;
130            if(Net_UserAgent_Mobile::isMobile() === true) {
131                // モバイルサイト
132                if(!$objCustomer->getCustomerDataFromMobilePhoneIdPass($arrForm['login_pass']) &&
133                   !$objCustomer->getCustomerDataFromEmailPass($arrForm['login_pass'], $arrForm['login_email'], true)) {
134                    $loginFailFlag = true;
135                }
136            } else {
137                // モバイルサイト以外
138                if(!$objCustomer->getCustomerDataFromEmailPass($arrForm['login_pass'], $arrForm['login_email'])) {
139                    $loginFailFlag = true;
140                }
141            }
142            if($loginFailFlag === true) {
143                // 仮登録の判定
144                $where = "email = ? AND status = 1 AND del_flg = 0";
145                $ret = $objQuery->count("dtb_customer", $where, array($arrForm['login_email']));
146
147                if($ret > 0) {
148                    SC_Utils_Ex::sfDispSiteError(TEMP_LOGIN_ERROR);
149                } else {
150                    SC_Utils_Ex::sfDispSiteError(SITE_LOGIN_ERROR);
151                }
152            }
153
154            if(Net_UserAgent_Mobile::isMobile() === true) {
155                // ログインが成功した場合は携帯端末IDを保存する。
156                $objCustomer->updateMobilePhoneId();
157
158                /*
159                 * 携帯メールアドレスが登録されていない場合は,
160                 * 携帯メールアドレス登録画面へ遷移
161                 */
162                $objMobile = new SC_Helper_Mobile_Ex();
163                if (!$objMobile->gfIsMobileMailAddress($objCustomer->getValue('email'))) {
164                    if (!$objCustomer->hasValue('email_mobile')) {
165                        SC_Response_Ex::sendRedirect('../entry/email_mobile.php');
166                        exit;
167                    }
168                }
169            }
170
171            //ダウンロード商品判定
172            if($this->cartKey == PRODUCT_TYPE_DOWNLOAD){
173                // 会員情報の住所を受注一時テーブルに書き込む
174                $objPurchase->copyFromCustomer($sqlval, $objCustomer, 'shipping');
175                $sqlval['deliv_id'] = $objPurchase->getDeliv($this->cartKey);
176                $objPurchase->saveShippingTemp($sqlval);
177                $objPurchase->saveOrderTemp($uniqid, $sqlval, $objCustomer);
178                // 正常に登録されたことを記録しておく
179                $objSiteSess->setRegistFlag();
180                // ダウンロード商品有りの場合は、支払方法画面に転送
181                SC_Response_Ex::sendRedirect('payment.php');
182                exit;
183            }
184            break;
185        // 削除
186        case 'delete':
187            if (SC_Utils_Ex::sfIsInt($_POST['other_deliv_id'])) {
188                $where = "other_deliv_id = ?";
189                $arrRet = $objQuery->delete("dtb_other_deliv", $where, array($_POST['other_deliv_id']));
190                $this->objFormParam->setValue('select_addr_id', '');
191            }
192            break;
193        // 会員登録住所に送る
194        case 'customer_addr':
195            $sqlval = array();
196            // 会員登録住所がチェックされている場合
197            if ($_POST['deliv_check'] == '-1') {
198                // 会員情報の住所を受注一時テーブルに書き込む
199                $objPurchase->copyFromCustomer($sqlval, $objCustomer, 'shipping');
200                $sqlval['deliv_id'] = $objPurchase->getDeliv($this->cartKey);
201                $objPurchase->saveShippingTemp($sqlval);
202                $objPurchase->saveOrderTemp($uniqid, $sqlval, $objCustomer);
203
204                // 正常に登録されたことを記録しておく
205                $objSiteSess->setRegistFlag();
206                // お支払い方法選択ページへ移動
207                SC_Response_Ex::sendRedirect(SHOPPING_PAYMENT_URL_PATH);
208                exit;
209            // 別のお届け先がチェックされている場合
210            } elseif($_POST['deliv_check'] >= 1) {
211                if (SC_Utils_Ex::sfIsInt($_POST['deliv_check'])) {
212                    $deliv_count = $objQuery->count("dtb_other_deliv","customer_id=? and other_deliv_id = ?" ,array($objCustomer->getValue('customer_id'), $_POST['deliv_check']));
213                    if ($deliv_count != 1) {
214                        SC_Utils_Ex::sfDispSiteError(CUSTOMER_ERROR);
215                    }
216
217                    $otherDeliv = $objQuery->select("*", "dtb_other_deliv",
218                                                    "other_deliv_id = ?",
219                                                    array($_POST['deliv_check']));
220                    $sqlval = $otherDeliv[0];
221                    $sqlval['deliv_id'] = $objPurchase->getDeliv($this->cartKey);
222                    $objPurchase->saveShippingTemp($sqlval, $_POST['deliv_check']);
223                    $objPurchase->saveOrderTemp($uniqid, $sqlval, $objCustomer);
224
225                    // 正常に登録されたことを記録しておく
226                    $objSiteSess->setRegistFlag();
227                    // お支払い方法選択ページへ移動
228                    SC_Response_Ex::sendRedirect(SHOPPING_PAYMENT_URL_PATH);
229                    exit;
230                }
231            }else{
232                // エラーを返す
233                $arrErr['deli'] = '※ お届け先を選択してください。';
234            }
235            break;
236        // 前のページに戻る
237        case 'return':
238            // 確認ページへ移動
239            SC_Response_Ex::sendRedirect(CART_URL_PATH);
240            exit;
241            break;
242        // お届け先複数指定
243        case 'multiple':
244            SC_Response_Ex::sendRedirect('multiple.php');
245            exit;
246            break;
247
248        default:
249            //$objPurchase->unsetShippingTemp();
250            $arrOrderTemp = $objPurchase->getOrderTemp($uniqid);
251            if (empty($arrOrderTemp)) $arrOrderTemp = array("");
252            $this->objFormParam->setParam($arrOrderTemp);
253            break;
254        }
255
256        // 登録済み住所を取得
257        $this->arrAddr = $objCustomer->getCustomerAddress($_SESSION['customer']['customer_id']);
258        // 入力値の取得
259        if (!isset($arrErr)) $arrErr = array();
260        $this->arrForm = $this->objFormParam->getFormParamList();
261        $this->arrErr = $arrErr;
262    }
263
264    /**
265     * デストラクタ.
266     *
267     * @return void
268     */
269    function destroy() {
270        parent::destroy();
271    }
272
273    /* パラメータ情報の初期化 */
274    function lfInitParam() {
275        $this->objFormParam->addParam("お名前1", "deliv_name01", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
276        $this->objFormParam->addParam("お名前2", "deliv_name02", STEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
277        $this->objFormParam->addParam("お名前(フリガナ・姓)", "deliv_kana01", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
278        $this->objFormParam->addParam("お名前(フリガナ・名)", "deliv_kana02", STEXT_LEN, "KVCa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
279        $this->objFormParam->addParam("郵便番号1", "deliv_zip01", ZIP01_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
280        $this->objFormParam->addParam("郵便番号2", "deliv_zip02", ZIP02_LEN, "n", array("EXIST_CHECK", "NUM_CHECK", "NUM_COUNT_CHECK"));
281        $this->objFormParam->addParam("都道府県", "deliv_pref", INT_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK", "NUM_CHECK"));
282        $this->objFormParam->addParam("住所1", "deliv_addr01", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
283        $this->objFormParam->addParam("住所2", "deliv_addr02", MTEXT_LEN, "KVa", array("EXIST_CHECK", "SPTAB_CHECK", "MAX_LENGTH_CHECK"));
284        $this->objFormParam->addParam("電話番号1", "deliv_tel01", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
285        $this->objFormParam->addParam("電話番号2", "deliv_tel02", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
286        $this->objFormParam->addParam("電話番号3", "deliv_tel03", TEL_ITEM_LEN, "n", array("EXIST_CHECK", "MAX_LENGTH_CHECK" ,"NUM_CHECK"));
287        $this->objFormParam->addParam("", "deliv_check");
288    }
289
290    function lfInitLoginFormParam() {
291        $this->objLoginFormParam->addParam("記憶する", "login_memory", INT_LEN, "n", array("MAX_LENGTH_CHECK", "NUM_CHECK"));
292        $this->objLoginFormParam->addParam("メールアドレス", "login_email", STEXT_LEN, "KVa", array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
293        $this->objLoginFormParam->addParam("パスワード", "login_pass", PASSWORD_LEN1, "", array("EXIST_CHECK"));
294        $this->objLoginFormParam->addParam("パスワード", "login_pass1", PASSWORD_LEN1, "", array("EXIST_CHECK", "MIN_LENGTH_CHECK"));
295        $this->objLoginFormParam->addParam("パスワード", "login_pass2", PASSWORD_LEN2, "", array("EXIST_CHECK", "MAX_LENGTH_CHECK"));
296    }
297
298    /* DBへデータの登録 */
299    function lfRegistNewAddrData($uniqid, $objCustomer) {
300        $sqlval = $this->objFormParam->getDbArray();
301        // 登録データの作成
302        $sqlval['deliv_check'] = '1';
303        $sqlval['order_temp_id'] = $uniqid;
304        $sqlval['update_date'] = 'Now()';
305        $sqlval['customer_id'] = $objCustomer->getValue('customer_id');
306        $sqlval['order_birth'] = $objCustomer->getValue('birth');
307
308        $objDb = new SC_Helper_DB_Ex();
309        $objDb->sfRegistTempOrder($uniqid, $sqlval);
310    }
311
312    /* 入力内容のチェック */
313    function lfCheckError() {
314        // 入力データを渡す。
315        $arrRet =  $this->objFormParam->getHashArray();
316        $objErr = new SC_CheckError($arrRet);
317        $objErr->arrErr = $this->objFormParam->checkError();
318        // 複数項目チェック
319        if ($_POST['mode'] == 'login'){
320            $objErr->doFunc(array("メールアドレス", "login_email", STEXT_LEN), array("EXIST_CHECK"));
321            $objErr->doFunc(array("パスワード", "login_pass", STEXT_LEN), array("EXIST_CHECK"));
322        }
323        $objErr->doFunc(array("TEL", "deliv_tel01", "deliv_tel02", "deliv_tel03"), array("TEL_CHECK"));
324        return $objErr->arrErr;
325    }
326
327    /**
328     * 入力されたEmailから余分な改行・空白を削除する
329     *
330     * @param string $_POST["login_email"]
331     */
332    function lfConvertEmail(){
333        if( strlen($_POST["login_email"]) < 1 ){ return ; }
334        $_POST["login_email"] = preg_replace('/^[  \r\n]*(.*?)[  \r\n]*$/u', '$1', $_POST["login_email"]);
335    }
336
337    /**
338     * 入力されたPassから余分な空白を削除し、最小桁数・最大桁数チェック用に変数に入れる
339     *
340     * @param string $_POST["login_pass"]
341     */
342    function lfConvertLoginPass(){
343    if( strlen($_POST["login_pass"]) < 1 ){ return ; }
344        $_POST["login_pass"] = trim($_POST["login_pass"]); //認証用
345        $_POST["login_pass1"] = $_POST["login_pass"];      //最小桁数比較用
346        $_POST["login_pass2"] = $_POST["login_pass"];      //最大桁数比較用
347    }
348}
349?>
Note: See TracBrowser for help on using the repository browser.