source: branches/version-2_5-dev/data/class/helper/SC_Helper_Purchase.php @ 20167

Revision 20167, 29.3 KB checked in by nanasess, 11 years ago (diff)

#981([フロント]MYページ)

  • 受注取得処理を抽象化

#642(共通ロジックの機能向上)

  • SC_Query::extractOnlyColsOf() を追加

#628(未使用処理・定義などの削除)

  • SC_Helper_DB クラスの未使用関数を削除
  • 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-2010 LOCKON CO.,LTD. All Rights Reserved.
6 *
7 * http://www.lockon.co.jp/
8 *
9 * This program is free software; you can redistribute it and/or
10 * modify it under the terms of the GNU General Public License
11 * as published by the Free Software Foundation; either version 2
12 * of the License, or (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License
20 * along with this program; if not, write to the Free Software
21 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
22 */
23
24/**
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::getSingletonInstance();
58        $objSiteSession = new SC_SiteSession();
59        $objCartSession = new SC_CartSession();
60        $objCustomer = new SC_Customer();
61        $customerId = $objCustomer->getValue('customer_id');
62
63        $objQuery->begin();
64        if (!$objSiteSession->isPrePage()) {
65            SC_Utils::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        $orderId = $this->registerOrder($orderTemp, $objCartSession,
75                                        $objCartSession->getKey());
76        $shippingTemp =& $this->getShippingTemp();
77        if (count($shippingTemp) > 1) {
78            foreach ($shippingTemp as $shippingId => $val) {
79                $this->registerShipmentItem($orderId, $shippingId,
80                                            $val['shipment_item']);
81            }
82        }
83
84        $this->registerShipping($orderId, $shippingTemp);
85        $objQuery->commit();
86        $this->unsetShippingTemp();
87        $objCustomer->updateSession();
88    }
89
90    /**
91     * カートに変化が無いか検証する.
92     *
93     * ユニークIDとセッションのユニークIDを比較し, 異なる場合は
94     * エラー画面を表示する.
95     *
96     * カートが空の場合, 購入ボタン押下後にカートが変更された場合は
97     * カート画面へ遷移する.
98     *
99     * @param string $uniqId ユニークID
100     * @param SC_CartSession $objCartSession
101     * @return void
102     */
103    function verifyChangeCart($uniqId, &$objCartSession) {
104        $cartKeys = $objCartSession->getKeys();
105
106        // カート内が空でないか
107        if (SC_Utils_Ex::isBlank($cartKeys)) {
108            SC_Response_Ex::sendRedirect(CART_URLPATH);
109            exit;
110        }
111
112        foreach ($cartKeys as $cartKey) {
113            // 初回のみカートの内容を保存
114            $objCartSession->saveCurrentCart($uniqid, $cartKey);
115
116            /*
117             * POSTのユニークIDとセッションのユニークIDを比較
118             *(ユニークIDがPOSTされていない場合はスルー)
119             */
120            if(!SC_SiteSession::checkUniqId()) {
121                SC_Utils_Ex::sfDispSiteError(CANCEL_PURCHASE);
122                exit;
123            }
124
125            // 購入ボタンを押してから変化がないか
126            $quantity = $objCartSession->getTotalQuantity($cartKey);
127            if($objCartSession->checkChangeCart($cartKey) || !($quantity > 0)) {
128                SC_Response_Ex::sendRedirect(CART_URLPATH);
129                exit;
130            }
131        }
132    }
133
134    /**
135     * 受注一時情報を取得する.
136     *
137     * @param integer $uniqId 受注一時情報ID
138     * @return array 受注一時情報の配列
139     */
140    function getOrderTemp($uniqId) {
141        $objQuery =& SC_Query::getSingletonInstance();
142        return $objQuery->getRow("*", "dtb_order_temp", "order_temp_id = ?",
143                                 array($uniqId));
144    }
145
146    /**
147     * 受注一時情報を保存する.
148     *
149     * 既存のデータが存在しない場合は新規保存. 存在する場合は更新する.
150     * 既存のデータが存在せず, ユーザーがログインしている場合は,
151     * 会員情報をコピーする.
152     *
153     * @param integer $uniqId 受注一時情報ID
154     * @param array $params 登録する受注情報の配列
155     * @param SC_Customer $objCustomer SC_Customer インスタンス
156     * @return array void
157     */
158    function saveOrderTemp($uniqId, $params, &$objCustomer) {
159        if (SC_Utils_Ex::isBlank($uniqId)) {
160            return;
161        }
162        $params['device_type_id'] = SC_Display::detectDevice();
163        $objQuery =& SC_Query::getSingletonInstance();
164        // 存在するカラムのみを対象とする
165        $cols = $objQuery->listTableFields('dtb_order_temp');
166        foreach ($params as $key => $val) {
167            if (in_array($key, $cols)) {
168                $sqlval[$key] = $val;
169            }
170        }
171
172        $sqlval['session'] = serialize($_SESSION);
173        $exists = $this->getOrderTemp($uniqId);
174        if (SC_Utils_Ex::isBlank($exists)) {
175            $this->copyFromCustomer($sqlval, $objCustomer);
176            $sqlval['order_temp_id'] = $uniqId;
177            $sqlval['create_date'] = "now()";
178            $objQuery->insert("dtb_order_temp", $sqlval);
179        } else {
180            $objQuery->update("dtb_order_temp", $sqlval, 'order_temp_id = ?',
181                              array($uniqId));
182        }
183    }
184
185    /**
186     * セッションの配送情報を取得する.
187     */
188    function getShippingTemp() {
189        return $_SESSION['shipping'];
190    }
191
192    /**
193     * 配送商品を設定する.
194     *
195     * @param integer $shipping_id 配送先ID
196     * @param integer $product_class_id 商品規格ID
197     * @param integer $quantity 数量
198     * @return void
199     */
200    function setShipmentItemTemp($shipping_id, $product_class_id, $quantity) {
201        // 配列が長くなるので, リファレンスを使用する
202        $arrItems =& $_SESSION['shipping'][$shipping_id]['shipment_item'];
203
204        $arrItems[$product_class_id]['shipping_id'] = $shipping_id;
205        $arrItems[$product_class_id]['product_class_id'] = $product_class_id;
206        $arrItems[$product_class_id]['quantity'] += $quantity;
207
208        $objProduct = new SC_Product();
209        if (empty($arrItems[$product_class_id]['productsClass'])) {
210            $product =& $objProduct->getDetailAndProductsClass($product_class_id);
211            $arrItems[$product_class_id]['productsClass'] = $product;
212        }
213        $incTax = SC_Helper_DB_Ex::sfCalcIncTax($arrItems[$product_class_id]['productsClass']['price02']);
214        $arrItems[$product_class_id]['total_inctax'] = $incTax * $arrItems[$product_class_id]['quantity'];
215    }
216
217    /**
218     * 配送商品の情報でカートを更新する.
219     *
220     * @param SC_CartSession $objCartSession SC_CartSession インスタンス
221     */
222    function shippingItemTempToCart(&$objCartSession) {
223        $arrShipmentItems = array();
224
225        foreach (array_keys($_SESSION['shipping']) as $shipping_id) {
226            foreach (array_keys($_SESSION['shipping'][$shipping_id]['shipment_item']) as $product_class_id) {
227                $arrShipmentItems[$product_class_id] += $_SESSION['shipping'][$shipping_id]['shipment_item'][$product_class_id]['quantity'];
228           }
229        }
230        foreach ($arrShipmentItems as $product_class_id => $quantity) {
231            $objCartSession->setProductValue($product_class_id, 'quantity',
232                                             $quantity,$objCartSession->getKey());
233        }
234    }
235
236    /**
237     * 配送先都道府県の配列を返す.
238     */
239    function getShippingPref() {
240        $results = array();
241        foreach ($_SESSION['shipping'] as $val) {
242            $results[] = $val['shipping_pref'];
243        }
244        return $results;
245    }
246
247    /**
248     * 複数配送指定の購入かどうか.
249     *
250     * @return boolean 複数配送指定の購入の場合 true
251     */
252    function isMultiple() {
253        return (count($this->getShippingTemp()) > 1);
254    }
255
256    /**
257     * 配送情報をセッションに保存する.
258     *
259     * @param array $arrSrc 配送情報の連想配列
260     * @param integer $shipping_id 配送先ID
261     * @return void
262     */
263    function saveShippingTemp(&$arrSrc, $shipping_id = 0) {
264        if (empty($_SESSION['shipping'][$shipping_id])) {
265            $_SESSION['shipping'][$shipping_id] = $arrSrc;
266            $_SESSION['shipping'][$shipping_id]['shipping_id'] = $shipping_id;
267        } else {
268            $_SESSION['shipping'][$shipping_id] = array_merge($_SESSION['shipping'][$shipping_id], $arrSrc);
269            $_SESSION['shipping'][$shipping_id]['shipping_id'] = $shipping_id;
270        }
271    }
272
273    /**
274     * セッションの配送情報を破棄する.
275     */
276    function unsetShippingTemp() {
277        unset($_SESSION['shipping']);
278    }
279
280    /**
281     * 会員情報を受注情報にコピーする.
282     *
283     * ユーザーがログインしていない場合は何もしない.
284     * 会員情報を $dest の order_* へコピーする.
285     * customer_id は強制的にコピーされる.
286     *
287     * @param array $dest コピー先の配列
288     * @param SC_Customer $objCustomer SC_Customer インスタンス
289     * @param string $prefix コピー先の接頭辞. デフォルト order
290     * @param array $keys コピー対象のキー
291     * @return void
292     */
293    function copyFromCustomer(&$dest, &$objCustomer, $prefix = 'order',
294                              $keys = array('name01', 'name02', 'kana01', 'kana02',
295                                            'sex', 'zip01', 'zip02', 'pref',
296                                            'addr01', 'addr02',
297                                            'tel01', 'tel02', 'tel03', 'job',
298                                            'birth', 'email')) {
299        if ($objCustomer->isLoginSuccess(true)) {
300
301            foreach ($keys as $key) {
302                if (in_array($key, $keys)) {
303                    $dest[$prefix . '_' . $key] = $objCustomer->getValue($key);
304                }
305            }
306
307            if (Net_UserAgent_Mobile::isMobile()
308                && in_array('email', $keys)) {
309                $email_mobile = $objCustomer->getValue('email_mobile');
310                if (empty($email_mobile)) {
311                    $dest[$prefix . '_email'] = $objCustomer->getValue('email');
312                } else {
313                    $dest[$prefix . '_email'] = $email_mobile;
314                }
315            }
316
317            $dest['customer_id'] = $objCustomer->getValue('customer_id');
318            $dest['update_date'] = 'Now()';
319        }
320    }
321
322    /**
323     * 受注情報を配送情報にコピーする.
324     *
325     * 受注情報($src)を $dest の order_* へコピーする.
326     *
327     * TODO 汎用的にして SC_Utils へ移動
328     *
329     * @param array $dest コピー先の配列
330     * @param array $src コピー元の配列
331     * @param array $keys コピー対象のキー
332     * @param string $prefix コピー先の接頭辞. デフォルト shipping
333     * @param string $src_prefix コピー元の接頭辞. デフォルト order
334     * @return void
335     */
336    function copyFromOrder(&$dest, $src,
337                           $prefix = 'shipping', $src_prefix = 'order',
338                           $keys = array('name01', 'name02', 'kana01', 'kana02',
339                                         'sex', 'zip01', 'zip02', 'pref',
340                                         'addr01', 'addr02',
341                                         'tel01', 'tel02', 'tel03')) {
342        if (!SC_Utils_Ex::isBlank($prefix)) {
343            $prefix = $prefix . '_';
344        }
345        if (!SC_Utils_Ex::isBlank($src_prefix)) {
346            $src_prefix = $src_prefix . '_';
347        }
348        foreach ($keys as $key) {
349            if (in_array($key, $keys)) {
350                $dest[$prefix . $key] = $src[$src_prefix . $key];
351            }
352        }
353    }
354
355    /**
356     * 購入金額に応じた支払方法を取得する.
357     *
358     * @param integer $total 購入金額
359     * @param integer $deliv_id 配送業者ID
360     * @return array 購入金額に応じた支払方法の配列
361     */
362    function getPaymentsByPrice($total, $deliv_id) {
363
364        $arrPaymentIds = $this->getPayments($deliv_id);
365        $objQuery =& SC_Query::getSingletonInstance();
366
367        // 削除されていない支払方法を取得
368        $where = 'del_flg = 0 AND payment_id IN (' . implode(', ', array_pad(array(), count($arrPaymentIds), '?')) . ')';
369        $objQuery->setOrder("rank DESC");
370        $payments = $objQuery->select("payment_id, payment_method, rule, upper_rule, note, payment_image, charge", "dtb_payment", $where, $arrPaymentIds);
371
372        foreach ($payments as $data) {
373            // 下限と上限が設定されている
374            if (strlen($data['rule']) != 0 && strlen($data['upper_rule']) != 0) {
375                if ($data['rule'] <= $total_inctax && $data['upper_rule'] >= $total_inctax) {
376                    $arrPayment[] = $data;
377                }
378            }
379            // 下限のみ設定されている
380            elseif (strlen($data['rule']) != 0) {
381                if($data['rule'] <= $total_inctax) {
382                    $arrPayment[] = $data;
383                }
384            }
385            // 上限のみ設定されている
386            elseif (strlen($data['upper_rule']) != 0) {
387                if($data['upper_rule'] >= $total_inctax) {
388                    $arrPayment[] = $data;
389                }
390            }
391            // いずれも設定なし
392            else {
393                $arrPayment[] = $data;
394            }
395          }
396        return $arrPayment;
397    }
398
399    /**
400     * お届け日一覧を取得する.
401     */
402    function getDelivDate(&$objCartSess, $productTypeId) {
403        $cartList = $objCartSess->getCartList($productTypeId);
404        $delivDateIds = array();
405        foreach ($cartList as $item) {
406            $delivDateIds[] = $item['productsClass']['deliv_date_id'];
407        }
408        $max_date = max($delivDateIds);
409        //発送目安
410        switch($max_date) {
411        //即日発送
412        case '1':
413            $start_day = 1;
414            break;
415            //1-2日後
416        case '2':
417            $start_day = 3;
418            break;
419            //3-4日後
420        case '3':
421            $start_day = 5;
422            break;
423            //1週間以内
424        case '4':
425            $start_day = 8;
426            break;
427            //2週間以内
428        case '5':
429            $start_day = 15;
430            break;
431            //3週間以内
432        case '6':
433            $start_day = 22;
434            break;
435            //1ヶ月以内
436        case '7':
437            $start_day = 32;
438            break;
439            //2ヶ月以降
440        case '8':
441            $start_day = 62;
442            break;
443            //お取り寄せ(商品入荷後)
444        case '9':
445            $start_day = "";
446            break;
447        default:
448            //お届け日が設定されていない場合
449            $start_day = "";
450        }
451        //お届け可能日のスタート値から、お届け日の配列を取得する
452        $arrDelivDate = $this->getDateArray($start_day, DELIV_DATE_END_MAX);
453        return $arrDelivDate;
454    }
455
456    /**
457     * お届け可能日のスタート値から, お届け日の配列を取得する.
458     */
459    function getDateArray($start_day, $end_day) {
460        $masterData = new SC_DB_MasterData();
461        $arrWDAY = $masterData->getMasterData("mtb_wday");
462        //お届け可能日のスタート値がセットされていれば
463        if($start_day >= 1) {
464            $now_time = time();
465            $max_day = $start_day + $end_day;
466            // 集計
467            for ($i = $start_day; $i < $max_day; $i++) {
468                // 基本時間から日数を追加していく
469                $tmp_time = $now_time + ($i * 24 * 3600);
470                list($y, $m, $d, $w) = split(" ", date("Y m d w", $tmp_time));
471                $val = sprintf("%04d/%02d/%02d(%s)", $y, $m, $d, $arrWDAY[$w]);
472                $arrDate[$val] = $val;
473            }
474        } else {
475            $arrDate = false;
476        }
477        return $arrDate;
478    }
479
480    /**
481     * 配送業者IDからお届け時間の配列を取得する.
482     *
483     * @param integer $deliv_id 配送業者ID
484     * @return array お届け時間の配列
485     */
486    function getDelivTime($deliv_id) {
487        $objQuery =& SC_Query::getSingletonInstance();
488        $objQuery->setOrder('time_id');
489        $results = $objQuery->select('time_id, deliv_time',
490                                     'dtb_delivtime',
491                                     'deliv_id = ?', array($deliv_id));
492        $arrDelivTime = array();
493        foreach ($results as $val) {
494            $arrDelivTime[$val['time_id']] = $val['deliv_time'];
495        }
496        return $arrDelivTime;
497    }
498
499    /**
500     * 商品種別ID から配送業者を取得する.
501     *
502     * @param integer $product_type_id 商品種別ID
503     * @return array 配送業者の配列
504     */
505    function getDeliv($product_type_id) {
506        $objQuery =& SC_Query::getSingletonInstance();
507        $objQuery->setOrder('rank');
508        return $objQuery->select('*', 'dtb_deliv', 'product_type_id = ?',
509                                 array($product_type_id));
510    }
511
512    /**
513     * 配送業者ID から, 有効な支払方法IDを取得する.
514     *
515     * @param integer $deliv_id 配送業者ID
516     * @return array 有効な支払方法IDの配列
517     */
518    function getPayments($deliv_id) {
519        $objQuery =& SC_Query::getSingletonInstance();
520        $objQuery->setOrder('rank');
521        return $objQuery->getCol('payment_id', 'dtb_payment_options',
522                                 'deliv_id = ?',
523                                 array($deliv_id), MDB2_FETCHMODE_ORDERED);
524    }
525
526    /**
527     * 配送情報の登録を行う.
528     *
529     * $arrParam のうち, dtb_shipping テーブルに存在するカラムのみを登録する.
530     *
531     * @param integer $order_id 受注ID
532     * @param array $arrParams 配送情報の連想配列
533     * @return void
534     */
535    function registerShipping($order_id, $arrParams) {
536        $objQuery =& SC_Query::getSingletonInstance();
537        $table = 'dtb_shipping';
538
539         foreach ($arrParams as $arrShipping) {
540
541            $arrValues = $objQuery->extractOnlyColsOf($table, $arrShipping);
542
543            // 配送日付を timestamp に変換
544            if (!SC_Utils_Ex::isBlank($arrValues['shipping_date'])) {
545                $d = mb_strcut($arrValues["shipping_date"], 0, 10);
546                $arrDate = split("/", $d);
547                $ts = mktime(0, 0, 0, $arrDate[1], $arrDate[2], $arrDate[0]);
548                $arrValues['shipping_date'] = date("Y-m-d", $ts);
549            }
550
551            $arrValues['order_id'] = $order_id;
552            $arrValues['create_date'] = 'Now()';
553            $arrValues['update_date'] = 'Now()';
554            $objQuery->insert($table, $arrValues);
555        }
556    }
557
558    /**
559     * 配送商品を登録する.
560     *
561     * @param integer $order_id 受注ID
562     * @param integer $shipping_id 配送先ID
563     * @param array $arrParams 配送商品の配列
564     * @return void
565     */
566    function registerShipmentItem($orderId, $shippingId, $params) {
567        $objQuery =& SC_Query::getSingletonInstance();
568        $objProduct = new SC_Product();
569        foreach ($params as $productClassId => $val) {
570            $d = $objProduct->getDetailAndProductsClass($productClassId);
571            $sqlval['order_id'] = $orderId;
572            $sqlval['shipping_id'] = $shippingId;
573            $sqlval['product_class_id'] = $productClassId;
574            $sqlval['product_name'] = $d['name'];
575            $sqlval['product_code'] = $d['product_code'];
576            $sqlval['classcategory_name1'] = $d['classcategory_name1'];
577            $sqlval['classcategory_name2'] = $d['classcategory_name2'];
578            $sqlval['price'] = $d['price02'];
579            $sqlval['quantity'] = $val['quantity'];
580            $objQuery->insert("dtb_shipment_item", $sqlval);
581        }
582    }
583
584    /**
585     * 受注情報を登録する.
586     *
587     * 引数の受注情報を受注テーブル及び受注詳細テーブルに登録する.
588     * 登録後, 受注一時テーブルに削除フラグを立て, カートの内容を削除する.
589     *
590     * TODO ダウンロード商品の場合の扱いを検討
591     *
592     * @param array $orderParams 登録する受注情報の配列
593     * @param SC_CartSession $objCartSession カート情報のインスタンス
594     * @param integer $cartKey 登録を行うカート情報のキー
595     * @param integer 受注ID
596     */
597    function registerOrder($orderParams, &$objCartSession, $cartKey) {
598        $objQuery =& SC_Query::getSingletonInstance();
599
600        // 不要な変数を unset
601        $unsets = array('mailmaga_flg', 'deliv_check', 'point_check', 'password',
602                        'reminder', 'reminder_answer', 'mail_flag', 'session');
603        foreach ($unsets as $unset) {
604            unset($orderParams[$unset]);
605        }
606
607        // ポイントは別登録
608        $addPoint = $orderParams['add_point'];
609        $usePoint = $orderParams['use_point'];
610        $orderParams['add_point'] = 0;
611        $orderParams['use_point'] = 0;
612
613        // 注文ステータスの指定が無い場合は新規受付
614        if(SC_Utils_Ex::isBlank($orderParams['status'])) {
615            $orderParams['status'] = ORDER_NEW;
616        }
617
618        $orderParams['create_date'] = 'Now()';
619        $orderParams['update_date'] = 'Now()';
620
621        $objQuery->insert("dtb_order", $orderParams);
622
623        // 受注.対応状況の更新
624        SC_Helper_DB_Ex::sfUpdateOrderStatus($orderParams['order_id'],
625                                             null, $addPoint, $usePoint);
626
627        // 詳細情報を取得
628        $cartItems = $objCartSession->getCartList($cartKey);
629
630        // 既に存在する詳細レコードを消しておく。
631        $objQuery->delete("dtb_order_detail", "order_id = ?",
632                          array($orderParams['order_id']));
633
634        $objProduct = new SC_Product();
635        foreach ($cartItems as $item) {
636            $p =& $item['productsClass'];
637            $detail['order_id'] = $orderParams['order_id'];
638            $detail['product_id'] = $p['product_id'];
639            $detail['product_class_id'] = $p['product_class_id'];
640            $detail['product_name'] = $p['name'];
641            $detail['product_code'] = $p['product_code'];
642            $detail['classcategory_name1'] = $p['classcategory_name1'];
643            $detail['classcategory_name2'] = $p['classcategory_name2'];
644            $detail['point_rate'] = $item['point_rate'];
645            $detail['price'] = $item['price'];
646            $detail['quantity'] = $item['quantity'];
647
648            // 在庫の減少処理
649            if (!$objProduct->reduceStock($p['product_class_id'], $item['quantity'])) {
650                $objQuery->rollback();
651                SC_Utils_Ex::sfDispSiteError(SOLD_OUT, "", true);
652            }
653            $objQuery->insert("dtb_order_detail", $detail);
654        }
655
656        $objQuery->update("dtb_order_temp", array('del_flg' => 1),
657                          "order_temp_id = ?",
658                          array(SC_SiteSession::getUniqId()));
659
660        $objCartSession->delAllProducts($cartKey);
661        SC_SiteSession::unsetUniqId();
662        return $orderParams['order_id'];
663    }
664
665    /**
666     * 受注情報を取得する.
667     *
668     * @param integer $order_id 受注ID
669     * @param integer $customer_id 顧客ID
670     * @return array 受注情報の配列
671     */
672    function getOrder($order_id, $customer_id = null) {
673        $objQuery =& SC_Query::getSingletonInstance();
674        $where = 'order_id = ?';
675        $arrValues = array($order_id);
676        if (!SC_Utils_Ex::isBlank($customer_id)) {
677            $where .= ' AND customer_id = ?';
678            $arrValues[] = $customer_id;
679        }
680        return $objQuery->getRow('*', 'dtb_order', $where, $arrValues);
681    }
682
683    /**
684     * 受注詳細を取得する.
685     *
686     * @param integer $order_id 受注ID
687     * @return array 受注詳細の配列
688     */
689    function getOrderDetail($order_id) {
690        $objQuery =& SC_Query::getSingletonInstance();
691        $dbFactory  = SC_DB_DBFactory_Ex::getInstance();
692        $col = <<< __EOS__
693            T3.product_id,
694            T3.product_class_id as product_class_id,
695            T3.product_type_id AS product_type_id,
696            T2.product_code,
697            T2.product_name,
698            T2.classcategory_name1 AS classcategory_name1,
699            T2.classcategory_name2 AS classcategory_name2,
700            T2.price,
701            T2.quantity,
702            T2.point_rate,
703            T1.status AS status,
704            T1.payment_date AS payment_date,
705            CASE WHEN EXISTS(
706                    SELECT 1 FROM dtb_products
707                     WHERE product_id = T3.product_id
708                       AND del_flg = 0
709                       AND status = 1)
710                 THEN '1' ELSE '0'
711                  END AS enable,
712__EOS__;
713        $col .= $dbFactory->getDownloadableDaysWhereSql('T1') . ' AS effective';
714        $from = <<< __EOS__
715                 dtb_order T1
716            JOIN dtb_order_detail T2
717              ON T1.order_id = T2.order_id
718            JOIN dtb_products_class T3
719              ON T2.product_class_id = T3.product_class_id
720__EOS__;
721        return $objQuery->select($col, $from, 'T1.order_id = ?', array($order_id));
722    }
723
724    /**
725     * 配送情報を取得する.
726     *
727     * @param integer $order_id 受注ID
728     * @param boolean $has_items 結果に配送商品も含める場合 true
729     * @return array 配送情報の配列
730     */
731    function getShippings($order_id, $has_items = true) {
732        $objQuery =& SC_Query::getSingletonInstance();
733        $arrResults = array();
734        $objQuery->setOrder('shipping_id');
735        $arrShippings = $objQuery->select("*", "dtb_shipping", "order_id = ?",
736                                          array($order_id));
737        // shipping_id ごとの配列を生成する
738        foreach ($arrShippings as $shipping) {
739            foreach ($shipping as $key => $val) {
740                $arrResults[$shipping['shipping_id']][$key] = $val;
741            }
742        }
743
744        if ($has_items) {
745            $objProduct = new SC_Product();
746            foreach (array_keys($arrResults) as $shipping_id) {
747                $arrResults[$shipping_id]['shipment_item']
748                        =& $this->getShipmentItems($order_id, $shipping_id);
749            }
750        }
751        return $arrResults;
752    }
753
754    /**
755     * 配送商品を取得する.
756     *
757     * @param integer $order_id 受注ID
758     * @param integer $shipping_id 配送先ID
759     * @param boolean $has_detail 商品詳細も取得する場合 true
760     * @return array 商品規格IDをキーにした配送商品の配列
761     */
762    function getShipmentItems($order_id, $shipping_id, $has_detail = true) {
763        $objQuery =& SC_Query::getSingletonInstance();
764        $objProduct = new SC_Product();
765        $arrResults = array();
766        $arrItems = $objQuery->select("*", "dtb_shipment_item",
767                                      "order_id = ? AND shipping_id = ?",
768                                      array($order_id, $shipping_id));
769
770        foreach ($arrItems as $key => $arrItem) {
771            $product_class_id = $arrItem['product_class_id'];
772
773            foreach ($arrItem as $detailKey => $detailVal) {
774                $arrResults[$product_class_id][$detailKey] = $detailVal;
775            }
776            // 商品詳細を関連づける
777            if ($has_detail) {
778                $arrResults[$product_class_id]['productsClass']
779                    =& $objProduct->getDetailAndProductsClass($product_class_id);
780            }
781        }
782        return $arrResults;
783    }
784
785    /**
786     * 受注完了メールを送信する.
787     *
788     * HTTP_USER_AGENT の種別により, 携帯電話の場合は携帯用の文面,
789     * PC の場合は PC 用の文面でメールを送信する.
790     *
791     * @param integer $orderId 受注ID
792     * @return void
793     */
794    function sendOrderMail($orderId) {
795        $mailHelper = new SC_Helper_Mail_Ex();
796        $mailHelper->sfSendOrderMail($orderId,
797                                     SC_MobileUserAgent::isMobile() ? 2 : 1);
798    }
799}
Note: See TracBrowser for help on using the repository browser.