source: branches/version-2_11-dev/data/class/helper/SC_Helper_Purchase.php @ 21013

Revision 21013, 47.3 KB checked in by habu, 10 years ago (diff)

#1395(フロント用のアプリログ出力関数)

とりあえず実装してみました。

バックトレースから、
ログ出力関数呼び出し元のクラス名・関数名・行数を取得して
メッセージの前に自動で付与する様にしています。

GC_Utils_Ex::gfFrontLog("メッセージ");
でログ出力できます。

また、LC_Pageクラスを継承しているクラス内では、
$this->log("メッセージ");
でログ出力できます。
この場合、ログイン中ユーザの顧客IDも含めてログ出力します。

  • 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-2011 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/**
25 * 商品購入関連のヘルパークラス.
26 *
27 * TODO 購入時強制会員登録機能(#521)の実装を検討
28 * TODO dtb_customer.buy_times, dtb_customer.buy_total の更新
29 *
30 * @package Helper
31 * @author Kentaro Ohkouchi
32 * @version $Id$
33 */
34class SC_Helper_Purchase {
35
36    /**
37     * 受注を完了する.
38     *
39     * 下記のフローで受注を完了する.
40     *
41     * 1. トランザクションを開始する
42     * 2. カートの内容を検証する.
43     * 3. 受注一時テーブルから受注データを読み込む
44     * 4. ユーザーがログインしている場合はその他の発送先へ登録する
45     * 5. 受注データを受注テーブルへ登録する
46     * 6. トランザクションをコミットする
47     *
48     * 実行中に, 何らかのエラーが発生した場合, 処理を中止しエラーページへ遷移する
49     *
50     * 決済モジュールを使用する場合は受注ステータスを「決済処理中」に設定し,
51     * 決済完了後「新規受付」に変更すること
52     *
53     * @param integer $orderStatus 受注処理を完了する際に設定する受注ステータス
54     * @return void
55     */
56    function completeOrder($orderStatus = ORDER_NEW) {
57        $objQuery =& SC_Query_Ex::getSingletonInstance();
58        $objSiteSession = new SC_SiteSession_Ex();
59        $objCartSession = new SC_CartSession_Ex();
60        $objCustomer = new SC_Customer_Ex();
61        $customerId = $objCustomer->getValue('customer_id');
62
63        $objQuery->begin();
64        if (!$objSiteSession->isPrePage()) {
65            SC_Utils_Ex::sfDispSiteError(PAGE_ERROR, $objSiteSession);
66        }
67
68        $uniqId = $objSiteSession->getUniqId();
69        $this->verifyChangeCart($uniqId, $objCartSession);
70
71        $orderTemp = $this->getOrderTemp($uniqId);
72
73        $orderTemp['status'] = $orderStatus;
74        $cartkey = $objCartSession->getKey();
75        $orderId = $this->registerOrderComplete($orderTemp, $objCartSession,
76                                                $cartkey);
77        $shippingTemp =& $this->getShippingTemp(true);
78        foreach ($shippingTemp as $shippingId => $val) {
79            $this->registerShipmentItem($orderId, $shippingId,
80                                        $val['shipment_item']);
81        }
82
83        $this->registerShipping($orderId, $shippingTemp);
84        $objQuery->commit();
85        $this->cleanupSession($orderId, $objCartSession, $objCustomer, $cartkey);
86
87        GC_Utils_Ex::gfFrontLog("order complete. customerId=" . $customerId);
88
89    }
90
91    /**
92     * 受注をキャンセルする.
93     *
94     * 受注完了後の受注をキャンセルする.
95     * この関数は, 主に決済モジュールにて, 受注をキャンセルする場合に使用する.
96     *
97     * 受注ステータスを引数 $orderStatus で指定したステータスに変更する.
98     * (デフォルト ORDER_CANCEL)
99     * 引数 $is_delete が true の場合は, 受注データを論理削除する.
100     * 商品の在庫数は, 受注前の在庫数に戻される.
101     *
102     * @param integer $order_id 受注ID
103     * @param integer $orderStatus 受注ステータス
104     * @param boolean $is_delete 受注データを論理削除する場合 true
105     * @return void
106     */
107    function cancelOrder($order_id, $orderStatus = ORDER_CANCEL, $is_delete = false) {
108        $objQuery =& SC_Query_Ex::getSingletonInstance();
109        $in_transaction = $objQuery->inTransaction();
110        if (!$in_transaction) {
111            $objQuery->begin();
112        }
113
114        $arrParams['status'] = $orderStatus;
115        if ($is_delete) {
116            $arrParams['del_flg'] = 1;
117        }
118
119        $this->registerOrder($order_id, $arrParams);
120
121        $arrOrderDetail = $this->getOrderDetail($order_id);
122        foreach ($arrOrderDetail as $arrDetail) {
123            $objQuery->update('dtb_products_class', array(),
124                              "product_class_id = ?", array($arrDetail['product_class_id']),
125                              array('stock' => 'stock + ?'), array($arrDetail['quantity']));
126        }
127        if (!$in_transaction) {
128            $objQuery->commit();
129        }
130    }
131
132    /**
133     * 受注をキャンセルし, カートをロールバックして, 受注一時IDを返す.
134     *
135     * 受注完了後の受注をキャンセルし, カートの状態を受注前の状態へ戻す.
136     * この関数は, 主に, 決済モジュールに遷移した後, 購入確認画面へ戻る場合に使用する.
137     *
138     * 受注ステータスを引数 $orderStatus で指定したステータスに変更する.
139     * (デフォルト ORDER_CANCEL)
140     * 引数 $is_delete が true の場合は, 受注データを論理削除する.
141     * 商品の在庫数, カートの内容は受注前の状態に戻される.
142     *
143     * @param integer $order_id 受注ID
144     * @param integer $orderStatus 受注ステータス
145     * @param boolean $is_delete 受注データを論理削除する場合 true
146     * @return string 受注一時ID
147     */
148    function rollbackOrder($order_id, $orderStatus = ORDER_CANCEL, $is_delete = false) {
149        $objQuery =& SC_Query_Ex::getSingletonInstance();
150        $in_transaction = $objQuery->inTransaction();
151        if (!$in_transaction) {
152            $objQuery->begin();
153        }
154
155        $this->cancelOrder($order_id, $orderStatus, $is_delete);
156        $arrOrderTemp = $this->getOrderTempByOrderId($order_id);
157        $_SESSION = array_merge($_SESSION, unserialize($arrOrderTemp['session']));
158
159        $objSiteSession = new SC_SiteSession_Ex();
160        $objCartSession = new SC_CartSession_Ex();
161        $objCustomer = new SC_Customer_Ex();
162
163        // 新たに受注一時情報を保存する
164        $objSiteSession->unsetUniqId();
165        $uniqid = $objSiteSession->getUniqId();
166        $arrOrderTemp['del_flg'] = 0;
167        $this->saveOrderTemp($uniqid, $arrOrderTemp, $objCustomer);
168        $this->verifyChangeCart($uniqid, $objCartSession);
169        $objSiteSession->setRegistFlag();
170
171        if (!$in_transaction) {
172            $objQuery->commit();
173        }
174        return $uniqid;
175    }
176
177    /**
178     * カートに変化が無いか検証する.
179     *
180     * ユニークIDとセッションのユニークIDを比較し, 異なる場合は
181     * エラー画面を表示する.
182     *
183     * カートが空の場合, 購入ボタン押下後にカートが変更された場合は
184     * カート画面へ遷移する.
185     *
186     * @param string $uniqId ユニークID
187     * @param SC_CartSession $objCartSession
188     * @return void
189     */
190    function verifyChangeCart($uniqId, &$objCartSession) {
191        $cartKeys = $objCartSession->getKeys();
192
193        // カート内が空でないか
194        if (SC_Utils_Ex::isBlank($cartKeys)) {
195            SC_Response_Ex::sendRedirect(CART_URLPATH);
196            exit;
197        }
198
199        foreach ($cartKeys as $cartKey) {
200            // 初回のみカートの内容を保存
201            $objCartSession->saveCurrentCart($uniqId, $cartKey);
202
203            /*
204             * POSTのユニークIDとセッションのユニークIDを比較
205             *(ユニークIDがPOSTされていない場合はスルー)
206             */
207            if(!SC_SiteSession_Ex::checkUniqId()) {
208                SC_Utils_Ex::sfDispSiteError(CANCEL_PURCHASE);
209                exit;
210            }
211
212            // 購入ボタンを押してから変化がないか
213            $quantity = $objCartSession->getTotalQuantity($cartKey);
214            if($objCartSession->checkChangeCart($cartKey) || !($quantity > 0)) {
215                SC_Response_Ex::sendRedirect(CART_URLPATH);
216                exit;
217            }
218        }
219    }
220
221    /**
222     * 受注一時情報を取得する.
223     *
224     * @param integer $uniqId 受注一時情報ID
225     * @return array 受注一時情報の配列
226     */
227    function getOrderTemp($uniqId) {
228        $objQuery =& SC_Query_Ex::getSingletonInstance();
229        return $objQuery->getRow("*", "dtb_order_temp", "order_temp_id = ?",
230                                 array($uniqId));
231    }
232
233    /**
234     * 受注IDをキーにして受注一時情報を取得する.
235     *
236     * @param integer $order_id 受注ID
237     * @return array 受注一時情報の配列
238     */
239    function getOrderTempByOrderId($order_id) {
240        $objQuery =& SC_Query_Ex::getSingletonInstance();
241        return $objQuery->getRow("*", "dtb_order_temp", "order_id = ?",
242                                 array($order_id));
243    }
244
245    /**
246     * 受注一時情報を保存する.
247     *
248     * 既存のデータが存在しない場合は新規保存. 存在する場合は更新する.
249     * 既存のデータが存在せず, ユーザーがログインしている場合は,
250     * 会員情報をコピーする.
251     *
252     * @param integer $uniqId 受注一時情報ID
253     * @param array $params 登録する受注情報の配列
254     * @param SC_Customer $objCustomer SC_Customer インスタンス
255     * @return array void
256     */
257    function saveOrderTemp($uniqId, $params, &$objCustomer) {
258        if (SC_Utils_Ex::isBlank($uniqId)) {
259            return;
260        }
261        $params['device_type_id'] = SC_Display::detectDevice();
262        $objQuery =& SC_Query_Ex::getSingletonInstance();
263        // 存在するカラムのみを対象とする
264        $cols = $objQuery->listTableFields('dtb_order_temp');
265        foreach ($params as $key => $val) {
266            if (in_array($key, $cols)) {
267                $sqlval[$key] = $val;
268            }
269        }
270
271        $sqlval['session'] = serialize($_SESSION);
272        $exists = $this->getOrderTemp($uniqId);
273        if (SC_Utils_Ex::isBlank($exists)) {
274            $this->copyFromCustomer($sqlval, $objCustomer);
275            $sqlval['order_temp_id'] = $uniqId;
276            $sqlval['create_date'] = "now()";
277            $objQuery->insert("dtb_order_temp", $sqlval);
278        } else {
279            $objQuery->update("dtb_order_temp", $sqlval, 'order_temp_id = ?',
280                              array($uniqId));
281        }
282    }
283
284    /**
285     * 配送情報をセッションから取得する.
286     *
287     * @param bool $has_shipment_item 配送商品を保有している配送先のみ返す。
288     */
289    function getShippingTemp($has_shipment_item) {
290        if ($has_shipment_item) {
291            $arrReturn = array();
292            foreach ($_SESSION['shipping'] as $key => $arrVal) {
293                if (count($arrVal['shipment_item']) == 0) continue;
294                $arrReturn[$key] = $arrVal;
295            }
296            return $arrReturn;
297        }
298
299        return $_SESSION['shipping'];
300    }
301
302    /**
303     * 配送商品をクリア(消去)する
304     *
305     * @param integer $shipping_id 配送先ID
306     * @return void
307     */
308    function clearShipmentItemTemp($shipping_id = null) {
309        if (is_null($shipping_id)) {
310            unset($_SESSION['shipping']);
311        } else {
312            unset($_SESSION['shipping'][$shipping_id]);
313        }
314    }
315
316    /**
317     * 配送商品を設定する.
318     *
319     * @param integer $shipping_id 配送先ID
320     * @param integer $product_class_id 商品規格ID
321     * @param integer $quantity 数量
322     * @return void
323     */
324    function setShipmentItemTemp($shipping_id, $product_class_id, $quantity) {
325        // 配列が長くなるので, リファレンスを使用する
326        $arrItems =& $_SESSION['shipping'][$shipping_id]['shipment_item'][$product_class_id];
327
328        $arrItems['shipping_id'] = $shipping_id;
329        $arrItems['product_class_id'] = $product_class_id;
330        $arrItems['quantity'] = $quantity;
331
332        $objProduct = new SC_Product_Ex();
333
334        // カート情報から読みこめば済むと思うが、一旦保留。むしろ、カート情報も含め、セッション情報を縮小すべきかもしれない。
335        /*
336        $objCartSession = new SC_CartSession_Ex();
337        $cartKey = $objCartSession->getKey();
338        // 詳細情報を取得
339        $cartItems = $objCartSession->getCartList($cartKey);
340        */
341
342        if (empty($arrItems['productsClass'])) {
343            $product =& $objProduct->getDetailAndProductsClass($product_class_id);
344            $arrItems['productsClass'] = $product;
345        }
346        $arrItems['price'] = $arrItems['productsClass']['price02'];
347        $inctax = SC_Helper_DB_Ex::sfCalcIncTax($arrItems['price']);
348        $arrItems['total_inctax'] = $inctax * $arrItems['quantity'];
349    }
350
351    /**
352     * 配送先都道府県の配列を返す.
353     */
354    function getShippingPref() {
355        $results = array();
356        foreach (SC_Helper_Purchase_Ex::getShippingTemp(true) as $val) {
357            $results[] = $val['shipping_pref'];
358        }
359        return $results;
360    }
361
362    /**
363     * 複数配送指定の購入かどうか.
364     *
365     * @return boolean 複数配送指定の購入の場合 true
366     */
367    function isMultiple() {
368        return count(SC_Helper_Purchase_Ex::getShippingTemp(true)) > 1;
369    }
370
371    /**
372     * 配送情報をセッションに保存する.
373     *
374     * @param array $arrSrc 配送情報の連想配列
375     * @param integer $shipping_id 配送先ID
376     * @return void
377     */
378    function saveShippingTemp($arrSrc, $shipping_id = 0) {
379        // 配送商品は引き継がない
380        unset($arrSrc['shipment_item']);
381
382        if (empty($_SESSION['shipping'][$shipping_id])) {
383            $_SESSION['shipping'][$shipping_id] = $arrSrc;
384            $_SESSION['shipping'][$shipping_id]['shipping_id'] = $shipping_id;
385        } else {
386            $_SESSION['shipping'][$shipping_id] = array_merge($_SESSION['shipping'][$shipping_id], $arrSrc);
387            $_SESSION['shipping'][$shipping_id]['shipping_id'] = $shipping_id;
388        }
389    }
390
391    /**
392     * セッションの配送情報を破棄する.
393     */
394    function unsetShippingTemp() {
395        unset($_SESSION['shipping']);
396        unset($_SESSION['multiple_temp']);
397    }
398
399    /**
400     * 会員情報を受注情報にコピーする.
401     *
402     * ユーザーがログインしていない場合は何もしない.
403     * 会員情報を $dest の order_* へコピーする.
404     * customer_id は強制的にコピーされる.
405     *
406     * @param array $dest コピー先の配列
407     * @param SC_Customer $objCustomer SC_Customer インスタンス
408     * @param string $prefix コピー先の接頭辞. デフォルト order
409     * @param array $keys コピー対象のキー
410     * @return void
411     */
412    function copyFromCustomer(&$dest, &$objCustomer, $prefix = 'order',
413                              $keys = array('name01', 'name02', 'kana01', 'kana02',
414                                            'sex', 'zip01', 'zip02', 'pref',
415                                            'addr01', 'addr02',
416                                            'tel01', 'tel02', 'tel03', 'job',
417                                            'birth', 'email')) {
418        if ($objCustomer->isLoginSuccess(true)) {
419
420            foreach ($keys as $key) {
421                if (in_array($key, $keys)) {
422                    $dest[$prefix . '_' . $key] = $objCustomer->getValue($key);
423                }
424            }
425
426            if (Net_UserAgent_Mobile::isMobile()
427                && in_array('email', $keys)) {
428                $email_mobile = $objCustomer->getValue('email_mobile');
429                if (empty($email_mobile)) {
430                    $dest[$prefix . '_email'] = $objCustomer->getValue('email');
431                } else {
432                    $dest[$prefix . '_email'] = $email_mobile;
433                }
434            }
435
436            $dest['customer_id'] = $objCustomer->getValue('customer_id');
437            $dest['update_date'] = 'Now()';
438        }
439    }
440
441    /**
442     * 受注情報を配送情報にコピーする.
443     *
444     * 受注情報($src)を $dest の order_* へコピーする.
445     *
446     * TODO 汎用的にして SC_Utils へ移動
447     *
448     * @param array $dest コピー先の配列
449     * @param array $src コピー元の配列
450     * @param array $keys コピー対象のキー
451     * @param string $prefix コピー先の接頭辞. デフォルト shipping
452     * @param string $src_prefix コピー元の接頭辞. デフォルト order
453     * @return void
454     */
455    function copyFromOrder(&$dest, $src,
456                           $prefix = 'shipping', $src_prefix = 'order',
457                           $keys = array('name01', 'name02', 'kana01', 'kana02',
458                                         'sex', 'zip01', 'zip02', 'pref',
459                                         'addr01', 'addr02',
460                                         'tel01', 'tel02', 'tel03')) {
461        if (!SC_Utils_Ex::isBlank($prefix)) {
462            $prefix = $prefix . '_';
463        }
464        if (!SC_Utils_Ex::isBlank($src_prefix)) {
465            $src_prefix = $src_prefix . '_';
466        }
467        foreach ($keys as $key) {
468            if (in_array($key, $keys)) {
469                $dest[$prefix . $key] = $src[$src_prefix . $key];
470            }
471        }
472    }
473
474    /**
475     * 購入金額に応じた支払方法を取得する.
476     *
477     * @param integer $total 購入金額
478     * @param integer $deliv_id 配送業者ID
479     * @return array 購入金額に応じた支払方法の配列
480     */
481    function getPaymentsByPrice($total, $deliv_id) {
482
483        $arrPaymentIds = $this->getPayments($deliv_id);
484        if (SC_Utils_Ex::isBlank($arrPaymentIds)) {
485            return array();
486        }
487
488        $objQuery =& SC_Query_Ex::getSingletonInstance();
489
490        // 削除されていない支払方法を取得
491        $where = 'del_flg = 0 AND payment_id IN (' . implode(', ', array_pad(array(), count($arrPaymentIds), '?')) . ')';
492        $objQuery->setOrder("rank DESC");
493        $payments = $objQuery->select("payment_id, payment_method, rule, upper_rule, note, payment_image, charge", "dtb_payment", $where, $arrPaymentIds);
494        foreach ($payments as $data) {
495            // 下限と上限が設定されている
496            if (strlen($data['rule']) != 0 && strlen($data['upper_rule']) != 0) {
497                if ($data['rule'] <= $total && $data['upper_rule'] >= $total) {
498                    $arrPayment[] = $data;
499                }
500            }
501            // 下限のみ設定されている
502            elseif (strlen($data['rule']) != 0) {
503                if($data['rule'] <= $total) {
504                    $arrPayment[] = $data;
505                }
506            }
507            // 上限のみ設定されている
508            elseif (strlen($data['upper_rule']) != 0) {
509                if($data['upper_rule'] >= $total) {
510                    $arrPayment[] = $data;
511                }
512            }
513            // いずれも設定なし
514            else {
515                $arrPayment[] = $data;
516            }
517          }
518        return $arrPayment;
519    }
520
521    /**
522     * お届け日一覧を取得する.
523     */
524    function getDelivDate(&$objCartSess, $productTypeId) {
525        $cartList = $objCartSess->getCartList($productTypeId);
526        $delivDateIds = array();
527        foreach ($cartList as $item) {
528            $delivDateIds[] = $item['productsClass']['deliv_date_id'];
529        }
530        $max_date = max($delivDateIds);
531        //発送目安
532        switch($max_date) {
533        //即日発送
534        case '1':
535            $start_day = 1;
536            break;
537            //1-2日後
538        case '2':
539            $start_day = 3;
540            break;
541            //3-4日後
542        case '3':
543            $start_day = 5;
544            break;
545            //1週間以内
546        case '4':
547            $start_day = 8;
548            break;
549            //2週間以内
550        case '5':
551            $start_day = 15;
552            break;
553            //3週間以内
554        case '6':
555            $start_day = 22;
556            break;
557            //1ヶ月以内
558        case '7':
559            $start_day = 32;
560            break;
561            //2ヶ月以降
562        case '8':
563            $start_day = 62;
564            break;
565            //お取り寄せ(商品入荷後)
566        case '9':
567            $start_day = "";
568            break;
569        default:
570            //お届け日が設定されていない場合
571            $start_day = "";
572        }
573        //お届け可能日のスタート値から、お届け日の配列を取得する
574        $arrDelivDate = $this->getDateArray($start_day, DELIV_DATE_END_MAX);
575        return $arrDelivDate;
576    }
577
578    /**
579     * お届け可能日のスタート値から, お届け日の配列を取得する.
580     */
581    function getDateArray($start_day, $end_day) {
582        $masterData = new SC_DB_MasterData();
583        $arrWDAY = $masterData->getMasterData("mtb_wday");
584        //お届け可能日のスタート値がセットされていれば
585        if($start_day >= 1) {
586            $now_time = time();
587            $max_day = $start_day + $end_day;
588            // 集計
589            for ($i = $start_day; $i < $max_day; $i++) {
590                // 基本時間から日数を追加していく
591                $tmp_time = $now_time + ($i * 24 * 3600);
592                list($y, $m, $d, $w) = explode(" ", date("Y m d w", $tmp_time));
593                $val = sprintf("%04d/%02d/%02d(%s)", $y, $m, $d, $arrWDAY[$w]);
594                $arrDate[$val] = $val;
595            }
596        } else {
597            $arrDate = false;
598        }
599        return $arrDate;
600    }
601
602    /**
603     * 配送業者IDからお届け時間の配列を取得する.
604     *
605     * @param integer $deliv_id 配送業者ID
606     * @return array お届け時間の配列
607     */
608    function getDelivTime($deliv_id) {
609        $objQuery =& SC_Query_Ex::getSingletonInstance();
610        $objQuery->setOrder('time_id');
611        $results = $objQuery->select('time_id, deliv_time',
612                                     'dtb_delivtime',
613                                     'deliv_id = ?', array($deliv_id));
614        $arrDelivTime = array();
615        foreach ($results as $val) {
616            $arrDelivTime[$val['time_id']] = $val['deliv_time'];
617        }
618        return $arrDelivTime;
619    }
620
621    /**
622     * 商品種別ID から配送業者を取得する.
623     *
624     * @param integer $product_type_id 商品種別ID
625     * @return array 配送業者の配列
626     */
627    function getDeliv($product_type_id) {
628        $objQuery =& SC_Query_Ex::getSingletonInstance();
629        $objQuery->setOrder('rank DESC');
630        return $objQuery->select('*', 'dtb_deliv', 'product_type_id = ? AND del_flg = 0',
631                                 array($product_type_id));
632    }
633
634    /**
635     * 配送業者ID から, 有効な支払方法IDを取得する.
636     *
637     * @param integer $deliv_id 配送業者ID
638     * @return array 有効な支払方法IDの配列
639     */
640    function getPayments($deliv_id) {
641        $objQuery =& SC_Query_Ex::getSingletonInstance();
642        $objQuery->setOrder('rank');
643        return $objQuery->getCol('payment_id', 'dtb_payment_options',
644                                 'deliv_id = ?',
645                                 array($deliv_id), MDB2_FETCHMODE_ORDERED);
646    }
647
648    /**
649     * 配送情報の登録を行う.
650     *
651     * $arrParam のうち, dtb_shipping テーブルに存在するカラムのみを登録する.
652     *
653     * TODO UPDATE/INSERT にする
654     *
655     * @param integer $order_id 受注ID
656     * @param array $arrParams 配送情報の連想配列
657     * @param boolean $convert_shipping_date yyyy/mm/dd(EEE) 形式の配送日付を変換する場合 true
658     * @return void
659     */
660    function registerShipping($order_id, $arrParams, $convert_shipping_date = true) {
661        $objQuery =& SC_Query_Ex::getSingletonInstance();
662        $table = 'dtb_shipping';
663        $where = 'order_id = ?';
664        $objQuery->delete($table, $where, array($order_id));
665
666        foreach ($arrParams as $key => $arrShipping) {
667
668            $arrValues = $objQuery->extractOnlyColsOf($table, $arrShipping);
669
670            // 配送日付を timestamp に変換
671            if (!SC_Utils_Ex::isBlank($arrValues['shipping_date'])
672                && $convert_shipping_date) {
673                $d = mb_strcut($arrValues["shipping_date"], 0, 10);
674                $arrDate = explode("/", $d);
675                $ts = mktime(0, 0, 0, $arrDate[1], $arrDate[2], $arrDate[0]);
676                $arrValues['shipping_date'] = date("Y-m-d", $ts);
677            }
678
679            // 非会員購入の場合は shipping_id が存在しない
680            if (!isset($arrValues['shipping_id'])) {
681                $arrValues['shipping_id'] = $key;
682            }
683            $arrValues['order_id'] = $order_id;
684            $arrValues['create_date'] = 'Now()';
685            $arrValues['update_date'] = 'Now()';
686            $objQuery->insert($table, $arrValues);
687        }
688    }
689
690    /**
691     * 配送商品を登録する.
692     *
693     * @param integer $order_id 受注ID
694     * @param integer $shipping_id 配送先ID
695     * @param array $arrParams 配送商品の配列
696     * @return void
697     */
698    function registerShipmentItem($order_id, $shipping_id, $arrParams) {
699        $objQuery =& SC_Query_Ex::getSingletonInstance();
700        $table = 'dtb_shipment_item';
701        $where = 'order_id = ? AND shipping_id = ?';
702        $objQuery->delete($table, $where, array($order_id, $shipping_id));
703
704        $objProduct = new SC_Product_Ex();
705        foreach ($arrParams as $arrValues) {
706            if (SC_Utils_Ex::isBlank($arrValues['product_class_id'])) {
707                continue;
708            }
709            $d = $objProduct->getDetailAndProductsClass($arrValues['product_class_id']);
710            $name = SC_Utils_Ex::isBlank($arrValues['product_name'])
711                ? $d['name']
712                : $arrValues['product_name'];
713
714            $code = SC_Utils_Ex::isBlank($arrValues['product_code'])
715                ? $d['product_code']
716                : $arrValues['product_code'];
717
718            $cname1 = SC_Utils_Ex::isBlank($arrValues['classcategory_name1'])
719                ? $d['classcategory_name1']
720                : $arrValues['classcategory_name1'];
721
722            $cname2 = SC_Utils_Ex::isBlank($arrValues['classcategory_name2'])
723                ? $d['classcategory_name2']
724                : $arrValues['classcategory_name2'];
725
726            $price = SC_Utils_Ex::isBlank($arrValues['price'])
727                ? $d['price']
728                : $arrValues['price'];
729
730            $arrValues['order_id'] = $order_id;
731            $arrValues['shipping_id'] = $shipping_id;
732            $arrValues['product_name'] = $name;
733            $arrValues['product_code'] = $code;
734            $arrValues['classcategory_name1'] = $cname1;
735            $arrValues['classcategory_name2'] = $cname2;
736            $arrValues['price'] = $price;
737
738            $arrExtractValues = $objQuery->extractOnlyColsOf($table, $arrValues);
739            $objQuery->insert($table, $arrExtractValues);
740        }
741    }
742
743    /**
744     * 受注登録を完了する.
745     *
746     * 引数の受注情報を受注テーブル及び受注詳細テーブルに登録する.
747     * 登録後, 受注一時テーブルに削除フラグを立てる.
748     *
749     * @param array $orderParams 登録する受注情報の配列
750     * @param SC_CartSession $objCartSession カート情報のインスタンス
751     * @param integer $cartKey 登録を行うカート情報のキー
752     * @param integer 受注ID
753     */
754    function registerOrderComplete($orderParams, &$objCartSession, $cartKey) {
755        $objQuery =& SC_Query_Ex::getSingletonInstance();
756
757        // 不要な変数を unset
758        $unsets = array('mailmaga_flg', 'deliv_check', 'point_check', 'password',
759                        'reminder', 'reminder_answer', 'mail_flag', 'session');
760        foreach ($unsets as $unset) {
761            unset($orderParams[$unset]);
762        }
763
764        // 注文ステータスの指定が無い場合は新規受付
765        if(SC_Utils_Ex::isBlank($orderParams['status'])) {
766            $orderParams['status'] = ORDER_NEW;
767        }
768
769        $orderParams['create_date'] = 'Now()';
770        $orderParams['update_date'] = 'Now()';
771
772        $this->registerOrder($orderParams['order_id'], $orderParams);
773
774        // 詳細情報を取得
775        $cartItems = $objCartSession->getCartList($cartKey);
776
777        // 詳細情報を生成
778        $objProduct = new SC_Product_Ex();
779        $i = 0;
780        foreach ($cartItems as $item) {
781            $p =& $item['productsClass'];
782            $arrDetail[$i]['order_id'] = $orderParams['order_id'];
783            $arrDetail[$i]['product_id'] = $p['product_id'];
784            $arrDetail[$i]['product_class_id'] = $p['product_class_id'];
785            $arrDetail[$i]['product_name'] = $p['name'];
786            $arrDetail[$i]['product_code'] = $p['product_code'];
787            $arrDetail[$i]['classcategory_name1'] = $p['classcategory_name1'];
788            $arrDetail[$i]['classcategory_name2'] = $p['classcategory_name2'];
789            $arrDetail[$i]['point_rate'] = $item['point_rate'];
790            $arrDetail[$i]['price'] = $item['price'];
791            $arrDetail[$i]['quantity'] = $item['quantity'];
792
793            // 在庫の減少処理
794            if (!$objProduct->reduceStock($p['product_class_id'], $item['quantity'])) {
795                $objQuery->rollback();
796                SC_Utils_Ex::sfDispSiteError(SOLD_OUT, "", true);
797            }
798            $i++;
799        }
800        $this->registerOrderDetail($orderParams['order_id'], $arrDetail);
801
802        $objQuery->update("dtb_order_temp", array('del_flg' => 1),
803                          "order_temp_id = ?",
804                          array(SC_SiteSession_Ex::getUniqId()));
805
806        return $orderParams['order_id'];
807    }
808
809    /**
810     * 受注情報を登録する.
811     *
812     * 既に受注IDが存在する場合は, 受注情報を更新する.
813     * 引数の受注IDが, 空白又は null の場合は, 新しく受注IDを発行して登録する.
814     *
815     * @param integer $order_id 受注ID
816     * @param array $arrParams 受注情報の連想配列
817     * @return integer 受注ID
818     */
819    function registerOrder($order_id, $arrParams) {
820        $table = 'dtb_order';
821        $where = 'order_id = ?';
822        $objQuery = SC_Query_Ex::getSingletonInstance();
823        $arrValues = $objQuery->extractOnlyColsOf($table, $arrParams);
824
825        $exists = $objQuery->count($table, $where, array($order_id));
826        if ($exists > 0) {
827
828            $this->sfUpdateOrderStatus($order_id, $arrValues['status'],
829                                       $arrValues['add_point'],
830                                       $arrValues['use_point'],
831                                       $arrValues);
832            $this->sfUpdateOrderNameCol($order_id);
833
834            $arrValues['update_date'] = 'now()';
835            $objQuery->update($table, $arrValues, $where, array($order_id));
836        } else {
837            if (SC_Utils_Ex::isBlank($order_id)) {
838                $order_id = $objQuery->nextVal('dtb_order_order_id');
839            }
840            /*
841             * 新規受付の場合は受注ステータス null で insert し,
842             * sfUpdateOrderStatus で ORDER_NEW に変更する.
843             */
844            $status = $arrValues['status'];
845            $arrValues['status'] = null;
846            $arrValues['order_id'] = $order_id;
847            $arrValues['customer_id'] =
848                    SC_Utils_Ex::isBlank($arrValues['customer_id'])
849                    ? 0 : $arrValues['customer_id'];
850            $arrValues['create_date'] = 'now()';
851            $arrValues['update_date'] = 'now()';
852            $objQuery->insert($table, $arrValues);
853
854            $this->sfUpdateOrderStatus($order_id, $status,
855                                       $arrValues['add_point'],
856                                       $arrValues['use_point'],
857                                       $arrValues);
858            $this->sfUpdateOrderNameCol($order_id);
859
860        }
861        return $order_id;
862    }
863
864    /**
865     * 受注詳細情報を登録する.
866     *
867     * 既に, 該当の受注が存在する場合は, 受注情報を削除し, 登録する.
868     *
869     * @param integer $order_id 受注ID
870     * @param array $arrParams 受注情報の連想配列
871     * @return void
872     */
873    function registerOrderDetail($order_id, $arrParams) {
874        $table = 'dtb_order_detail';
875        $where = 'order_id = ?';
876        $objQuery = SC_Query_Ex::getSingletonInstance();
877
878        $objQuery->delete($table, $where, array($order_id));
879        foreach ($arrParams as $arrDetail) {
880            $arrValues = $objQuery->extractOnlyColsOf($table, $arrDetail);
881            $arrValues['order_detail_id'] = $objQuery->nextVal('dtb_order_detail_order_detail_id');
882            $arrValues['order_id'] = $order_id;
883            $objQuery->insert($table, $arrValues);
884        }
885    }
886
887    /**
888     * 受注情報を取得する.
889     *
890     * @param integer $order_id 受注ID
891     * @param integer $customer_id 会員ID
892     * @return array 受注情報の配列
893     */
894    function getOrder($order_id, $customer_id = null) {
895        $objQuery =& SC_Query_Ex::getSingletonInstance();
896        $where = 'order_id = ?';
897        $arrValues = array($order_id);
898        if (!SC_Utils_Ex::isBlank($customer_id)) {
899            $where .= ' AND customer_id = ?';
900            $arrValues[] = $customer_id;
901        }
902        return $objQuery->getRow('*', 'dtb_order', $where, $arrValues);
903    }
904
905    /**
906     * 受注詳細を取得する.
907     *
908     * @param integer $order_id 受注ID
909     * @param boolean $has_order_status 受注ステータス, 入金日も含める場合 true
910     * @return array 受注詳細の配列
911     */
912    function getOrderDetail($order_id, $has_order_status = true) {
913        $objQuery =& SC_Query_Ex::getSingletonInstance();
914        $dbFactory  = SC_DB_DBFactory_Ex::getInstance();
915        $col = <<< __EOS__
916            T3.product_id,
917            T3.product_class_id as product_class_id,
918            T3.product_type_id AS product_type_id,
919            T2.product_code,
920            T2.product_name,
921            T2.classcategory_name1 AS classcategory_name1,
922            T2.classcategory_name2 AS classcategory_name2,
923            T2.price,
924            T2.quantity,
925            T2.point_rate,
926__EOS__;
927        if ($has_order_status) {
928            $col .= 'T1.status AS status, T1.payment_date AS payment_date,';
929
930        }
931        $col .= <<< __EOS__
932
933            CASE WHEN EXISTS(
934                    SELECT * FROM dtb_products
935                     WHERE product_id = T3.product_id
936                       AND del_flg = 0
937                       AND status = 1)
938                 THEN '1' ELSE '0'
939                  END AS enable,
940__EOS__;
941        $col .= $dbFactory->getDownloadableDaysWhereSql('T1') . ' AS effective';
942        $from = <<< __EOS__
943                 dtb_order T1
944            JOIN dtb_order_detail T2
945              ON T1.order_id = T2.order_id
946            JOIN dtb_products_class T3
947              ON T2.product_class_id = T3.product_class_id
948__EOS__;
949        $objQuery->setOrder('T2.order_detail_id');
950        return $objQuery->select($col, $from, 'T1.order_id = ?', array($order_id));
951    }
952
953    /**
954     * ダウンロード可能フラグを, 受注詳細に設定する.
955     *
956     * ダウンロード可能と判断されるのは, 以下の通り.
957     *
958     * 1. ダウンロード可能期限が期限内かつ, 入金日が入力されている
959     * 2. 販売価格が 0 円である
960     *
961     * 受注詳細行には, is_downloadable という真偽値が設定される.
962     * @param array 受注詳細の配列
963     * @return void
964     */
965    function setDownloadableFlgTo(&$arrOrderDetail) {
966        foreach (array_keys($arrOrderDetail) as $key) {
967            // 販売価格が 0 円
968            if ($arrOrderDetail[$key]['price'] == '0') {
969                $arrOrderDetail[$key]['is_downloadable'] = true;
970            }
971            // ダウンロード期限内かつ, 入金日あり
972            elseif ($arrOrderDetail[$key]['effective'] == '1'
973                    && !SC_Utils_Ex::isBlank($arrOrderDetail[$key]['payment_date'])) {
974                $arrOrderDetail[$key]['is_downloadable'] = true;
975            } else {
976                $arrOrderDetail[$key]['is_downloadable'] = false;
977            }
978        }
979    }
980
981    /**
982     * 配送情報を取得する.
983     *
984     * @param integer $order_id 受注ID
985     * @param boolean $has_items 結果に配送商品も含める場合 true
986     * @return array 配送情報の配列
987     */
988    function getShippings($order_id, $has_items = true) {
989        $objQuery =& SC_Query_Ex::getSingletonInstance();
990        $arrResults = array();
991        $objQuery->setOrder('shipping_id');
992        $arrShippings = $objQuery->select("*", "dtb_shipping", "order_id = ?",
993                                          array($order_id));
994        // shipping_id ごとの配列を生成する
995        foreach ($arrShippings as $shipping) {
996            foreach ($shipping as $key => $val) {
997                $arrResults[$shipping['shipping_id']][$key] = $val;
998            }
999        }
1000
1001        if ($has_items) {
1002            $objProduct = new SC_Product_Ex();
1003            foreach (array_keys($arrResults) as $shipping_id) {
1004                $arrResults[$shipping_id]['shipment_item']
1005                        =& $this->getShipmentItems($order_id, $shipping_id);
1006            }
1007        }
1008        return $arrResults;
1009    }
1010
1011    /**
1012     * 配送商品を取得する.
1013     *
1014     * @param integer $order_id 受注ID
1015     * @param integer $shipping_id 配送先ID
1016     * @param boolean $has_detail 商品詳細も取得する場合 true
1017     * @return array 商品規格IDをキーにした配送商品の配列
1018     */
1019    function getShipmentItems($order_id, $shipping_id, $has_detail = true) {
1020        $objQuery =& SC_Query_Ex::getSingletonInstance();
1021        $objProduct = new SC_Product_Ex();
1022        $arrResults = array();
1023        $arrItems = $objQuery->select("*", "dtb_shipment_item",
1024                                      "order_id = ? AND shipping_id = ?",
1025                                      array($order_id, $shipping_id));
1026
1027        foreach ($arrItems as $key => $arrItem) {
1028            $product_class_id = $arrItem['product_class_id'];
1029
1030            foreach ($arrItem as $detailKey => $detailVal) {
1031                $arrResults[$key][$detailKey] = $detailVal;
1032            }
1033            // 商品詳細を関連づける
1034            if ($has_detail) {
1035                $arrResults[$key]['productsClass']
1036                    =& $objProduct->getDetailAndProductsClass($product_class_id);
1037            }
1038        }
1039        return $arrResults;
1040    }
1041
1042    /**
1043     * 受注完了メールを送信する.
1044     *
1045     * HTTP_USER_AGENT の種別により, 携帯電話の場合は携帯用の文面,
1046     * PC の場合は PC 用の文面でメールを送信する.
1047     *
1048     * @param integer $orderId 受注ID
1049     * @return void
1050     */
1051    function sendOrderMail($orderId) {
1052        $mailHelper = new SC_Helper_Mail_Ex();
1053        $mailHelper->sfSendOrderMail($orderId,
1054                                     SC_MobileUserAgent_Ex::isMobile() ? 2 : 1);
1055    }
1056
1057    /**
1058     * 受注.対応状況の更新
1059     *
1060     * 必ず呼び出し元でトランザクションブロックを開いておくこと。
1061     *
1062     * @param integer $orderId 注文番号
1063     * @param integer|null $newStatus 対応状況 (null=変更無し)
1064     * @param integer|null $newAddPoint 加算ポイント (null=変更無し)
1065     * @param integer|null $newUsePoint 使用ポイント (null=変更無し)
1066     * @param array $sqlval 更新後の値をリファレンスさせるためのパラメーター
1067     * @return void
1068     */
1069    function sfUpdateOrderStatus($orderId, $newStatus = null, $newAddPoint = null, $newUsePoint = null, &$sqlval) {
1070        $objQuery =& SC_Query_Ex::getSingletonInstance();
1071
1072        $arrOrderOld = $objQuery->getRow('status, add_point, use_point, customer_id', 'dtb_order', 'order_id = ?', array($orderId));
1073
1074        // 対応状況が変更無しの場合、DB値を引き継ぐ
1075        if (is_null($newStatus)) {
1076            $newStatus = $arrOrderOld['status'];
1077        }
1078
1079        // 使用ポイント、DB値を引き継ぐ
1080        if (is_null($newUsePoint)) {
1081            $newUsePoint = $arrOrderOld['use_point'];
1082        }
1083
1084        // 加算ポイント、DB値を引き継ぐ
1085        if (is_null($newAddPoint)) {
1086            $newAddPoint = $arrOrderOld['add_point'];
1087        }
1088
1089        if (USE_POINT !== false) {
1090            // 会員.ポイントの加減値
1091            $addCustomerPoint = 0;
1092
1093            // ▼使用ポイント
1094            // 変更前の対応状況が利用対象の場合、変更前の使用ポイント分を戻す
1095            if ($this->isUsePoint($arrOrderOld['status'])) {
1096                $addCustomerPoint += $arrOrderOld['use_point'];
1097            }
1098
1099            // 変更後の対応状況が利用対象の場合、変更後の使用ポイント分を引く
1100            if ($this->isUsePoint($newStatus)) {
1101                $addCustomerPoint -= $newUsePoint;
1102            }
1103
1104            // ▲使用ポイント
1105
1106            // ▼加算ポイント
1107            // 変更前の対応状況が加算対象の場合、変更前の加算ポイント分を戻す
1108            if ($this->isAddPoint($arrOrderOld['status'])) {
1109                $addCustomerPoint -= $arrOrderOld['add_point'];
1110            }
1111
1112            // 変更後の対応状況が加算対象の場合、変更後の加算ポイント分を足す
1113            if ($this->isAddPoint($newStatus)) {
1114                $addCustomerPoint += $newAddPoint;
1115            }
1116            // ▲加算ポイント
1117
1118            if ($addCustomerPoint != 0) {
1119                // ▼会員テーブルの更新
1120                $sqlval = array();
1121                $where = '';
1122                $arrVal = array();
1123                $arrRawSql = array();
1124                $arrRawSqlVal = array();
1125
1126                $sqlval['update_date'] = 'Now()';
1127                $arrRawSql['point'] = 'point + ?';
1128                $arrRawSqlVal[] = $addCustomerPoint;
1129                $where .= 'customer_id = ?';
1130                $arrVal[] = $arrOrderOld['customer_id'];
1131
1132                $objQuery->update('dtb_customer', $sqlval, $where, $arrVal, $arrRawSql, $arrRawSqlVal);
1133                // ▲会員テーブルの更新
1134
1135                // 会員.ポイントをマイナスした場合、
1136                if ($addCustomerPoint < 0) {
1137                    $sql = 'SELECT point FROM dtb_customer WHERE customer_id = ?';
1138                    $point = $objQuery->getOne($sql, array($arrOrderOld['customer_id']));
1139                    // 変更後の会員.ポイントがマイナスの場合、
1140                    if ($point < 0) {
1141                        // ロールバック
1142                        $objQuery->rollback();
1143                        // エラー
1144                        SC_Utils_Ex::sfDispSiteError(LACK_POINT);
1145                    }
1146                }
1147            }
1148        }
1149
1150        // ▼受注テーブルの更新
1151        if (empty($sqlval)) {
1152            $sqlval = array();
1153        }
1154
1155        if (USE_POINT !== false) {
1156            $sqlval['add_point'] = $newAddPoint;
1157            $sqlval['use_point'] = $newUsePoint;
1158        }
1159        // ステータスが発送済みに変更の場合、発送日を更新
1160        if ($arrOrderOld['status'] != ORDER_DELIV && $newStatus == ORDER_DELIV) {
1161            $sqlval['commit_date'] = 'Now()';
1162        }
1163        // ステータスが入金済みに変更の場合、入金日を更新
1164        elseif ($arrOrderOld['status'] != ORDER_PRE_END && $newStatus == ORDER_PRE_END) {
1165            $sqlval['payment_date'] = 'Now()';
1166        }
1167
1168        $sqlval['status'] = $newStatus;
1169        $sqlval['update_date'] = 'Now()';
1170
1171        $dest = $objQuery->extractOnlyColsOf('dtb_order', $sqlval);
1172        $objQuery->update('dtb_order', $dest, 'order_id = ?', array($orderId));
1173        // ▲受注テーブルの更新
1174    }
1175
1176    /**
1177     * 受注の名称列を更新する
1178     *
1179     * @param integer $order_id 更新対象の注文番号
1180     * @param boolean $temp_table 更新対象は「受注_Temp」か
1181     * @static
1182     */
1183    function sfUpdateOrderNameCol($order_id, $temp_table = false) {
1184        $objQuery =& SC_Query_Ex::getSingletonInstance();
1185
1186        if ($temp_table) {
1187            $tgt_table = 'dtb_order_temp';
1188            $sql_where = 'order_temp_id = ?';
1189        } else {
1190            $tgt_table = 'dtb_order';
1191            $sql_where = 'order_id = ?';
1192
1193            $objQuery->update('dtb_shipping', array(),
1194                              $sql_where,
1195                              array($order_id),
1196                              array('shipping_time' =>
1197                                    "(SELECT deliv_time FROM dtb_delivtime WHERE time_id = dtb_shipping.time_id AND deliv_id = dtb_shipping.deliv_id)"));
1198
1199        }
1200
1201        $objQuery->update($tgt_table, array(),
1202                          $sql_where,
1203                          array($order_id),
1204                          array('payment_method' =>
1205                                "(SELECT payment_method FROM dtb_payment WHERE payment_id = " . $tgt_table . ".payment_id)"));
1206    }
1207
1208    /**
1209     * ポイント使用するかの判定
1210     *
1211     * $status が null の場合は false を返す.
1212     *
1213     * @param integer $status 対応状況
1214     * @return boolean 使用するか(会員テーブルから減算するか)
1215     */
1216    function isUsePoint($status) {
1217        if ($status == null) {
1218            return false;
1219        }
1220        switch ($status) {
1221            case ORDER_CANCEL:      // キャンセル
1222                return false;
1223            default:
1224                break;
1225        }
1226
1227        return true;
1228    }
1229
1230    /**
1231     * ポイント加算するかの判定
1232     *
1233     * @param integer $status 対応状況
1234     * @return boolean 加算するか
1235     */
1236    function isAddPoint($status) {
1237        switch ($status) {
1238            case ORDER_NEW:         // 新規注文
1239            case ORDER_PAY_WAIT:    // 入金待ち
1240            case ORDER_PRE_END:     // 入金済み
1241            case ORDER_CANCEL:      // キャンセル
1242            case ORDER_BACK_ORDER:  // 取り寄せ中
1243                return false;
1244
1245            case ORDER_DELIV:       // 発送済み
1246                return true;
1247
1248            default:
1249                break;
1250        }
1251
1252        return false;
1253    }
1254
1255    /**
1256     * セッションに保持している情報を破棄する.
1257     *
1258     * 通常、受注処理(completeOrder)完了後に呼び出され、
1259     * セッション情報を破棄する.
1260     *
1261     * 決済モジュール画面から確認画面に「戻る」場合を考慮し、
1262     * セッション情報を破棄しないカスタマイズを、モジュール側で
1263     * 加える機会を与える.
1264     *
1265     * @param integer $orderId 注文番号
1266     * @param SC_CartSession $objCartSession カート情報のインスタンス
1267     * @param SC_Customer $objCustomer SC_Customer インスタンス
1268     * @param integer $cartKey 登録を行うカート情報のキー
1269     */
1270    function cleanupSession($orderId, &$objCartSession, &$objCustomer, $cartKey) {
1271        // カートの内容を削除する.
1272        $objCartSession->delAllProducts($cartKey);
1273        SC_SiteSession_Ex::unsetUniqId();
1274
1275        // セッションの配送情報を破棄する.
1276        $this->unsetShippingTemp();
1277        $objCustomer->updateSession();
1278    }
1279}
Note: See TracBrowser for help on using the repository browser.