delivery.logic.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229
  1. <?php
  2. /**
  3. * 物流推送
  4. *
  5. *
  6. *
  7. *
  8. * by Jeff Wan
  9. */
  10. defined('InShopNC') or exit('Access Invalid!');
  11. require_once (BASE_CORE_PATH . '/framework/function/http.php');
  12. class deliveryLogic
  13. {
  14. const oms_url = 'https://oapi.lrlz.com/lrlzApiRest/router/rest';
  15. //const oms_url = 'http://oapitest.lrlz.com/lrlzApiRest/router/rest';
  16. private static $appkey = '2015panda';
  17. private static $appPassWord = 'nEs5vu86JSjh89WPW4de2d3e87rwli3e8rw';
  18. private function sign($data) {
  19. return md5(self::$appkey . self::$appPassWord . $data);
  20. }
  21. public function putOrder($pay_sn, $trade_no,$log_fail = true)
  22. {
  23. Log::record(__METHOD__ . " {$pay_sn} {$trade_no}",Log::DEBUG);
  24. // 调试模式下不能推送到oms
  25. if(defined('OMS_PUSH_OFF') && OMS_PUSH_OFF == true) {
  26. return false;
  27. }
  28. $order_list = Model('order')->getNormalOrderList(array('pay_sn'=> $pay_sn), $this->page, '*', 'order_id desc', '', array('order_address', 'order_goods'),true);
  29. if(empty($order_list)) {
  30. Log::record("putOrder:cannot get order list when pay_sn={$pay_sn},trade_no={$trade_no} ",Log::DEBUG);
  31. return false;
  32. }
  33. $order_sn = '';
  34. $delivery_order_list = array();
  35. foreach ($order_list as $order_info)
  36. {
  37. if ($order_info['order_state'] === '20')
  38. {
  39. $nick_name = $order_info['reciver_name'];
  40. $delivery_order = array();
  41. $order_sn = $order_info['order_sn'];
  42. $delivery_order['tid'] = $order_info['order_sn'];
  43. $delivery_order['total_fee'] = $order_info['order_amount'];
  44. $delivery_order['discount_fee'] = '';
  45. $delivery_order['post_fee'] = $order_info['shipping_fee'];
  46. $delivery_order['created'] = date('Y-m-d H:i:s', $order_info['add_time']);
  47. $delivery_order['pay_time'] = date('Y-m-d H:i:s',$order_info['payment_time']);
  48. $delivery_order['buyer_message'] = '';
  49. $delivery_order['express_code'] = '';
  50. $delivery_order['pay_account_type'] = $order_info['payment_code'] == 'wxpay' ? '微信支付': '支付宝';
  51. $delivery_order['pay_account_id'] = '';
  52. $delivery_order['pay_account_no'] = $trade_no;
  53. $delivery_order['buyer_nick'] = $nick_name;
  54. $delivery_order['buyer_email'] = $order_info['buyer_email'];
  55. $delivery_order['trade_memo'] = '';
  56. $delivery_order['receiver_name'] = $order_info['reciver_name'];
  57. $delivery_area = explode("\t", $order_info['reciver_info']['area']);
  58. $delivery_order['receiver_state'] = $delivery_area[0];
  59. $delivery_order['receiver_city'] = $delivery_area[1];
  60. $delivery_order['receiver_district'] = $delivery_area[2];
  61. Log::record("{$delivery_order['receiver_state']} {$delivery_order['receiver_city']} {$delivery_order['receiver_district']}",Log::DEBUG);
  62. $delivery_order['receiver_address'] = $order_info['reciver_info']['street'];
  63. $delivery_order['receiver_zip'] = '000000';
  64. $delivery_order['receiver_mobile'] = $order_info['reciver_info']['mob_phone'];
  65. $delivery_order['receiver_phone'] = $order_info['reciver_info']['tel_phone'];
  66. $delivery_order['order_size'] = count($order_info['extend_order_goods']);
  67. $delivery_order['orderList'] = array();
  68. foreach($order_info['extend_order_goods'] as $key => $goods)
  69. {
  70. $delivery_goods = array();
  71. $delivery_goods['oid'] = $order_info['order_sn'] . $key;
  72. $delivery_goods['tid'] = $order_info['order_sn'];
  73. $delivery_goods['title'] = $goods['goods_name'];
  74. $delivery_goods['price'] = $goods['goods_price'];
  75. $delivery_goods['num'] = $goods['goods_num'];
  76. $goods_serial = Model('goods')->getGoodsInfo(array('goods_id'=>$goods['goods_id']));
  77. $delivery_goods['outer_sku_id'] = $goods_serial['goods_serial'];
  78. $delivery_goods['outer_sku_properties_name'] = $goods['goods_name'];
  79. $delivery_goods['buyer_nick'] = $nick_name;
  80. array_push($delivery_order['orderList'] , $delivery_goods);
  81. }
  82. array_push($delivery_order_list, $delivery_order);
  83. }
  84. }
  85. // 订单状态不对
  86. if (empty($delivery_order_list) || count($delivery_order_list) == 0) {
  87. Log::record("putOrder: pay_sn={$pay_sn}, 错误原因: 订单状态不对",Log::ERR);
  88. return false;
  89. }
  90. $data = array('type' => 'PUT_TRADE', 'data' => $delivery_order_list);
  91. $body = json_encode($data,JSON_UNESCAPED_UNICODE);
  92. $sign = $this->sign($body);
  93. $headers = array('v_appkey: '.self::$appkey, 'v_sign: '.$sign, 'Content-Type: application/json');
  94. $resp = http_post_data(self::oms_url,urlencode($body),$headers);
  95. if($resp === false)
  96. { //网络出现异常时,后台重新推送
  97. if($log_fail) {
  98. $log = array();
  99. $log['pay_sn'] = $pay_sn;
  100. $log['order_sn'] = $order_sn;
  101. $log['trade_no'] = $trade_no;
  102. $log['push_time'] = time();
  103. $log['order_status'] = 0;
  104. Model('omsfail')->insert($log);
  105. }
  106. return false;
  107. }
  108. $success = $this->check($resp,$err_state,$reason);
  109. if($success == false)
  110. {
  111. Log::record("post data={$resp}",Log::ERR);
  112. if($log_fail) {
  113. $log = array();
  114. $log['pay_sn'] = $pay_sn;
  115. $log['order_sn'] = $order_sn;
  116. $log['trade_no'] = $trade_no;
  117. $log['push_time'] = time();
  118. $log['reason'] = $reason;
  119. $log['order_status'] = $err_state;
  120. $log['oms_response'] = $resp;
  121. Model('omsfail')->insert($log);
  122. }
  123. return false;
  124. } else {
  125. return true;
  126. }
  127. }
  128. public function handleCallback($param)
  129. {
  130. $model_order = Model('order');
  131. $condition = array('order_sn' => $param['order_sn']);
  132. $order_info = $model_order->getOrderInfo($condition,array('order_common','order_goods'));
  133. $model_express = Model('express');
  134. $express_info = $model_express->getExpressInfoByOMS($param['oms_code']);
  135. $data['reciver_name'] = $order_info['reciver_name'];
  136. $data['reciver_info'] = $order_info['reciver_info'];
  137. $data['deliver_explain'] = $order_info['deliver_explain'];
  138. $data['daddress_id'] = intval($order_info['daddress_id']);
  139. $data['shipping_express_id'] =intval($express_info['express_id']);
  140. $data['shipping_code'] = $param['shipping_code'];
  141. $logic_order = Logic('order');
  142. $result = $logic_order->changeOrderSend($order_info, 'seller', $order_info['buyer_name'], $data);
  143. return $result;
  144. }
  145. public function cancel_oms($order_sn)
  146. {
  147. $param = array('type' => 'TRADE_INTERCEPT','data' => array('tids' => $order_sn,'remark' => '用户退款'));
  148. $body = json_encode($param,JSON_UNESCAPED_UNICODE);
  149. $sign = $this->sign($body);
  150. $headers = array('v_appkey: '.self::$appkey, 'v_sign: '.$sign, 'Content-Type: application/json');
  151. $resp = http_post_data(self::oms_url,urlencode($body),$headers);
  152. if($resp === false) {
  153. Log::record(__METHOD__ . " NET Error",Log::ERR);
  154. return false;
  155. }
  156. else {
  157. Log::record($resp,Log::DEBUG);
  158. }
  159. return true;
  160. }
  161. /**
  162. * @param $pay_sn
  163. * @param $trade_no
  164. * @param $result
  165. * @param $order_sn
  166. * @return mixed
  167. */
  168. private function check($resp,&$err_state,&$reson)
  169. {
  170. $err_state = 0;
  171. //1:成功 0 :失败
  172. // 1:新订单 2:等待仓库处理 99:已拦截 90:库存不足 7:已发货
  173. // -99:发货失败 -2:订单关闭 -3:订单已存在(没有进行拦截的订单不予更新) -1:异常订单 -2:订单关闭
  174. $result = json_decode($resp, true);
  175. if (!empty($result) && is_array($result))
  176. {
  177. if ($result['apiCode'] == 'success')
  178. {
  179. if (!empty($result['data']) && is_array($result['data']) && count($result['data']) > 0)
  180. {
  181. // 填充错误理由
  182. $reson = $result['data'][0]['errorMessge'];
  183. if (!empty($result['data'][0]['status'])) {
  184. $status = intval($result['data'][0]['status']);
  185. if ($status == 1 || $status == 2 || $status == 3 || $status == 7 || $status == 99) {
  186. return true;
  187. }
  188. } else {
  189. $msg = $result['data'][0]['errorMessge'];
  190. if (strstr($msg, '订单已存在')) {
  191. return true;
  192. } else {
  193. $err_state = 2;
  194. }
  195. }
  196. }
  197. }
  198. }
  199. return false;
  200. }
  201. }