Order.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. <?php
  2. namespace app\index\controller;
  3. use app\index\model\BoxActionModel;
  4. use app\index\model\BoxModel;
  5. use app\index\model\CabinetModel;
  6. use app\index\model\MsgModel;
  7. use app\index\model\OrderModel;
  8. use think\facade\Log;
  9. class Order extends Base
  10. {
  11. const base_url = 'https://yxmall-adminportal.eavic.com/oms-web/box';
  12. public function CheckOrder(){
  13. $order_sn = input('param.order_sn');
  14. //商网接口
  15. $postData['orderCode'] = $order_sn;
  16. $postData = json_encode($postData);
  17. $result = http_post_json(self::base_url . '/check' , $postData);
  18. if($result == false){
  19. json_error(3000);
  20. }
  21. $result = json_decode($result,true);
  22. if(!empty($result) && $result['code'] == 0) {
  23. $existed = $result['data']['isEffective'] != 0;
  24. if($existed == true){
  25. $BoxModel = new BoxModel();
  26. $order = $BoxModel->where('order_sn',$order_sn)->find();
  27. if(!empty($order)){
  28. $existed = false;
  29. }
  30. }
  31. json_success(['order_sn' => $order_sn,'existed' => $existed]);
  32. }
  33. else {
  34. json_return($result['code'],[],$result['message']);
  35. }
  36. }
  37. /**
  38. * 自提柜向服务器上报
  39. */
  40. public function RecordStore()
  41. {
  42. $order_sn = input('param.order_sn');
  43. $trunk = input('param.trunk');
  44. $cabinet_code = input('param.cabinet');
  45. $cabinet = CabinetModel::where('cabinet_code', $cabinet_code)->find();
  46. if (empty($cabinet)) {
  47. json_error(1008, '找不到柜子');
  48. }
  49. $cabinet_number = $cabinet['id'];
  50. $code = $this->createRandCode();
  51. $ret = $this->CreateOrder($order_sn, $trunk, $cabinet_number, $code);
  52. if ($ret['code'] != 1) {
  53. json_error(1006);
  54. }
  55. return $this->report($order_sn, $cabinet_number,$cabinet['alias'], $trunk, $code);
  56. }
  57. private function report($order_sn,$cabinet_number,$alias,$trunk, $code)
  58. {
  59. $url = self::base_url . '/deliver';
  60. $msg = "{$alias}柜门{$trunk}箱门,取件码{$code}";
  61. $postData['orderCode'] = $order_sn;
  62. $postData['boxMsg'] = $msg;
  63. $postData = json_encode($postData);
  64. Log::record("report msg:{$msg}");
  65. $max_times = 5;
  66. for ($i=0; $i < $max_times ; $i++) {
  67. $result = http_post_json($url, $postData);
  68. if($result != false) {
  69. break;
  70. }
  71. else {
  72. Log::record("repost Error:{$i} : {$result}");
  73. }
  74. }
  75. if ($result == false) {
  76. Log::record('RecordStore Error:' . $result);
  77. $msg = "商网连接错误,错误信息:{$result}";
  78. $this->CreateMsg($cabinet_number, $trunk, $msg, $order_sn, 4);
  79. json_error(3000);
  80. }
  81. else
  82. {
  83. Log::record("RecordStore Success result:{$result}");
  84. $result = json_decode($result,true);
  85. if($result['code'] != 0){
  86. $msg = "错误码:{$result['code']},错误信息:{$result['message']}";
  87. $this->CreateMsg($cabinet_number,$trunk,$msg,$order_sn,4);
  88. json_return($result['code'] , [] , $result['message']);
  89. }
  90. else {
  91. $this->box_action_record($cabinet_number , $trunk , 1 , $order_sn , $alias);
  92. $this->CreateMsg($cabinet_number,$trunk,$msg,$order_sn,1);
  93. json_success([]);
  94. }
  95. }
  96. }
  97. public function CheckFcode(){
  98. $code = input('param.code');
  99. // $cabinet_code = input('param.cabinet');
  100. $BoxModel = new BoxModel();
  101. $box = $BoxModel->CheckCode($code);
  102. if(empty($box)){
  103. json_error(2003);
  104. }
  105. //返回access
  106. $data['code'] = $code;
  107. $data['existed'] = true;
  108. $data['trunk'] = $box['box_number'];
  109. $cabinet = CabinetModel::where('id',$box['cabinet_number'])->find();
  110. $data['cabinet'] = $cabinet['cabinet_code'];
  111. json_success($data);
  112. }
  113. public function RecordFetch(){
  114. $trunk = input('param.trunk');
  115. $cabinet_code = input('param.cabinet');
  116. $cabinet = CabinetModel::where('cabinet_code',$cabinet_code)->find();
  117. $cabinet_number = $cabinet['id'];
  118. $BoxModel = new BoxModel();
  119. $Box = $BoxModel->getOneCabinetBox($cabinet_number , $trunk);
  120. if(empty($Box)){
  121. json_error(2004);
  122. }
  123. $ret = $BoxModel->editData(['cabinet_number' => $cabinet_number , 'box_number' => $trunk] ,
  124. ['order_sn' => '' , 'box_status' => 1, 'fetch_code' => '']);
  125. if($ret['code'] != 1){
  126. json_error(1006);
  127. }
  128. $OrderModel = new OrderModel();
  129. $OrderModel->editData(['order_sn' => $Box['order_sn']] , ['order_status' => 2 , 'out_time' => date("Y-m-d H:i:s")]);
  130. $order_sn = $Box['order_sn'];
  131. $postData['orderCode'] = $order_sn;
  132. $postData = json_encode($postData);
  133. $result = http_post_json(self::base_url . '/receive' , $postData);
  134. if($result == false){
  135. Log::record('RecordFetch Error:'.$result);
  136. json_error(3000);
  137. }
  138. Log::record('RecordFetch Success:');
  139. Log::record($result);
  140. $result = json_decode($result,true);
  141. if($result['code'] != 0){
  142. json_return($result['code'] , [] , $result['message']);
  143. }
  144. // 存消息
  145. $msg = "{$cabinet['alias']}柜门{$trunk}箱门";
  146. $this->CreateMsg($cabinet_number,$trunk,$msg,$order_sn,2);
  147. $this->box_action_record($cabinet_number , $trunk , 2 , $order_sn ,$cabinet['alias']);
  148. json_success([]);
  149. }
  150. public function ManualSave(){
  151. $order_sn = input('param.order_sn');
  152. $box_number = input('param.box_number');
  153. $cabinet_number = input('param.cabinet_number');
  154. $BoxModel = new BoxModel();
  155. $box = $BoxModel->where(['cabinet_number' => $cabinet_number , 'box_number' => $box_number , 'order_sn' => $order_sn])->find();
  156. if(empty($box)){
  157. json_error(2004);
  158. }
  159. $cabinet = CabinetModel::where('id',$cabinet_number)->find();
  160. $ret = $BoxModel->editData(['cabinet_number' => $cabinet_number , 'box_number' => $box_number] ,
  161. ['order_sn' => '' , 'box_status' => 1, 'fetch_code' => '']);
  162. if($ret['code'] != 1){
  163. json_error(1006);
  164. }
  165. $OrderModel = new OrderModel();
  166. $OrderModel->editData(['order_sn' => $order_sn] , ['order_status' => 2 , 'out_time' => date("Y-m-d H:i:s")]);
  167. $postData['orderCode'] = $order_sn;
  168. $postData = json_encode($postData);
  169. $result = http_post_json(self::base_url . '/receive' , $postData);
  170. if($result == false){
  171. Log::record('ManualSave Error:'.$result);
  172. json_error(3000);
  173. }
  174. Log::record('ManualSave Success:');
  175. Log::record($result);
  176. $result = json_decode($result,true);
  177. if($result['code'] != 0){
  178. json_return($result['code'] , [] , $result['message']);
  179. }
  180. // 存消息
  181. $msg = "{$cabinet['alias']}柜门{$box_number}箱门";
  182. $this->CreateMsg($cabinet_number,$box_number,$msg,$order_sn,2);
  183. $this->box_action_record($cabinet_number , $box_number , 2 , $order_sn ,$cabinet['alias']);
  184. json_success([]);
  185. }
  186. public function OrderList(){
  187. $param = input('param.');
  188. $limit = isset($param['pageSize']) ? $param['pageSize'] : 10;
  189. $param['pageNumber'] = isset($param['pageNumber']) ? $param['pageNumber'] : 1;
  190. $offset = ($param['pageNumber'] - 1) * $limit;
  191. $where = $TimeWhere = [];
  192. if(!empty($param['order_sn'])){
  193. $where['sc_order.order_sn'] = $param['order_sn'];
  194. }
  195. if(!empty($param['start_time']) && !empty($param['end_time'])){
  196. if($param['start_time'] > $param['end_time'] || strtotime($param['end_time']) > time()){
  197. json_error(1007,'日期有误');
  198. }
  199. $start_time = $param['start_time'];
  200. $end_time = $param['end_time'];
  201. $TimeWhere[] = ['enter_time','between',"$start_time,$end_time"];
  202. }
  203. $OrderModel = new OrderModel();
  204. $selectResult = $OrderModel->getOrdersByWhere($where,$offset, $limit,$TimeWhere);
  205. $order_status = ['1' => '已存入' , '2' => '已取走'];
  206. $CabinetModel = new CabinetModel();
  207. // 拼装参数
  208. foreach($selectResult as $key=>$vo){
  209. $selectResult[$key]['order_status'] = $order_status[$vo['order_status']];
  210. $selectResult[$key]['enter_time'] = date("m-d H:i",strtotime($vo['enter_time']));
  211. if($vo['out_time'] == null){
  212. $selectResult[$key]['out_time'] = '';
  213. }else{
  214. $selectResult[$key]['out_time'] = date("m-d H:i",strtotime($vo['out_time']));
  215. }
  216. $cabinet = $CabinetModel->find($vo['cabinet_number']);
  217. $selectResult[$key]['alias'] = $cabinet['alias'];
  218. }
  219. $return['total'] = $OrderModel->getAllCounts($where,$TimeWhere); //总数量
  220. $return['rows'] = $selectResult;
  221. json_success($return);
  222. }
  223. public function SendMsg(){
  224. $order_sn = input('param.order_sn');
  225. $box_number = input('param.box_number');
  226. $cabinet_number = input('param.cabinet_number');
  227. $box = BoxModel::where(['cabinet_number' => $cabinet_number , 'box_number' => $box_number , 'order_sn' => $order_sn])->find();
  228. if(empty($box)){
  229. json_error(2002);
  230. }
  231. $cabinet = CabinetModel::find($cabinet_number);
  232. $alias = $cabinet['alias'];
  233. $code = $box['fetch_code'];
  234. return $this->report($order_sn,$cabinet_number,$alias,$box_number,$code);
  235. }
  236. private function hasBox($cabinet_number , $box_number)
  237. {
  238. $BoxModel = new BoxModel();
  239. return $BoxModel->getOneCabinetBox($cabinet_number , $box_number);
  240. }
  241. private function CreateMsg($cabinet_number , $box_number , $msg , $order_sn , $type){
  242. $MsgModel = new MsgModel();
  243. $params['cabinet_number'] = $cabinet_number;
  244. $params['box_number'] = $box_number;
  245. $params['order_sn'] = $order_sn;
  246. $params['msg'] = $msg;
  247. $params['type'] = $type;
  248. $params['datetime'] = date("Y-m-d H:i:s");
  249. $MsgModel->save($params);
  250. }
  251. /**
  252. * 生成订单并绑定箱子
  253. */
  254. private function CreateOrder($order_sn , $box_number , $cabinet, $code)
  255. {
  256. $data['order_sn'] = $order_sn;
  257. $data['cabinet_number'] = $cabinet;
  258. $data['box_number'] = $box_number;
  259. $data['code'] = $code;
  260. $data['enter_time'] = date("Y-m-d H:i:s");
  261. $OrderModel = new OrderModel();
  262. return $OrderModel->CreateOrder($data);
  263. }
  264. /**
  265. * 记录箱子开启/关闭
  266. */
  267. private function box_action_record($cabinet_number , $box_number , $type , $order_sn , $cabinet_alias){
  268. $BoxActionModel = new BoxActionModel();
  269. $params['cabinet_number'] = $cabinet_number;
  270. $params['box_number'] = $box_number;
  271. $params['order_sn'] = $order_sn;
  272. $params['cabinet_alias'] = $cabinet_alias;
  273. $params['type'] = $type;
  274. $params['datetime'] = date("Y-m-d H:i:s");
  275. $BoxActionModel->save($params);
  276. }
  277. /**
  278. * 生成校验码
  279. */
  280. private function createRandCode()
  281. {
  282. while (true)
  283. {
  284. $code = rand(100000,999999);
  285. $BoxModel = new BoxModel();
  286. $box = $BoxModel->where('fetch_code',$code)->find();
  287. if(empty($box)){
  288. return $code;
  289. }
  290. }
  291. }
  292. }