order.logic.php 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420
  1. <?php
  2. /**
  3. * 实物订单行为
  4. *
  5. * 好商城 V3 33hao.com
  6. */
  7. defined('InShopNC') or exit('Access Invalid!');
  8. require_once(BASE_ROOT_PATH . '/helper/account_helper.php');
  9. class orderLogic
  10. {
  11. /**
  12. * 取消订单
  13. * @param array $order_info
  14. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  15. * @param string $user 操作人
  16. * @param string $msg 操作备注
  17. * @param boolean $if_update_account 是否变更账户金额
  18. * @param boolean $if_queue 是否使用队列
  19. * @return array
  20. */
  21. public function changeOrderStateCancel($order_info, $role, $user = '', $msg = '', $if_update_account = true, $if_quque = true)
  22. {
  23. try {
  24. $model_order = Model('order');
  25. $trans = new trans_wapper($model_order,__METHOD__);
  26. $order_id = $order_info['order_id'];
  27. //库存销量变更
  28. $goods_list = $model_order->getOrderGoodsList(array('order_id'=>$order_id));
  29. $data = array();
  30. foreach ($goods_list as $goods) {
  31. $data[$goods['goods_id']] = $goods['goods_num'];
  32. }
  33. if ($if_quque) {
  34. QueueClient::push('cancelOrderUpdateStorage', $data);
  35. } else {
  36. Logic('queue')->cancelOrderUpdateStorage($data);
  37. }
  38. if ($if_update_account) {
  39. $model_pd = Model('predeposit');
  40. //解冻充值卡
  41. $rcb_amount = floatval($order_info['rcb_amount']);
  42. if ($rcb_amount > 0) {
  43. $data_pd = array();
  44. $data_pd['member_id'] = $order_info['buyer_id'];
  45. $data_pd['member_name'] = $order_info['buyer_name'];
  46. $data_pd['amount'] = $rcb_amount;
  47. $data_pd['order_sn'] = $order_info['order_sn'];
  48. $model_pd->changeRcb('order_cancel',$data_pd);
  49. }
  50. //解冻预存款
  51. $pd_amount = floatval($order_info['pd_amount']);
  52. if ($pd_amount > 0) {
  53. $data_pd = array();
  54. $data_pd['member_id'] = $order_info['buyer_id'];
  55. $data_pd['member_name'] = $order_info['buyer_name'];
  56. $data_pd['amount'] = $pd_amount;
  57. $data_pd['order_sn'] = $order_info['order_sn'];
  58. $model_pd->changePd('order_cancel',$data_pd);
  59. }
  60. }
  61. //更新订单信息
  62. $update_order = array('order_state' => ORDER_STATE_CANCEL, 'pd_amount' => 0);
  63. $update = $model_order->editOrder($update_order,array('order_id'=>$order_id));
  64. if (!$update) {
  65. throw new Exception('保存失败');
  66. }
  67. //添加订单日志
  68. $data = array();
  69. $data['order_id'] = $order_id;
  70. $data['log_role'] = $role;
  71. $data['log_msg'] = '取消了订单';
  72. $data['log_user'] = $user;
  73. if ($msg) {
  74. $data['log_msg'] .= ' ( '.$msg.' )';
  75. }
  76. $data['log_orderstate'] = ORDER_STATE_CANCEL;
  77. $model_order->addOrderLog($data);
  78. $trans->commit();
  79. return callback(true,'操作成功');
  80. } catch (Exception $e) {
  81. $trans->rollback();
  82. return callback(false,'操作失败');
  83. }
  84. }
  85. /**
  86. * 收货
  87. * @param array $order_info
  88. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  89. * @param string $user 操作人
  90. * @param string $msg 操作备注
  91. * @return array
  92. */
  93. public function changeOrderStateReceive($order_info, $role, $user = '', $msg = '') {
  94. try {
  95. //v3-b11
  96. $member_id=$order_info['buyer_id'];
  97. $order_id = $order_info['order_id'];
  98. $model_order = Model('order');
  99. //更新订单状态
  100. $update_order = array();
  101. $update_order['finnshed_time'] = time();
  102. $update_order['order_state'] = ORDER_STATE_SUCCESS;
  103. $update = $model_order->editOrder($update_order,array('order_id'=>$order_id));
  104. if (!$update) {
  105. throw new Exception('保存失败');
  106. }
  107. account_helper::onOrderSuccess($order_id);
  108. //添加订单日志
  109. $data = array();
  110. $data['order_id'] = $order_id;
  111. $data['log_role'] = 'buyer';
  112. $data['log_msg'] = '签收了货物';
  113. $data['log_user'] = $user;
  114. if ($msg) {
  115. $data['log_msg'] .= ' ( '.$msg.' )';
  116. }
  117. $data['log_orderstate'] = ORDER_STATE_SUCCESS;
  118. $model_order->addOrderLog($data);
  119. //添加会员积分
  120. if (C('points_isuse') == 1){
  121. Model('points')->savePointsLog('order',array('pl_memberid'=>$order_info['buyer_id'],'pl_membername'=>$order_info['buyer_name'],'orderprice'=>$order_info['order_amount'],'order_sn'=>$order_info['order_sn'],'order_id'=>$order_info['order_id']),true);
  122. }
  123. //添加会员经验值
  124. Model('exppoints')->saveExppointsLog('order',array('exp_memberid'=>$order_info['buyer_id'],'exp_membername'=>$order_info['buyer_name'],'orderprice'=>$order_info['order_amount'],'order_sn'=>$order_info['order_sn'],'order_id'=>$order_info['order_id']),true);
  125. //邀请人获得返利积分 by 33ha o .com
  126. $model_member = Model('member');
  127. $inviter_id = $model_member->table('member')->getfby_member_id($member_id,'inviter_id');
  128. $inviter_name = $model_member->table('member')->getfby_member_id($inviter_id,'member_name');
  129. $rebate_amount = ceil(0.01 * $order_info['order_amount'] * $GLOBALS['setting_config']['points_rebate']);
  130. Model('points')->savePointsLog('rebate',array('pl_memberid'=>$inviter_id,'pl_membername'=>$inviter_name,'rebate_amount'=>$rebate_amount),true);
  131. return callback(true,'操作成功');
  132. } catch (Exception $e) {
  133. return callback(false,'操作失败');
  134. }
  135. }
  136. /**
  137. * 更改运费
  138. * @param array $order_info
  139. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  140. * @param string $user 操作人
  141. * @param float $price 运费
  142. * @return array
  143. */
  144. public function changeOrderShipPrice($order_info, $role, $user = '', $price) {
  145. try {
  146. $order_id = $order_info['order_id'];
  147. $model_order = Model('order');
  148. $data = array();
  149. $data['shipping_fee'] = abs(floatval($price));
  150. $data['order_amount'] = array('exp','goods_amount+'.$data['shipping_fee']);
  151. $update = $model_order->editOrder($data,array('order_id'=>$order_id));
  152. if (!$update) {
  153. throw new Exception('保存失败');
  154. }
  155. //记录订单日志
  156. $data = array();
  157. $data['order_id'] = $order_id;
  158. $data['log_role'] = $role;
  159. $data['log_user'] = $user;
  160. $data['log_msg'] = '修改了运费'.'( '.$price.' )';;
  161. $data['log_orderstate'] = $order_info['payment_code'] == 'offline' ? ORDER_STATE_PAY : ORDER_STATE_NEW;
  162. $model_order->addOrderLog($data);
  163. return callback(true,'操作成功');
  164. } catch (Exception $e) {
  165. return callback(false,'操作失败');
  166. }
  167. }
  168. /**
  169. * 更改运费
  170. * @param array $order_info
  171. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  172. * @param string $user 操作人
  173. * @param float $price 运费
  174. * @return array
  175. */
  176. public function changeOrderSpayPrice($order_info, $role, $user = '', $price) {
  177. try {
  178. $order_id = $order_info['order_id'];
  179. $model_order = Model('order');
  180. $data = array();
  181. $data['goods_amount'] = abs(floatval($price));
  182. $data['order_amount'] = array('exp','shipping_fee+'.$data['goods_amount']);
  183. $update = $model_order->editOrder($data,array('order_id'=>$order_id));
  184. if (!$update) {
  185. throw new Exception('保存失败');
  186. }
  187. //记录订单日志
  188. $data = array();
  189. $data['order_id'] = $order_id;
  190. $data['log_role'] = $role;
  191. $data['log_user'] = $user;
  192. $data['log_msg'] = '修改了运费'.'( '.$price.' )';;
  193. $data['log_orderstate'] = $order_info['payment_code'] == 'offline' ? ORDER_STATE_PAY : ORDER_STATE_NEW;
  194. $model_order->addOrderLog($data);
  195. return callback(true,'操作成功');
  196. } catch (Exception $e) {
  197. return callback(false,'操作失败');
  198. }
  199. }
  200. /**
  201. * 回收站操作(放入回收站、还原、永久删除)
  202. * @param array $order_info
  203. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  204. * @param string $state_type 操作类型
  205. * @return array
  206. */
  207. public function changeOrderStateRecycle($order_info, $role, $state_type) {
  208. $order_id = $order_info['order_id'];
  209. $model_order = Model('order');
  210. //更新订单删除状态
  211. $state = str_replace(array('delete','drop','restore'), array(ORDER_DEL_STATE_DELETE,ORDER_DEL_STATE_DROP,ORDER_DEL_STATE_DEFAULT), $state_type);
  212. $update = $model_order->editOrder(array('delete_state'=>$state),array('order_id'=>$order_id));
  213. if (!$update) {
  214. return callback(false,'操作失败');
  215. } else {
  216. return callback(true,'操作成功');
  217. }
  218. }
  219. /**
  220. * 发货
  221. * @param array $order_info
  222. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  223. * @param string $user 操作人
  224. * @return array
  225. */
  226. public function changeOrderSend($order_info, $role, $user = '', $post = array())
  227. {
  228. $order_id = $order_info['order_id'];
  229. $model_order = Model('order');
  230. try
  231. {
  232. $trans = new trans_wapper($model_order,__METHOD__);
  233. $data = array();
  234. $data['reciver_name'] = $post['reciver_name'];
  235. $data['reciver_info'] = $post['reciver_info'];
  236. $data['deliver_explain'] = $post['deliver_explain'];
  237. $data['daddress_id'] = intval($post['daddress_id']);
  238. $data['shipping_express_id'] = intval($post['shipping_express_id']);
  239. $data['shipping_time'] = time();
  240. $condition = array();
  241. $condition['order_id'] = $order_id;
  242. $store_id = intval($_SESSION['store_id']);
  243. if($store_id <= 0) {
  244. $condition['store_id'] = intval($post['store_id']);
  245. }
  246. $update = $model_order->editOrderCommon($data,$condition);
  247. if (!$update) {
  248. throw new Exception('操作失败');
  249. }
  250. $data = array();
  251. $data['shipping_code'] = $post['shipping_code'];
  252. $data['order_state'] = ORDER_STATE_SEND;
  253. $data['delay_time'] = time();
  254. $update = $model_order->editOrder($data,$condition);
  255. if (!$update) {
  256. throw new Exception('操作失败');
  257. }
  258. $trans->commit();
  259. } catch (Exception $e) {
  260. $trans->rollback();
  261. return callback(false,$e->getMessage());
  262. }
  263. //更新表发货信息
  264. if ($post['shipping_express_id'] && $order_info['extend_order_common']['reciver_info']['dlyp']) {
  265. $data = array();
  266. $data['shipping_code'] = $post['shipping_code'];
  267. $data['order_sn'] = $order_info['order_sn'];
  268. $express_info = Model('express')->getExpressInfo(intval($post['shipping_express_id']));
  269. $data['express_code'] = $express_info['e_code'];
  270. $data['express_name'] = $express_info['e_name'];
  271. Model('delivery_order')->editDeliveryOrder($data,array('order_id' => $order_info['order_id']));
  272. }
  273. //添加订单日志
  274. $data = array();
  275. $data['order_id'] = intval($_GET['order_id']);
  276. $data['log_role'] = 'seller';
  277. $data['log_user'] = $_SESSION['member_name'];
  278. $data['log_msg'] = '发出了货物 ( 编辑了发货信息 )';
  279. $data['log_orderstate'] = ORDER_STATE_SEND;
  280. $model_order->addOrderLog($data);
  281. // 发送买家消息
  282. $param = array();
  283. $param['code'] = 'order_deliver_success';
  284. $param['member_id'] = $order_info['buyer_id'];
  285. $param['param'] = array(
  286. 'order_sn' => $order_info['order_sn'],
  287. 'order_url' => urlShop('member_order', 'show_order', array('order_id' => $order_id))
  288. );
  289. QueueClient::push('sendMemberMsg', $param);
  290. return callback(true,'操作成功');
  291. }
  292. /**
  293. * 收到货款
  294. * @param array $order_info
  295. * @param string $role 操作角色 buyer、seller、admin、system 分别代表买家、商家、管理员、系统
  296. * @param string $user 操作人
  297. * @return array
  298. */
  299. public function changeOrderReceivePay($order_list, $role, $user = '', $post = array()) {
  300. $model_order = Model('order');
  301. try {
  302. $trans = new trans_wapper($model_order,__METHOD__);
  303. $data = array();
  304. $data['api_pay_state'] = 1;
  305. // 33hao
  306. $update = $model_order->editOrderPay($data,array('pay_sn'=>$order_list[0]['pay_sn']));
  307. //$update = $model_order->editOrderPay($data,array('pay_sn'=>$order_info['pay_sn']));
  308. if (!$update) {
  309. throw new Exception('更新支付单状态失败');
  310. }
  311. $model_pd = Model('predeposit');
  312. foreach($order_list as $order_info) {
  313. $order_id = $order_info['order_id'];
  314. if ($order_info['order_state'] != ORDER_STATE_NEW) continue;
  315. //下单,支付被冻结的充值卡
  316. $rcb_amount = floatval($order_info['rcb_amount']);
  317. if ($rcb_amount > 0) {
  318. $data_pd = array();
  319. $data_pd['member_id'] = $order_info['buyer_id'];
  320. $data_pd['member_name'] = $order_info['buyer_name'];
  321. $data_pd['amount'] = $rcb_amount;
  322. $data_pd['order_sn'] = $order_info['order_sn'];
  323. $model_pd->changeRcb('order_comb_pay',$data_pd);
  324. }
  325. //下单,支付被冻结的预存款
  326. $pd_amount = floatval($order_info['pd_amount']);
  327. if ($pd_amount > 0) {
  328. $data_pd = array();
  329. $data_pd['member_id'] = $order_info['buyer_id'];
  330. $data_pd['member_name'] = $order_info['buyer_name'];
  331. $data_pd['amount'] = $pd_amount;
  332. $data_pd['order_sn'] = $order_info['order_sn'];
  333. $model_pd->changePd('order_comb_pay',$data_pd);
  334. }
  335. }
  336. //更新订单状态
  337. $update_order = array();
  338. $update_order['order_state'] = ORDER_STATE_PAY;
  339. $update_order['payment_time'] = ($post['payment_time'] ? strtotime($post['payment_time']) : time());
  340. $update_order['payment_code'] = $post['payment_code'];
  341. $update_order['trade_no'] = $post['trade_no'];
  342. $update = $model_order->editOrder($update_order,array('pay_sn'=>$order_info['pay_sn'],'order_state'=>ORDER_STATE_NEW));
  343. if (!$update) {
  344. throw new Exception('操作失败');
  345. }
  346. $trans->commit();
  347. } catch (Exception $e) {
  348. $trans->rollback();
  349. return callback(false,$e->getMessage());
  350. }
  351. foreach($order_list as $order_info) {
  352. //防止重复发送消息 v 3 - 3 3 h a o . c o m
  353. if ($order_info['order_state'] != ORDER_STATE_NEW) continue;
  354. $order_id = $order_info['order_id'];
  355. // 支付成功发送买家消息
  356. $param = array();
  357. $param['code'] = 'order_payment_success';
  358. $param['member_id'] = $order_info['buyer_id'];
  359. $param['param'] = array(
  360. 'order_sn' => $order_info['order_sn'],
  361. 'order_url' => urlShop('member_order', 'show_order', array('order_id' => $order_info['order_id']))
  362. );
  363. QueueClient::push('sendMemberMsg', $param);
  364. // 支付成功发送店铺消息
  365. $param = array();
  366. $param['code'] = 'new_order';
  367. $param['store_id'] = $order_info['store_id'];
  368. $param['param'] = array(
  369. 'order_sn' => $order_info['order_sn']
  370. );
  371. QueueClient::push('sendStoreMsg', $param);
  372. //添加订单日志
  373. $data = array();
  374. $data['order_id'] = $order_id;
  375. $data['log_role'] = $role;
  376. $data['log_user'] = $user;
  377. $data['log_msg'] = '收到了货款 ( 支付平台交易号 : '.$post['trade_no'].' )';
  378. $data['log_orderstate'] = ORDER_STATE_PAY;
  379. $model_order->addOrderLog($data);
  380. }
  381. return callback(true,'操作成功');
  382. }
  383. }