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

Revision 18777, 21.1 KB checked in by eccuore, 10 years ago (diff)

#792(ダウンロード販売機能) 機能追加

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