Order.php 12 KB

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