gogs 1 年之前
父节点
当前提交
65f1919b1f
共有 1 个文件被更改,包括 218 次插入38 次删除
  1. 218 38
      app/Http/Controllers/Api/DwyController.php

+ 218 - 38
app/Http/Controllers/Api/DwyController.php

@@ -7,40 +7,173 @@ use App\Service\EmployeeService;
 use App\Service\SysMenuService;
 use Illuminate\Http\Request;
 use Illuminate\Support\Facades\Redis;
-
+use Illuminate\Support\Str;
 
 class DwyController extends BaseController
 {
-    public function openCommand(Request $request){
+
+
+    public function advertisement()
+    {
+
+        return ['status' => 200, 'data' => [
+            'video' => ['https://clouddevice.qingyaokeji.com/1.mp4',
+                'https://clouddevice.qingyaokeji.com/2.mp4'],
+            'img' => [
+                'https://clouddevice.qingyaokeji.com/3.jpeg',
+                'https://clouddevice.qingyaokeji.com/3.jpeg',
+            ],
+            'limit_time' => 10
+        ]];
+    }
+
+    public function openCommand(Request $request)
+    {
         $data = $request->all();
+        file_put_contents('dwy1.txt', json_encode($data) . PHP_EOL, 8);
         $device_id = $data['device_code'];
         $box_code = $data['box_code'];
-        $key = $device_id.'_'.$box_code;
+        $key = $data['type'];
+        if ($key === 'UP') {
+            $num = Redis::get($device_id . 'status_num');
+            if (empty($num)) $num = 0;
+            $num++;
+
+            if ($num === 1) {
+                Redis::set($device_id . 'status_num', $num);
+                Redis::expire($device_id . 'status_num', 300);
+
+                Redis::set($device_id . 'status', 201);
+                Redis::expire($device_id . 'status', 300);
 
-        Redis::set($key,1);
+                Redis::set($device_id, json_encode([$box_code]));
+                Redis::expire($device_id, 300);
+            } else {
+
+                $old = Redis::get($device_id);
+                if (empty($old)) $old = [];
+                else $old = json_decode($old, true);
+                $data = array_merge($old, [$box_code]);
+                Redis::set($device_id, json_encode($data));
+                Redis::expire($device_id, 300);
+
+                Redis::del($device_id . 'status');
+                Redis::del($device_id . 'status_num');
+            }
+
+        } else {
+            Redis::set($device_id, json_encode([$box_code]));
+            Redis::expire($device_id, 300);
+        }
+
+        return ['status' => 200];
 
-        return ['status'=>200];
 
     }
 
+    public function openDoor(Request $request)
+    {
+        $data = $request->all();
+        file_put_contents('dwy1.txt', json_encode($data) . PHP_EOL, 8);
+        $data = $data['device_code'];
+        $code = Redis::get($data);
+        Redis::del($data);
+//        return ['data'=>['CK00001','CK00018'],'status'=>200];
+        if (empty($code)) return ['data' => [], 'status' => 201];
+
+        $status = Redis::get($data . 'status');
+        if (empty($status)) $status = 200;
+        return ['data' => json_decode($code, true), 'status' => $status];
+    }
+
+
+    public function getOpenCommand(Request $request)
+    {
 
-    public function getOpenCommand(Request $request){
         $data = $request->all();
+        file_put_contents('dwy1.txt', json_encode($data) . PHP_EOL, 8);
         $device_id = $data['device_code'];
-        $box_code = explode(',',$data['box_code']);
-        $key = $device_id.'_'.$box_code[0];
+        $box_code = $data['box_code'];
+        $key = $device_id . '_' . $box_code;
         $return = 201;
         $status = Redis::get($key);
-        if($status) {
+        if ($status) {
             $return = 200;
             Redis::del($key);
         }
 
-        return ['status'=>$return];
+        return ['status' => $return];
+    }
+
+    public function boxList(Request $request)
+    {
+        $param = $request->all();
+        $token = $param['token'];
+        $device_code = $param['device_code'];
+
+        //商标仓列表
+        $url = 'https://tm.dwycloud.com/jbl/api/module-data/device/device/diy/device_code';
+        $header = [
+            'Content-Type:application/json',
+            'Authorization: ' . $token,
+        ];
+        $box_data = $this->post_helper($url, '{"device_code":"' . $device_code . '"}', $header);
+        $box_data = json_decode($box_data, true);
+        if (isset($box_data['status']) && $box_data['status'] === 'success') {
+            //库存查询
+            $url = 'https://tm.dwycloud.com/jbl/api/module-data/brand_in_stock/brand_in_stock/diy/box_inventory';
+            $stock_data = $this->post_helper($url, '{"device_code":"' . $device_code . '"}', $header);
+            $stock_data = json_decode($stock_data, true);
+            if ($stock_data) {
+                $list = [];
+                $material_list = [];
+                foreach ($box_data['data'] as $v) {
+                    $list[$v['box_code']] = [
+                        'material_code' => $v['material_code'],
+                        'material_code_show' => $v['material_code_show'],
+                        'box_code' => $v['box_code'],
+                        'box_code_show' => $v['box_code_show'],
+                        'min_stock_qty' => $v['min_stock_qty'] ?? 0,
+                        'safe_stock_qty' => $v['safe_stock_qty'] ?? 0,
+                        'status' => 1, //0设备仓中没有对应库存,1有对应库存,2对应商标仓中还有数量不允许上标
+                        'qty' => 0,
+                    ];
+                    $material_list[$v['material_code']][] = $v['box_code'];
+                }
+
+                $return = [];
+                foreach ($stock_data as $v) {
+                    if (isset($material_list[$v['material_code']]) && $v['box_code'] == 'CK00001' && $v['qty'] > 0) {
+                        foreach ($material_list[$v['material_code']] as $vv) {
+                            $list[$vv]['status'] = 1;
+                        }
+                    }
+                    if (isset($list[$v['box_code']]) && $v['qty'] > 0) {
+                        $list[$v['box_code']]['qty'] = $v['qty'];
+                    }
+                }
+                foreach ($list as $v) {
+                    if ($v['qty'] > 0) {
+                        $v['status'] = 2;
+                    }
+                    $return[] = $v;
+                }
+                return ['status' => 'success', 'data' => $return];
+            }
+
+        }
+
+        return $box_data;
+
+
     }
 
-    public function setLb(Request $request){
+
+    public function setLb(Request $request)
+    {
+
         $param = $request->all();
+        file_put_contents('dwy.txt', json_encode($param) . PHP_EOL, 8);
 //        $param = [
 //            'token'=>'Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiIyNzM2OTUyNTA3NTI5NTQzNzMiLCJhdXRoIjoiUk9MRV9JTk5FUl9VU0VSLFJPTEVfQlJBTkRfQVJSRVNULFJPTEVfQURNSU4iLCJ0b2tlbklkIjoiOTUwIiwiZXhwIjoxNzA3OTcxMTcxfQ.2VQ9Wqmk4rvKAcTsQPw59llBbeXjalKDGIZA4kesnuOJ0POmPVOVlRLbTtUDxl0XiFdPDUrKzuEFl2DXSgQdJg',
 //            'list'=>[
@@ -56,62 +189,109 @@ class DwyController extends BaseController
 //        dd(json_encode($param));
         $token = $param['token'];
         $list = $param['list'];
-        $url = 'http://121.36.131.68:7774/jbl/api/module-data/brand_in_stock/brand_in_stock/diy/box_inventory';
+        $url = 'https://tm.dwycloud.com/jbl/api/module-data/brand_in_stock/brand_in_stock/diy/box_inventory';
         $header = [
             'Content-Type:application/json',
-            'Authorization:'.$token,
+            'Authorization: ' . $token,
         ];
-        $data = $this->post_helper($url,'{"device_code":"DV00001"}',$header);
-//        var_dump($data);
-        $data = json_decode($data,true);
-        $a = 4;
-        foreach ($data as $k=>&$v){
-            if($v['box_code_show'] == '设备仓') {
+        $data = $this->post_helper($url, '{"device_code":"DV00001"}', $header);
+        $data = json_decode($data, true);
+        foreach ($data as $k => &$v) {
+
+            if (!isset($v['product_list'])) $v['product_list'] = [];
+            if (!isset($v['box_code_show']) || $v['box_code_show'] == '设备仓') {
                 unset($data[$k]);
                 continue;
             }
-            if($v['qty'] <= 0) {
+            $v['use_qty'] = $v['qty'];
+            if ($v['qty'] <= 0) {
                 unset($data[$k]);
                 continue;
             }
-            if(!isset($v['send_qty'])) $v['send_qty'] = 0;
-            foreach ($list as $kk=>$vv ){
-                if($vv['num'] == 0) continue;
-                if($v['material_code_show'] === $vv['title']){
-
-                    if(($v['qty']-$v['send_qty'])>$vv['num']) {
+//            $key_list = [];
+            if (!isset($v['send_qty'])) $v['send_qty'] = 0;
+            foreach ($list as $kk => $vv) {
+                if ($vv['num'] == 0) continue;
+                if ($v['material_code_show'] === $vv['title']) {
+                    $v['restore_qty'] = isset($vv['restock_qty']) && $vv['restock_qty'] > 0 ? $vv['restock_qty'] : 0;
+                    if (($v['qty'] - $v['send_qty']) > $vv['num']) {
                         $list[$kk]['num'] -= $vv['num'];
                         $v['send_qty'] += $vv['num'];
-                    } else{
-                        $list[$kk]['num'] -= ($v['qty']-$v['send_qty']);
-                        $v['send_qty'] += ($v['qty']-$v['send_qty']);
+                    } else {
+                        $list[$kk]['num'] -= ($v['qty'] - $v['send_qty']);
+                        $v['send_qty'] += ($v['qty'] - $v['send_qty']);
                     }
+
+                    //把产品相关参数进行封装
+                    $key_arr = [
+                        'product_code' => $vv['product_code'] ?? '',
+                        'product_code_show' => $vv['product_code_show'] ?? '',
+                        'order_item_id' => $vv['order_item_id'] ?? '',
+                        'order_item_id_show' => $vv['order_item_id_show'] ?? '',
+                        'send_qty' => $vv['num'],
+                        'restock_qty' => $vv['restock_qty'] ?? 0,
+                    ];
+                    $v['product_list'][] = $key_arr;
                 }
-            }
 
-            //测试用
-            if($v['box_code'] == 'CK00012'){
-                $v['send_qty'] = $a;
+
             }
-            $a++;
         }
         sort($data);
-        return ['status'=>200,'data'=>$data];
+        return ['status' => 200, 'data' => $data];
     }
 
-    public function post_helper($url, $data,$header){
+    public function zjlb(Request $request)
+    {
+
+        $param = $request->all();
+        file_put_contents('dwy1.txt', json_encode($param) . PHP_EOL, 8);
+//        $param = [
+//            'token'=>'Bearer eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiIyNzM2OTUyNTA3NTI5NTQzNzMiLCJhdXRoIjoiUk9MRV9JTk5FUl9VU0VSLFJPTEVfQlJBTkRfQVJSRVNULFJPTEVfQURNSU4iLCJ0b2tlbklkIjoiOTUwIiwiZXhwIjoxNzA3OTcxMTcxfQ.2VQ9Wqmk4rvKAcTsQPw59llBbeXjalKDGIZA4kesnuOJ0POmPVOVlRLbTtUDxl0XiFdPDUrKzuEFl2DXSgQdJg',
+//            'list'=>[
+//                [
+//                    'title'=>'优选A7家具板ENF小标',
+//                    'num'=>'20',
+//                ],[
+//                    'title'=>'植萃除醛圆标',
+//                    'num'=>'10',
+//                ],
+//            ],
+//        ];
+//        dd(json_encode($param));
+        $url = 'https://tm.dwycloud.com/jbl/api/module-data/brand_in_stock/brand_in_stock/diy/box_inventory';
+        $header = [
+            'Content-Type:application/json',
+            'Authorization: ' . $request->header('Authorization'),
+        ];
+        $data = $this->post_helper($url, json_encode($param), $header);
+        $data = json_decode($data, true);
+        foreach ($data as $k => $v) {
+            if($v['box_code'] !== 'CK00001') unset($data[$k]);
+            if($v['qty'] == 0) unset($data[$k]);
+        }
+        sort($data);
+        return json_encode($data);
+    }
+
+    public function post_helper($url, $data, $header)
+    {
         $ch = curl_init();
 
         curl_setopt($ch, CURLOPT_POST, 1);
         curl_setopt($ch, CURLOPT_URL, $url);
         curl_setopt($ch, CURLOPT_HTTPHEADER, $header);
-        curl_setopt($ch,  CURLOPT_RETURNTRANSFER, true);
+        curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
         curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
         curl_setopt($ch, CURLOPT_TIMEOUT, 30);
-        if(!is_null($data)) curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
+        if (!is_null($data)) curl_setopt($ch, CURLOPT_POSTFIELDS, $data);
         $r = curl_exec($ch);
         curl_close($ch);
         return $r;
 
     }
+
+
+
+
 }