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

Revision 22554, 48.7 KB checked in by pineray, 9 years ago (diff)

#2136 dtb_deliv の処理を SC_Helper_Delivery クラスに集める.

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