|
@@ -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;
|
|
|
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
}
|