source: branches/version-2_12-dev/data/class/helper/SC_Helper_Purchase.php @ 21570

Revision 21570, 47.7 KB checked in by Seasoft, 12 years ago (diff)

#1439 (「お届け先の指定」に戻った際に、選択した状態を引き継いでいない)

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