localizer
lzq 2025-09-13 18:18:06 +08:00
parent 41337d5db1
commit f50e9c4c5f
47 changed files with 1707 additions and 275 deletions

View File

@ -74,6 +74,7 @@ public class Mqtt implements BeanPostProcessor {
String jsonStr = null;
try {
jsonStr = Jackson.toJsonStr(msg);
log.info("mqtt 发布消息:{} {} {}", topic, qos, jsonStr);
MqttMessage message = new MqttMessage(jsonStr.getBytes());
message.setQos(qos);
client.publish(topic, message);

View File

@ -0,0 +1,40 @@
package com.njzscloud.common.mqtt.util;
import cn.hutool.extra.spring.SpringUtil;
import com.njzscloud.common.mqtt.support.Mqtt;
import com.njzscloud.common.mqtt.support.MqttMsg;
import java.util.function.Consumer;
public final class MqttUtil {
private static final Mqtt mqtt;
static {
mqtt = SpringUtil.getBean(Mqtt.class);
}
public static void subscribe(String topic, int qos, Consumer<MqttMsg> handler) {
mqtt.subscribe(topic, qos, handler);
}
public static void subscribe(String topic, Consumer<MqttMsg> handler) {
mqtt.subscribe(topic, handler);
}
public static void subscribe(String topic, int qos) {
mqtt.subscribe(topic, qos);
}
public static void subscribe(String topic) {
mqtt.subscribe(topic);
}
public static void publish(String topic, Object msg) {
mqtt.publish(topic, msg);
}
public static void publish(String topic, int qos, Object msg) {
mqtt.publish(topic, qos, msg);
}
}

View File

@ -1,16 +1,13 @@
package com.njzscloud.supervisory.biz.pojo.entity;
import com.baomidou.mybatisplus.annotation.*;
import com.njzscloud.common.mp.support.handler.j.JsonTypeHandler;
import com.njzscloud.supervisory.biz.contant.AuditStatus;
import com.njzscloud.supervisory.biz.contant.BizObj;
import lombok.Getter;
import lombok.Setter;
import lombok.experimental.Accessors;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.List;
/**
*
@ -28,50 +25,39 @@ public class BizCompanyEntity {
private Long id;
/**
* Id; sys_user.id
*
*/
private Long userId;
/**
* ; biz_obj
*/
private BizObj bizObj;
/**
*
* ; 0-->1-->
*/
private Boolean station;
/**
* ; biz_company.uscc
*
*/
private String uscc;
/**
*
*
*/
private String companyName;
/**
* ;
*
*/
private String businessLicense;
/**
* ;
*/
private String certification;
/**
* ; []
*
*/
private LocalDate licenseStartTime;
private LocalDate licenseEndTime;
/**
* ; []
*
*/
@TableField(value = "certification_date", typeHandler = JsonTypeHandler.class)
private List<String> certificationDate;
private LocalDate licenseEndTime;
/**
*
@ -79,24 +65,44 @@ public class BizCompanyEntity {
private String legalRepresentative;
/**
* ;
* ;
*/
private String province;
/**
* ;
* ;
*/
private String city;
/**
* ;
* ;
*/
private String county;
private String area;
/**
* ;
* ;
*/
private String street;
private String town;
/**
* ;
*/
private String provinceName;
/**
* ;
*/
private String cityName;
/**
* ;
*/
private String areaName;
/**
* ;
*/
private String townName;
/**
*
@ -112,6 +118,7 @@ public class BizCompanyEntity {
*
*/
private Double lat;
/**
*
*/
@ -121,16 +128,15 @@ public class BizCompanyEntity {
*
*/
private String phone;
/**
* ; audit_status
*
*/
private AuditStatus auditStatus;
/**
*
*/
private String auditMemo;
/**
* Id; sys_user.id
*/

View File

@ -1,13 +1,12 @@
package com.njzscloud.supervisory.biz.pojo.param;
import com.njzscloud.supervisory.biz.contant.BizObj;
import com.njzscloud.supervisory.biz.contant.AuditStatus;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
import java.time.LocalDate;
import java.util.List;
/**
*
@ -19,45 +18,39 @@ import java.util.List;
public class AddBizCompanyParam {
/**
* Id; sys_user.id
*
*/
private Long userId;
/**
* ; biz_obj
* ; 0-->1-->
*/
private BizObj bizObj;
private Boolean station;
/**
*
*/
private String companyName;
/**
* ; biz_company.uscc
*
*/
private String uscc;
/**
* ;
*
*/
private String companyName;
/**
*
*/
private String businessLicense;
/**
* ;
*/
private String certification;
/**
* ; []
*
*/
private LocalDate licenseStartTime;
private LocalDate licenseEndTime;
/**
* ; []
*
*/
private List<String> certificationDate;
private LocalDate licenseEndTime;
/**
*
@ -65,30 +58,60 @@ public class AddBizCompanyParam {
private String legalRepresentative;
/**
* ;
* ;
*/
private String province;
/**
* ;
* ;
*/
private String city;
/**
* ;
* ;
*/
private String county;
private String area;
/**
* ;
* ;
*/
private String street;
private String town;
/**
* ;
*/
private String provinceName;
/**
* ;
*/
private String cityName;
/**
* ;
*/
private String areaName;
/**
* ;
*/
private String townName;
/**
*
*/
private String address;
/**
*
*/
private Double lng;
/**
*
*/
private Double lat;
/**
*
*/
@ -98,4 +121,13 @@ public class AddBizCompanyParam {
*
*/
private String phone;
/**
*
*/
private AuditStatus auditStatus;
/**
*
*/
private String auditMemo;
}

View File

@ -1,14 +1,12 @@
package com.njzscloud.supervisory.biz.pojo.result;
import com.njzscloud.supervisory.biz.contant.AuditStatus;
import com.njzscloud.supervisory.biz.contant.BizObj;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
import java.time.LocalDate;
import java.util.List;
/**
*
@ -18,49 +16,42 @@ import java.util.List;
@ToString
@Accessors(chain = true)
public class SearchCompanyResult {
private Long id;
/**
* ; biz_company.uscc
*/
private String uscc;
/**
* Id; sys_user.id
*
*/
private Long userId;
/**
* ; biz_obj
* ; 0-->1-->
*/
private BizObj bizObj;
private Boolean station;
/**
*
*
*/
private String uscc;
/**
*
*/
private String companyName;
/**
* ;
*
*/
private String businessLicense;
/**
* ;
*/
private String certification;
/**
* ; []
*
*/
private LocalDate licenseStartTime;
private LocalDate licenseEndTime;
/**
* ; []
*
*/
private List<String> certificationDate;
private LocalDate licenseEndTime;
/**
*
@ -68,24 +59,44 @@ public class SearchCompanyResult {
private String legalRepresentative;
/**
* ;
* ;
*/
private String province;
/**
* ;
* ;
*/
private String city;
/**
* ;
* ;
*/
private String county;
private String area;
/**
* ;
* ;
*/
private String street;
private String town;
/**
* ;
*/
private String provinceName;
/**
* ;
*/
private String cityName;
/**
* ;
*/
private String areaName;
/**
* ;
*/
private String townName;
/**
*
@ -111,9 +122,12 @@ public class SearchCompanyResult {
*
*/
private String phone;
/**
* ; audit_status
*
*/
private AuditStatus auditStatus;
/**
*
*/
private String auditMemo;
}

View File

@ -19,6 +19,7 @@ import com.njzscloud.supervisory.biz.pojo.param.AddBizCompanyParam;
import com.njzscloud.supervisory.biz.pojo.param.ModifyBizCompanyParam;
import com.njzscloud.supervisory.biz.pojo.param.SearchCompanyParam;
import com.njzscloud.supervisory.biz.pojo.result.SearchCompanyResult;
import com.njzscloud.supervisory.config.AppProperties;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
@ -31,6 +32,8 @@ import org.springframework.transaction.annotation.Transactional;
@Service
@RequiredArgsConstructor
public class BizCompanyService extends ServiceImpl<BizCompanyMapper, BizCompanyEntity> implements IService<BizCompanyEntity> {
private final AppProperties appProperties;
/**
*
*
@ -43,8 +46,13 @@ public class BizCompanyService extends ServiceImpl<BizCompanyMapper, BizCompanyE
@Transactional(rollbackFor = Exception.class)
public void add(AddBizCompanyParam addBizCompanyParam) {
BizCompanyEntity bizCompanyEntity = BeanUtil.copyProperties(addBizCompanyParam, BizCompanyEntity.class);
bizCompanyEntity.setAuditStatus(AuditStatus.DaiShenHe);
AppProperties.DefaultPlace defaultPlace = appProperties.getDefaultPlace();
BizCompanyEntity bizCompanyEntity = BeanUtil.copyProperties(addBizCompanyParam, BizCompanyEntity.class)
.setAuditStatus(AuditStatus.DaiShenHe)
.setProvince(defaultPlace.getProvince())
.setCity(defaultPlace.getCity())
.setProvinceName(defaultPlace.getProvinceName())
.setCityName(defaultPlace.getCityName());
this.save(bizCompanyEntity);
}
@ -132,7 +140,6 @@ public class BizCompanyService extends ServiceImpl<BizCompanyMapper, BizCompanyE
String companyName = searchCompanyParam.getCompanyName();
String legalRepresentative = searchCompanyParam.getLegalRepresentative();
return PageResult.of(this.page(pageParam.toPage(), Wrappers.<BizCompanyEntity>lambdaQuery()
.eq(bizObj != null, BizCompanyEntity::getBizObj, bizObj)
.eq(auditStatus != null, BizCompanyEntity::getAuditStatus, auditStatus)
.like(StrUtil.isNotBlank(companyName), BizCompanyEntity::getCompanyName, companyName)
.like(StrUtil.isNotBlank(legalRepresentative), BizCompanyEntity::getLegalRepresentative, legalRepresentative)

View File

@ -1,15 +1,19 @@
package com.njzscloud.supervisory.device.controller;
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson2.JSONObject;
import com.njzscloud.common.core.utils.R;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.supervisory.device.pojo.entity.DeviceInfoEntity;
import com.njzscloud.supervisory.device.service.DeviceInfoService;
import com.njzscloud.supervisory.order.pojo.param.DeviceRecognitionParam;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.bind.annotation.*;
import java.util.List;
import java.util.Map;
/**
*
@ -78,4 +82,59 @@ public class DeviceInfoController {
return R.success(deviceInfoService.paging(pageParam, deviceInfoEntity));
}
/**
*
*/
@PostMapping("/recognition")
public R<?> recognition(@RequestBody JSONObject param) {
JSONObject alarmInfoPlate = param.getJSONObject("AlarmInfoPlate");
if (alarmInfoPlate == null) {
alarmInfoPlate = param.getJSONObject("alarmInfoPlate");
}
if (alarmInfoPlate == null) {
return R.failed();
}
String serialno = alarmInfoPlate.getString("serialno");
JSONObject result = alarmInfoPlate.getJSONObject("result");
if (result == null) {
result = alarmInfoPlate.getJSONObject("Result");
}
if (result == null) {
return R.failed();
}
JSONObject plateResult = result.getJSONObject("PlateResult");
if (plateResult == null) {
plateResult = result.getJSONObject("plateResult");
}
if (plateResult == null) {
return R.failed();
}
String imageFile = plateResult.getString("imageFile");
String license = plateResult.getString("license");
if (StrUtil.isBlank(serialno) || StrUtil.isBlank(imageFile) || StrUtil.isBlank(license) || license.contains("无")) {
return R.failed();
}
deviceInfoService.recognition(new DeviceRecognitionParam().setSn(serialno).setImg(imageFile).setLicensePlate(license));
return R.success();
}
/**
* 1
*/
@PostMapping("/report1")
public Map<String, Object> report1(@RequestBody JSONObject data) {
return deviceInfoService.report1(data);
}
/**
* 2
*/
@PostMapping("/report2")
public Map<String, Object> report2(@RequestBody JSONObject data) {
return deviceInfoService.report2(data);
}
}

View File

@ -0,0 +1,18 @@
package com.njzscloud.supervisory.device.drive.barrier;
import lombok.Getter;
public abstract class Barrier {
@Getter
protected String sn;
public Barrier(String sn) {
this.sn = sn;
}
public abstract void open();
public abstract void close();
public abstract void auto();
}

View File

@ -0,0 +1,78 @@
package com.njzscloud.supervisory.device.drive.barrier.generic;
import cn.hutool.core.util.StrUtil;
import com.njzscloud.common.mqtt.support.MqttMsg;
import com.njzscloud.common.mqtt.util.MqttUtil;
import com.njzscloud.supervisory.device.drive.barrier.Barrier;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
@Slf4j
public class GenericBarrier extends Barrier {
private static final String SUBSCRIBE_TOPIC = "device/{}/message/up/{}";
private static final String PUBLISH_TOPIC = "device/{}/message/down/{}";
private static final String REPLY_TOPIC = "device/{}/message/down/{}/reply";
private final GenericBarrierConfig config;
public GenericBarrier(GenericBarrierConfig config) {
super(config.getSn());
this.config = config;
// MqttUtil.subscribe(topic(Fn.gpio_out_reply), this::openReply);
}
@Override
public void open() {
IoParam ioParam = IoParam.defaultParam().setSn(getSn());
ioParam
.getPayload()
.getBody()
.setIo(config.getIo())
.setValue(1);
MqttUtil.publish(topic(Fn.gpio_out), ioParam);
}
private void openReply(MqttMsg msg) {
IoResult ioResult = msg.getMsg(IoResult.class);
log.info("道闸开门结果:{}、{}、{}、{}", config.getName(), config.getSn(), config.getCode().getTxt(), ioResult);
}
@Override
public void close() {
IoParam ioParam = IoParam.defaultParam().setSn(getSn());
ioParam
.getPayload()
.getBody()
.setIo(config.getIo())
.setValue(0);
MqttUtil.publish(topic(Fn.gpio_out), ioParam);
}
@Override
public void auto() {
IoParam ioParam = IoParam.defaultParam().setSn(getSn());
ioParam
.getPayload()
.getBody()
.setIo(config.getIo())
.setValue(2);
MqttUtil.publish(topic(Fn.gpio_out), ioParam);
}
private String topic(Fn fn) {
return fn.topic(getSn());
}
@RequiredArgsConstructor
public enum Fn {
gpio_out(PUBLISH_TOPIC, "gpio_out"),
gpio_out_reply(REPLY_TOPIC, "gpio_out"),
;
private final String tpl;
private final String name;
public String topic(String sn) {
return StrUtil.format(tpl, sn, name);
}
}
}

View File

@ -0,0 +1,22 @@
package com.njzscloud.supervisory.device.drive.barrier.generic;
import com.njzscloud.supervisory.device.contant.DeviceCode;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class GenericBarrierConfig {
private String name;
private String sn;
private DeviceCode code;
private String ip;
private Integer io;
private String loadometer;
private String vidicon;
private String voicebox;
}

View File

@ -0,0 +1,90 @@
package com.njzscloud.supervisory.device.drive.barrier.generic;
import cn.hutool.core.util.IdUtil;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class IoParam {
/**
* ID
*/
private String id;
/**
*
*/
private String sn;
/**
*
*/
private String name;
/**
* 1.0
*/
private String version;
/**
*
*/
private Integer timestamp;
private Payload payload;
public static IoParam defaultParam() {
return new IoParam()
.setId(IdUtil.fastSimpleUUID())
.setName("gpio_out")
.setVersion("1.0")
.setTimestamp((int) (System.currentTimeMillis() / 1000))
.setPayload(new Payload()
.setType("gpio_out")
.setBody(new Body()
.setDelay(500)
.setIo(0)
.setValue(2)
)
)
;
}
@Getter
@Setter
@ToString
@Accessors(chain = true)
public static class Body {
/**
* ms
* [500,5000]
*/
private Integer delay;
/**
* IO
* [0,3]
*/
private Integer io;
/**
* IO 0 , 1 ,2
* [0,2]
*/
private Integer value;
}
@Getter
@Setter
@ToString
@Accessors(chain = true)
public static class Payload {
/**
*
*/
private String type;
/**
*
*/
private Body body;
}
}

View File

@ -0,0 +1,41 @@
package com.njzscloud.supervisory.device.drive.barrier.generic;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class IoResult {
/**
* ID
*/
private String id;
/**
*
*/
private String sn;
/**
*
*/
private String name;
/**
* 200 200
*/
private Integer code;
/**
* 1.0
*/
private String version;
/**
*
*/
private Integer timestamp;
/**
*
*/
private Object payload;
}

View File

@ -0,0 +1,15 @@
package com.njzscloud.supervisory.device.drive.loadometer;
import lombok.Getter;
public abstract class Loadometer {
@Getter
protected String sn;
protected String weight;
public Loadometer(String sn) {
this.sn = sn;
}
public abstract int weight();
}

View File

@ -0,0 +1,14 @@
package com.njzscloud.supervisory.device.drive.voicebox;
import lombok.Getter;
public abstract class Voicebox {
@Getter
protected String sn;
public Voicebox(String sn) {
this.sn = sn;
}
public abstract void play(String content);
}

View File

@ -0,0 +1,19 @@
package com.njzscloud.supervisory.device.drive.voicebox.generic;
import cn.hutool.core.map.MapUtil;
import com.njzscloud.common.mqtt.util.MqttUtil;
import com.njzscloud.supervisory.device.drive.voicebox.Voicebox;
public class GenericVoicebox extends Voicebox {
public GenericVoicebox(String sn) {
super(sn);
}
@Override
public void play(String content) {
MqttUtil.publish("zsy/1/voice", MapUtil.builder()
.put("deviceNo", getSn())
.put("text", content)
.build());
}
}

View File

@ -1,24 +1,42 @@
package com.njzscloud.supervisory.device.service;
import cn.hutool.core.map.MapBuilder;
import cn.hutool.core.map.MapUtil;
import cn.hutool.core.util.StrUtil;
import com.alibaba.fastjson2.JSONObject;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.common.mqtt.util.MqttUtil;
import com.njzscloud.supervisory.device.contant.DeviceCode;
import com.njzscloud.supervisory.device.mapper.DeviceInfoMapper;
import com.njzscloud.supervisory.device.pojo.entity.DeviceInfoEntity;
import com.njzscloud.supervisory.order.contant.CheckStatus;
import com.njzscloud.supervisory.order.contant.OrderStatus;
import com.njzscloud.supervisory.order.pojo.entity.OrderInfoEntity;
import com.njzscloud.supervisory.order.pojo.param.DeviceRecognitionParam;
import com.njzscloud.supervisory.order.pojo.param.TruckComingOrderParam;
import com.njzscloud.supervisory.order.pojo.param.TruckLeavingOrderParam;
import com.njzscloud.supervisory.order.pojo.result.OrderPagingResult;
import com.njzscloud.supervisory.order.service.OrderInfoService;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
import java.util.Map;
/**
*
*/
@Slf4j
@Service
@RequiredArgsConstructor
public class DeviceInfoService extends ServiceImpl<DeviceInfoMapper, DeviceInfoEntity> implements IService<DeviceInfoEntity> {
private final OrderInfoService orderInfoService;
/**
*
@ -69,4 +87,234 @@ public class DeviceInfoService extends ServiceImpl<DeviceInfoMapper, DeviceInfoE
return PageResult.of(this.page(pageParam.toPage(), Wrappers.<DeviceInfoEntity>query(deviceInfoEntity)));
}
public void recognition(DeviceRecognitionParam deviceRecognitionParam) {
String sn = deviceRecognitionParam.getSn();
DeviceInfoEntity deviceInfoEntity = this.getOne(Wrappers.<DeviceInfoEntity>lambdaQuery().eq(DeviceInfoEntity::getSn, sn));
if (deviceInfoEntity == null) {
log.error("设备不存在:{}", deviceRecognitionParam);
return;
}
DeviceCode deviceCode = deviceInfoEntity.getDeviceCode();
switch (deviceCode) {
// TODO 进前置不启用
case JinQianZhi: {
OrderPagingResult orderInfoByLicensePlate = orderInfoService.pendingOrder(deviceRecognitionParam.getLicensePlate());
if (orderInfoByLicensePlate == null) {
// 播语音
return;
}
// 播语音
// 开门
orderInfoService.updateById(new OrderInfoEntity().setId(orderInfoByLicensePlate.getId()).setOrderStatus(OrderStatus.DaiJinChang));
}
break;
case Jin: {
OrderPagingResult orderInfoByLicensePlate = orderInfoService.pendingOrder(deviceRecognitionParam.getLicensePlate());
if (orderInfoByLicensePlate == null) {
// 播语音
return;
}
// 播语音
// 获取磅重
// 播语音
// 拍照
Integer weight = null;
String frontPhoto = null;
String bodyPhoto = null;
orderInfoService.truckComing(new TruckComingOrderParam()
.setOrderId(orderInfoByLicensePlate.getId())
.setWeight(weight)
.setFrontPhoto(frontPhoto)
.setBodyPhoto(bodyPhoto)
);
}
break;
// TODO 出前置不启用
case ChuQianZhi: {
OrderPagingResult orderInfoByLicensePlate = orderInfoService.pendingOrder(deviceRecognitionParam.getLicensePlate());
if (orderInfoByLicensePlate == null) {
// 播语音
return;
}
CheckStatus checkStatus = orderInfoByLicensePlate.getCheckStatus();
if (checkStatus == CheckStatus.WeiKanLiao) {
// 播语音
return;
}
}
break;
case Chu: {
OrderPagingResult orderInfoByLicensePlate = orderInfoService.pendingOrder(deviceRecognitionParam.getLicensePlate());
if (orderInfoByLicensePlate == null) {
// 播语音
return;
}
// 播语音
// 获取磅重
// 播语音
// 拍照
Integer weight = null;
String frontPhoto = null;
String bodyPhoto = null;
orderInfoService.truckLeaving(new TruckLeavingOrderParam()
.setOrderId(orderInfoByLicensePlate.getId())
.setWeight(weight)
.setFrontPhoto(frontPhoto)
.setBodyPhoto(bodyPhoto)
);
}
break;
default:
break;
}
}
public Map<String, Object> report1(JSONObject data) {
MapBuilder<String, Object> resBuilder = MapUtil.<String, Object>builder()
.put("code", 0)
.put("msg", "success");
MapBuilder<String, Object> dataBuilder = MapUtil.<String, Object>builder()
.put("order_no", "")
.put("type", 0);
String sn = data.getString("carDiscernCode");
String licensePlate = data.getString("carNumber");
DeviceInfoEntity deviceInfoEntity = this.getOne(Wrappers.<DeviceInfoEntity>lambdaQuery().eq(DeviceInfoEntity::getSn, sn));
if (deviceInfoEntity == null) {
log.error("设备不存在:{}", data);
return resBuilder
.put("data", dataBuilder.put("type", 0).build())
.build();
}
OrderPagingResult orderPagingResult = orderInfoService.pendingOrder(licensePlate);
if (orderPagingResult == null) {
// 播语音
playVoice(sn, "{}无订单", licensePlate);
return resBuilder
.put("data", dataBuilder.put("type", 0).build())
.build();
}
DeviceCode deviceCode = deviceInfoEntity.getDeviceCode();
OrderStatus orderStatus = orderPagingResult.getOrderStatus();
if (deviceCode == DeviceCode.JinQianZhi && orderStatus == OrderStatus.QingYunZhong) {
// 开门
open(sn);
return resBuilder
.put("data", dataBuilder.put("type", 0).build())
.build();
}
if (deviceCode == DeviceCode.Jin && orderStatus == OrderStatus.QingYunZhong) {
return resBuilder
.put("data", dataBuilder.put("type", 1)
.put("order_no", orderPagingResult.getId() + "")
.build())
.build();
}
if (deviceCode == DeviceCode.ChuQianZhi && orderStatus == OrderStatus.YiJinChang) {
// 开门
open(sn);
return resBuilder
.put("data", dataBuilder.put("type", 0).build())
.build();
}
if (deviceCode == DeviceCode.Chu && orderStatus == OrderStatus.YiJinChang) {
return resBuilder
.put("data", dataBuilder.put("type", 2)
.put("order_no", orderPagingResult.getId() + "")
.build())
.build();
}
return resBuilder
.put("data", dataBuilder.put("type", 0).build())
.build();
}
public Map<String, Object> report2(JSONObject data) {
MapBuilder<String, Object> resBuilder = MapUtil.<String, Object>builder()
.put("code", 0)
.put("msg", "success");
MapBuilder<String, Object> dataBuilder = MapUtil.<String, Object>builder()
.put("car_number", "")
.put("order_no", "")
.put("lane_code", "");
String sn = data.getString("carDiscernCode");
String licensePlate = data.getString("carNumber");
Long orderId = data.getLong("orderNo");
DeviceInfoEntity deviceInfoEntity = this.getOne(Wrappers.<DeviceInfoEntity>lambdaQuery().eq(DeviceInfoEntity::getSn, sn));
if (deviceInfoEntity == null) {
log.error("设备不存在:{}", data);
return resBuilder
.put("data", dataBuilder.build())
.build();
}
DeviceCode deviceCode = deviceInfoEntity.getDeviceCode();
OrderInfoEntity orderInfo = orderInfoService.getById(orderId);
if (orderInfo == null) {
// 播语音
playVoice(sn, "{}无订单", orderId);
return resBuilder
.put("data", dataBuilder.build())
.build();
}
Integer weight = data.getInteger("weight");
String frontPhoto = data.getString("photoFront");
String bodyPhoto = data.getString("photoBody");
if (weight == null || weight <= 200) {
// 播语音
playVoice(sn, "{}磅重异常,请重新称重", licensePlate);
return resBuilder
.put("data", dataBuilder.build())
.build();
}
if (deviceCode == DeviceCode.Jin) {
// 播语音
playVoice(sn, "{}称重完成,磅重{}吨", licensePlate, weight / 1000);
// 开门
open(sn);
orderInfoService.truckComing(new TruckComingOrderParam()
.setOrderId(orderId)
.setWeight(weight)
.setFrontPhoto(frontPhoto)
.setBodyPhoto(bodyPhoto)
);
}
if (deviceCode == DeviceCode.Chu) {
// 播语音
playVoice(sn, "{}称重完成,磅重{}吨", licensePlate, weight / 1000);
// 开门
open(sn);
orderInfoService.truckLeaving(new TruckLeavingOrderParam()
.setOrderId(orderId)
.setWeight(weight)
.setFrontPhoto(frontPhoto)
.setBodyPhoto(bodyPhoto)
);
}
return resBuilder
.put("data", dataBuilder.build())
.build();
}
private void open(String sn) {
MqttUtil.publish("zsy/1/barrier", MapUtil.builder()
.put("deviceNo", sn)
.build());
}
private void playVoice(String sn, String content, Object... params) {
MqttUtil.publish("zsy/1/voice", MapUtil.builder()
.put("deviceNo", sn)
.put("text", StrUtil.format(content, params))
.build());
}
}

View File

@ -0,0 +1,47 @@
package com.njzscloud.supervisory.gps;
import java.util.List;
/**
*
*/
public class GeoUtils {
/**
*
*
* @param point [, ]
* @param polygon [, ]
* @return truefalse
*/
public static boolean isPointInPolygon(double[] point, List<double[]> polygon) {
// 点的纬度和经度
double lat = point[0];
double lon = point[1];
boolean inside = false;
// 遍历多边形的每条边
for (int i = 0, j = polygon.size() - 1; i < polygon.size(); j = i++) {
double[] vertexI = polygon.get(i);
double[] vertexJ = polygon.get(j);
double latI = vertexI[0];
double lonI = vertexI[1];
double latJ = vertexJ[0];
double lonJ = vertexJ[1];
// 检查点是否在边的端点上
if ((lat == latI && lon == lonI) || (lat == latJ && lon == lonJ)) {
return true;
}
// 检查射线是否与当前边相交
if (((latI > lat) != (latJ > lat)) &&
(lon < (lonJ - lonI) * (lat - latI) / (latJ - latI) + lonI)) {
inside = !inside;
}
}
return inside;
}
}

View File

@ -11,7 +11,6 @@ import lombok.RequiredArgsConstructor;
@Getter
@RequiredArgsConstructor
public enum CheckStatus implements DictStr {
Wu("Wu", "无"),
YiKanLiao("YiKanLiao", "已看料"),
WeiKanLiao("WeiKanLiao", "未看料"),
;

View File

@ -14,12 +14,14 @@ public enum OrderStatus implements DictStr {
YiYuYue("YiYuYue", "已预约"),
DaiPaiDan("DaiPaiDan", "待派单"),
DaiJieDan("DaiJieDan", "待接单"),
YiJieDan("YiJieDan", "已接单"),
YiJieDan("YiJieDan", "已接单"),// 接单后要审核
QingYunZhong("QingYunZhong", "清运中"),
YiJinChang("YiJinChang", "已进场"),
DaiJinChang("DaiJinChang", "待进场"),
YiJinChang("YiJinChang", "已进场"),// 出场前要看料
DaiChuChang("DaiChuChang", "待出场"),
YiChuChang("YiChuChang", "已出场"),
YiWanCheng("YiWanCheng", "已完成"),
YiQuXiao("YiQuXiao", "已取消"),
YiWanCheng("YiWanCheng", "已完成"),// 最终态,完成前要支付
YiQuXiao("YiQuXiao", "已取消"),// 最终态,取消前要退款
;
private final String val;
private final String txt;

View File

@ -22,15 +22,6 @@ public class OrderCargoPlaceController {
private final OrderCargoPlaceService orderCargoPlaceService;
/**
*
*/
@PostMapping("/add")
public R<?> add(@RequestBody OrderCargoPlaceEntity orderCargoPlaceEntity) {
orderCargoPlaceService.add(orderCargoPlaceEntity);
return R.success();
}
/**
*
*/

View File

@ -22,15 +22,6 @@ public class OrderGoodsController {
private final OrderGoodsService orderGoodsService;
/**
*
*/
@PostMapping("/add")
public R<?> add(@RequestBody OrderGoodsEntity orderGoodsEntity) {
orderGoodsService.add(orderGoodsEntity);
return R.success();
}
/**
*
*/

View File

@ -1,10 +1,12 @@
package com.njzscloud.supervisory.order.controller;
import cn.hutool.core.lang.Assert;
import com.njzscloud.common.core.utils.R;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.common.security.support.UserDetail;
import com.njzscloud.common.security.util.SecurityUtil;
import com.njzscloud.supervisory.order.contant.OrderCategory;
import com.njzscloud.supervisory.order.pojo.entity.OrderInfoEntity;
import com.njzscloud.supervisory.order.pojo.param.*;
import com.njzscloud.supervisory.order.pojo.result.OrderPagingResult;
@ -24,15 +26,18 @@ import java.util.Set;
@RequestMapping("/order_info")
@RequiredArgsConstructor
public class OrderInfoController {
private final OrderInfoService orderInfoService;
/**
*
*/
@PostMapping("/add")
public R<?> add(@RequestBody OrderInfoEntity orderInfoEntity) {
orderInfoService.add(orderInfoEntity);
public R<?> add(@RequestBody AddOrderInfoParam addOrderInfoParam) {
OrderCategory orderCategory = addOrderInfoParam.getOrderCategory();
Assert.isTrue(orderCategory == OrderCategory.PuTong
|| orderCategory == OrderCategory.DuanBoChu
, "订单类型必须是普通订单、短驳出");
orderInfoService.add(addOrderInfoParam);
return R.success();
}
@ -45,6 +50,15 @@ public class OrderInfoController {
return R.success();
}
/**
*
*/
@PostMapping("/modify_goods")
public R<?> modifyGoods(@RequestBody ModifyOrderGoodsParam modifyOrderGoodsParam) {
orderInfoService.modifyGoods(modifyOrderGoodsParam);
return R.success();
}
/**
*
*/
@ -138,4 +152,22 @@ public class OrderInfoController {
return R.success();
}
/**
*
*/
@PostMapping("/truck_coming")
public R<?> truckComing(@RequestBody TruckComingOrderParam truckComingOrderParam) {
orderInfoService.truckComing(truckComingOrderParam);
return R.success();
}
/**
*
*/
@PostMapping("/truck_out")
public R<?> truckOut(@RequestBody TruckLeavingOrderParam truckLeavingOrderParam) {
orderInfoService.truckLeaving(truckLeavingOrderParam);
return R.success();
}
}

View File

@ -0,0 +1,11 @@
package com.njzscloud.supervisory.order.controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@RequestMapping("/device")
public class RecognitionController {
}

View File

@ -17,4 +17,6 @@ public interface OrderInfoMapper extends BaseMapper<OrderInfoEntity> {
Page<OrderPagingResult> paging(Page<OrderPagingResult> page, @Param("ew") QueryWrapper<OrderPagingResult> ew);
OrderPagingResult detail(@Param("ew") QueryWrapper<OrderPagingResult> ew);
OrderPagingResult pendingOrder(@Param("ew") QueryWrapper<Object> ew);
}

View File

@ -3,6 +3,7 @@ package com.njzscloud.supervisory.order.pojo.entity;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import com.njzscloud.supervisory.goods.contant.MoneyStrategy;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
@ -54,7 +55,7 @@ public class OrderGoodsEntity {
/**
* ; money_strategy
*/
private String moneyStrategy;
private MoneyStrategy moneyStrategy;
/**
* Id

View File

@ -72,7 +72,15 @@ public class OrderInfoEntity {
*
*/
private String auditMemo;
/**
* Id
*/
private Long targetStationId;
/**
* Id
*/
private Long targetOrderId;
/**
* ; order_category
*/
@ -165,6 +173,10 @@ public class OrderInfoEntity {
@TableField(typeHandler = JsonTypeHandler.class)
private List<String> checkPhoto;
/**
*
*/
private Long carInOutId;
/**
* Id; sys_user.id
*/

View File

@ -0,0 +1,58 @@
package com.njzscloud.supervisory.order.pojo.param;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
import javax.validation.constraints.NotBlank;
import javax.validation.constraints.NotNull;
/**
*
*/
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class AddOrderCargoPlaceParam {
/**
* ;
*/
@NotBlank(message = "未指定区县")
private String area;
/**
* ;
*/
private String town;
/**
* ;
*/
@NotBlank(message = "未指定区县名称")
private String areaName;
/**
* ;
*/
private String townName;
/**
*
*/
private String address;
/**
*
*/
@NotNull(message = "未指定经度")
private Double lng;
/**
*
*/
@NotNull(message = "未指定纬度")
private Double lat;
}

View File

@ -0,0 +1,89 @@
package com.njzscloud.supervisory.order.pojo.param;
import com.njzscloud.common.mvc.validator.Constrained;
import com.njzscloud.common.mvc.validator.Constraint;
import com.njzscloud.common.mvc.validator.ValidRule;
import com.njzscloud.supervisory.order.contant.OrderCategory;
import com.njzscloud.supervisory.order.contant.PayerCategory;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
import javax.validation.Valid;
import javax.validation.constraints.NotNull;
/**
*
*/
@Getter
@Setter
@ToString
@Accessors(chain = true)
@Constraint
public class AddOrderInfoParam implements Constrained {
/**
* Id
*/
@Valid
@NotNull(message = "未指定装货地址")
private AddOrderCargoPlaceParam cargoPlace;
/**
* Id; order_goods.id
*/
private Long goodsId;
/**
* Id
*/
private Long transCompanyId;
/**
* Id
*/
private Long stationId;
/**
* Id
*/
private Long targetStationId;
/**
* Id
*/
private Long targetOrderId;
/**
* ; order_category
*/
private OrderCategory orderCategory;
/**
* Id
*/
private Long payer;
/**
* ; payer_category
*/
private PayerCategory payerCategory;
/**
*
*/
private String customerMemo;
@Override
public ValidRule[] rules() {
return new ValidRule[]{
ValidRule.of(() -> goodsId != null && goodsId >= 0, "未指定产品"),
ValidRule.of(() -> stationId != null && stationId >= 0, "未指定站点"),
ValidRule.of(() -> orderCategory != null, "未指定订单类型"),
ValidRule.of(() -> orderCategory == OrderCategory.PuTong || orderCategory == OrderCategory.DuanBoChu, "订单类型必须是普通订单、短驳出"),
ValidRule.of(() -> {
if (orderCategory != OrderCategory.PuTong) {
return targetStationId != null && targetStationId >= 0;
} else return true;
}, "普通订单不能指定目标站点"),
};
}
}

View File

@ -0,0 +1,16 @@
package com.njzscloud.supervisory.order.pojo.param;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class DeviceRecognitionParam {
private String sn;
private String img;
private String licensePlate;
}

View File

@ -0,0 +1,31 @@
package com.njzscloud.supervisory.order.pojo.param;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
/**
*
*/
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class ModifyOrderGoodsParam {
/**
* Id
*/
private Long orderId;
/**
* Id
*/
private Long goodsCategoryId;
/**
* Id
*/
private Long originGoodsId;
}

View File

@ -0,0 +1,37 @@
package com.njzscloud.supervisory.order.pojo.param;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
/**
*
*/
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class TruckComingOrderParam {
/**
* Id
*/
private Long orderId;
/**
* ;
*/
private Integer weight;
/**
*
*/
private String frontPhoto;
/**
*
*/
private String bodyPhoto;
}

View File

@ -0,0 +1,37 @@
package com.njzscloud.supervisory.order.pojo.param;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
import lombok.experimental.Accessors;
/**
*
*/
@Getter
@Setter
@ToString
@Accessors(chain = true)
public class TruckLeavingOrderParam {
/**
* Id
*/
private Long orderId;
/**
* ;
*/
private Integer weight;
/**
*
*/
private String frontPhoto;
/**
*
*/
private String bodyPhoto;
}

View File

@ -1,6 +1,8 @@
package com.njzscloud.supervisory.order.pojo.result;
import com.njzscloud.supervisory.biz.contant.AuditStatus;
import com.njzscloud.supervisory.goods.contant.MoneyStrategy;
import com.njzscloud.supervisory.order.contant.*;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;
@ -60,7 +62,7 @@ public class OrderPagingResult {
/**
* Id
*/
private Long trafficCompanyId;
private Long transCompanyId;
/**
* Id; sys_user.id
@ -80,12 +82,12 @@ public class OrderPagingResult {
/**
* ; order_category
*/
private String orderCategory;
private OrderCategory orderCategory;
/**
* ; order_status
*/
private String orderStatus;
private OrderStatus orderStatus;
/**
* Id; sys_user.id
@ -95,7 +97,7 @@ public class OrderPagingResult {
/**
* ; check_status
*/
private String checkStatus;
private CheckStatus checkStatus;
/**
* Id
@ -135,12 +137,12 @@ public class OrderPagingResult {
/**
* ; payer_category
*/
private String payerCategory;
private PayerCategory payerCategory;
/**
* ; payment_status
*/
private String paymentStatus;
private PaymentStatus paymentStatus;
/**
*
@ -203,7 +205,7 @@ public class OrderPagingResult {
/**
* ; money_strategy
*/
private String moneyStrategy;
private MoneyStrategy moneyStrategy;
/**
* Id

View File

@ -5,12 +5,16 @@ import com.baomidou.mybatisplus.extension.service.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.supervisory.order.contant.OrderCategory;
import com.njzscloud.supervisory.order.mapper.OrderCarInOutMapper;
import com.njzscloud.supervisory.order.pojo.entity.OrderCarInOutEntity;
import com.njzscloud.supervisory.order.pojo.param.TruckComingOrderParam;
import com.njzscloud.supervisory.order.pojo.param.TruckLeavingOrderParam;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.time.LocalDateTime;
import java.util.List;
/**
@ -56,4 +60,53 @@ public class OrderCarInOutService extends ServiceImpl<OrderCarInOutMapper, Order
return PageResult.of(this.page(pageParam.toPage(), Wrappers.<OrderCarInOutEntity>query(orderCarInOutEntity)));
}
/**
*
*/
@Transactional(rollbackFor = Exception.class)
public long truckComing(TruckComingOrderParam truckComingOrderParam, OrderCategory orderCategory) {
Integer roughWeight = null;
Integer tareWeight = null;
if (orderCategory == OrderCategory.DuanBoChu) {
tareWeight = truckComingOrderParam.getWeight();
} else {
roughWeight = truckComingOrderParam.getWeight();
}
OrderCarInOutEntity entity = new OrderCarInOutEntity()
.setRoughWeight(roughWeight)
.setTareWeight(tareWeight)
.setInFrontPhoto(truckComingOrderParam.getFrontPhoto())
.setInBodyPhoto(truckComingOrderParam.getBodyPhoto())
.setInTime(LocalDateTime.now());
this.save(entity);
return entity.getId();
}
/**
*
*/
@Transactional(rollbackFor = Exception.class)
public void truckOut(Long carInOutId, TruckLeavingOrderParam truckLeavingOrderParam, OrderCategory orderCategory) {
OrderCarInOutEntity orderCarInOutEntity = this.getById(carInOutId);
Integer roughWeight = null;
Integer tareWeight = null;
Integer settleWeight = null;
if (orderCategory == OrderCategory.DuanBoChu) {
roughWeight = truckLeavingOrderParam.getWeight();
settleWeight = roughWeight - orderCarInOutEntity.getRoughWeight();
} else {
tareWeight = truckLeavingOrderParam.getWeight();
settleWeight = orderCarInOutEntity.getRoughWeight() - tareWeight;
}
this.updateById(new OrderCarInOutEntity()
.setId(carInOutId)
.setRoughWeight(roughWeight)
.setTareWeight(tareWeight)
.setOutFrontPhoto(truckLeavingOrderParam.getFrontPhoto())
.setOutBodyPhoto(truckLeavingOrderParam.getBodyPhoto())
.setSettleWeight(settleWeight)
.setOutTime(LocalDateTime.now())
);
}
}

View File

@ -1,12 +1,16 @@
package com.njzscloud.supervisory.order.service;
import cn.hutool.core.bean.BeanUtil;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.supervisory.config.AppProperties;
import com.njzscloud.supervisory.order.mapper.OrderCargoPlaceMapper;
import com.njzscloud.supervisory.order.pojo.entity.OrderCargoPlaceEntity;
import com.njzscloud.supervisory.order.pojo.param.AddOrderCargoPlaceParam;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@ -18,13 +22,25 @@ import java.util.List;
*/
@Slf4j
@Service
@RequiredArgsConstructor
public class OrderCargoPlaceService extends ServiceImpl<OrderCargoPlaceMapper, OrderCargoPlaceEntity> implements IService<OrderCargoPlaceEntity> {
private final AppProperties appProperties;
/**
*
*
* @return
*/
public void add(OrderCargoPlaceEntity orderCargoPlaceEntity) {
this.save(orderCargoPlaceEntity);
public long add(AddOrderCargoPlaceParam addOrderCargoPlaceParam) {
OrderCargoPlaceEntity orderCargoPlaceEntity = BeanUtil.copyProperties(addOrderCargoPlaceParam, OrderCargoPlaceEntity.class);
AppProperties.DefaultPlace defaultPlace = appProperties.getDefaultPlace();
this.save(orderCargoPlaceEntity
.setProvince(defaultPlace.getProvince())
.setCity(defaultPlace.getCity())
.setProvinceName(defaultPlace.getProvinceName())
.setCityName(defaultPlace.getCityName())
);
return orderCargoPlaceEntity.getId();
}
/**

View File

@ -1,12 +1,18 @@
package com.njzscloud.supervisory.order.service;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.lang.Assert;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.IService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.njzscloud.common.core.ex.Exceptions;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.supervisory.goods.pojo.entity.GoodsInfoEntity;
import com.njzscloud.supervisory.goods.service.GoodsInfoService;
import com.njzscloud.supervisory.order.mapper.OrderGoodsMapper;
import com.njzscloud.supervisory.order.pojo.entity.OrderGoodsEntity;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@ -18,13 +24,22 @@ import java.util.List;
*/
@Slf4j
@Service
@RequiredArgsConstructor
public class OrderGoodsService extends ServiceImpl<OrderGoodsMapper, OrderGoodsEntity> implements IService<OrderGoodsEntity> {
private final GoodsInfoService goodsInfoService;
/**
*
*/
public void add(OrderGoodsEntity orderGoodsEntity) {
@Transactional(rollbackFor = Exception.class)
public long add(Long goodsId) {
GoodsInfoEntity goodsInfoEntity = goodsInfoService.getById(goodsId);
Assert.notNull(goodsInfoEntity, () -> Exceptions.clierr("商品不存在"));
goodsInfoEntity.setId(null);
OrderGoodsEntity orderGoodsEntity = BeanUtil.copyProperties(goodsInfoEntity, OrderGoodsEntity.class)
.setOriginGoodsId(goodsId);
this.save(orderGoodsEntity);
return orderGoodsEntity.getId();
}
/**

View File

@ -1,5 +1,6 @@
package com.njzscloud.supervisory.order.service;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.lang.Assert;
import cn.hutool.core.util.StrUtil;
@ -10,12 +11,15 @@ import com.njzscloud.common.core.ex.Exceptions;
import com.njzscloud.common.mp.support.PageParam;
import com.njzscloud.common.mp.support.PageResult;
import com.njzscloud.common.security.util.SecurityUtil;
import com.njzscloud.common.sn.support.SnUtil;
import com.njzscloud.supervisory.biz.contant.AuditStatus;
import com.njzscloud.supervisory.biz.pojo.entity.BizAuditConfigEntity;
import com.njzscloud.supervisory.biz.service.BizAuditConfigService;
import com.njzscloud.supervisory.order.contant.CheckStatus;
import com.njzscloud.supervisory.order.contant.OrderCategory;
import com.njzscloud.supervisory.order.contant.OrderStatus;
import com.njzscloud.supervisory.order.mapper.OrderInfoMapper;
import com.njzscloud.supervisory.order.pojo.entity.OrderGoodsEntity;
import com.njzscloud.supervisory.order.pojo.entity.OrderInfoEntity;
import com.njzscloud.supervisory.order.pojo.param.*;
import com.njzscloud.supervisory.order.pojo.result.OrderPagingResult;
@ -25,6 +29,7 @@ import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.time.LocalDateTime;
import java.util.Arrays;
import java.util.List;
import java.util.Set;
import java.util.stream.Collectors;
@ -38,12 +43,62 @@ import java.util.stream.Collectors;
public class OrderInfoService extends ServiceImpl<OrderInfoMapper, OrderInfoEntity> implements IService<OrderInfoEntity> {
private final BizAuditConfigService bizAuditConfigService;
private final OrderGoodsService orderGoodsService;
private final OrderCargoPlaceService orderCargoPlaceService;
private final OrderCarInOutService orderCarInOutService;
/**
*
*/
public void add(OrderInfoEntity orderInfoEntity) {
@Transactional(rollbackFor = Exception.class)
public void add(AddOrderInfoParam addOrderInfoParam) {
AddOrderCargoPlaceParam cargoPlace = addOrderInfoParam.getCargoPlace();
long cargoPlaceId = orderCargoPlaceService.add(cargoPlace);
Long userId = SecurityUtil.currentUserId();
String area = cargoPlace.getArea();
BizAuditConfigEntity bizAuditConfigEntity = bizAuditConfigService.getOne(Wrappers.lambdaQuery(BizAuditConfigEntity.class).eq(BizAuditConfigEntity::getArea, area));
AuditStatus auditStatus = null;
if (bizAuditConfigEntity != null) {
String areaRole = bizAuditConfigEntity.getAreaRole();
String cityRole = bizAuditConfigEntity.getCityRole();
if (areaRole != null && cityRole != null) {
auditStatus = AuditStatus.QuDaiShenHe;
} else if (areaRole == null && cityRole != null) {
auditStatus = AuditStatus.ShiDaiShenHe;
}
}
Long transCompanyId = addOrderInfoParam.getTransCompanyId();
OrderStatus orderStatus = transCompanyId == null ? OrderStatus.YiYuYue : OrderStatus.DaiPaiDan;
Long goodsId = addOrderInfoParam.getGoodsId();
Long orderGoodsId = orderGoodsService.add(goodsId);
OrderInfoEntity orderInfoEntity = BeanUtil.copyProperties(addOrderInfoParam, OrderInfoEntity.class)
.setSn(SnUtil.next())
.setCargoPlaceId(cargoPlaceId)
.setUserId(userId)
.setAuditStatus(auditStatus)
.setOrderStatus(orderStatus)
.setGoodsId(orderGoodsId)
.setCheckStatus(CheckStatus.WeiKanLiao);
this.save(orderInfoEntity);
Long orderId = orderInfoEntity.getId();
OrderCategory orderCategory = addOrderInfoParam.getOrderCategory();
if (orderCategory == OrderCategory.DuanBoChu) {
this.add(addOrderInfoParam.setOrderCategory(OrderCategory.DuanBoRu)
.setTargetOrderId(orderId)
.setTargetStationId(addOrderInfoParam.getStationId())
.setStationId(addOrderInfoParam.getTargetStationId())
);
} else if (orderCategory == OrderCategory.DuanBoRu) {
this.updateById(new OrderInfoEntity().setId(addOrderInfoParam.getTargetOrderId())
.setTargetOrderId(orderId));
}
}
/**
@ -239,4 +294,68 @@ public class OrderInfoService extends ServiceImpl<OrderInfoMapper, OrderInfoEnti
);
// TODO 关闭 GPS
}
@Transactional(rollbackFor = Exception.class)
public void modifyGoods(ModifyOrderGoodsParam modifyOrderGoodsParam) {
OrderInfoEntity orderInfoEntity = this.getById(modifyOrderGoodsParam.getOrderId());
Assert.notNull(orderInfoEntity, () -> Exceptions.clierr("订单不存在"));
OrderStatus orderStatus = orderInfoEntity.getOrderStatus();
Assert.isTrue(orderStatus != OrderStatus.YiChuChang
&& orderStatus != OrderStatus.YiWanCheng
&& orderStatus != OrderStatus.YiQuXiao
, () -> Exceptions.clierr("当前订单状态,无法修改商品"));
orderGoodsService.modify(new OrderGoodsEntity()
.setId(orderInfoEntity.getGoodsId())
.setGoodsCategoryId(modifyOrderGoodsParam.getGoodsCategoryId())
.setOriginGoodsId(modifyOrderGoodsParam.getOriginGoodsId())
);
}
/**
*
*/
@Transactional(rollbackFor = Exception.class)
public void truckComing(TruckComingOrderParam truckComingOrderParam) {
OrderInfoEntity orderInfoEntity = this.getById(truckComingOrderParam.getOrderId());
Assert.notNull(orderInfoEntity, () -> Exceptions.clierr("订单不存在"));
OrderStatus orderStatus = orderInfoEntity.getOrderStatus();
Assert.isTrue(orderStatus == OrderStatus.QingYunZhong, () -> Exceptions.clierr("当前订单状态,无法进场"));
OrderCategory orderCategory = orderInfoEntity.getOrderCategory();
long carInOutId = orderCarInOutService.truckComing(truckComingOrderParam, orderCategory);
this.updateById(new OrderInfoEntity()
.setId(orderInfoEntity.getId())
.setCarInOutId(carInOutId)
.setOrderStatus(OrderStatus.YiJinChang)
);
}
/**
*
*/
@Transactional(rollbackFor = Exception.class)
public void truckLeaving(TruckLeavingOrderParam truckLeavingOrderParam) {
OrderInfoEntity orderInfoEntity = this.getById(truckLeavingOrderParam.getOrderId());
Assert.notNull(orderInfoEntity, () -> Exceptions.clierr("订单不存在"));
OrderStatus orderStatus = orderInfoEntity.getOrderStatus();
Assert.isTrue(orderStatus == OrderStatus.YiJinChang, () -> Exceptions.clierr("当前订单状态,无法出场"));
this.updateById(new OrderInfoEntity()
.setId(orderInfoEntity.getId())
.setOrderStatus(OrderStatus.YiChuChang)
);
OrderCategory orderCategory = orderInfoEntity.getOrderCategory();
orderCarInOutService.truckOut(orderInfoEntity.getCarInOutId(), truckLeavingOrderParam, orderCategory);
// TODO 关闭 GPS
}
public OrderPagingResult pendingOrder(String licensePlate) {
return baseMapper.pendingOrder(Wrappers.query()
.eq("e.license_plate", licensePlate)
.in("a.order_status", Arrays.asList(OrderStatus.QingYunZhong, OrderStatus.YiJinChang))
.orderByDesc("a.trans_time")
);
}
}

View File

@ -4,6 +4,7 @@ import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.njzscloud.common.security.support.EndpointResource;
import com.njzscloud.common.security.support.MenuResource;
import com.njzscloud.common.security.support.UserDetail;
import com.njzscloud.supervisory.biz.pojo.result.SearchCompanyResult;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
@ -19,4 +20,6 @@ public interface AuthMapper {
Set<String> selectRoleByUserId(@Param("userId") Long userId);
UserDetail selectUser(@Param("ew") QueryWrapper<Object> ew);
SearchCompanyResult selectCompanyInfo(@Param("userId") Long userId);
}

View File

@ -2,6 +2,8 @@ package com.njzscloud.supervisory.sys.auth.pojo.result;
import com.njzscloud.common.security.support.EndpointResource;
import com.njzscloud.common.security.support.MenuResource;
import com.njzscloud.supervisory.biz.contant.BizObj;
import com.njzscloud.supervisory.biz.pojo.result.SearchCompanyResult;
import com.njzscloud.supervisory.sys.user.contant.Gender;
import lombok.Getter;
import lombok.Setter;
@ -21,6 +23,9 @@ public class MyResult {
private List<EndpointResource> endpoints;
private List<Map<String, Object>> setting;
private BizObj bizObj;
private SearchCompanyResult company;
/**
* Id
*/

View File

@ -5,6 +5,7 @@ import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.njzscloud.common.security.contant.AuthWay;
import com.njzscloud.common.security.support.*;
import com.njzscloud.common.security.util.SecurityUtil;
import com.njzscloud.supervisory.biz.pojo.result.SearchCompanyResult;
import com.njzscloud.supervisory.sys.auth.mapper.AuthMapper;
import com.njzscloud.supervisory.sys.auth.pojo.result.MyResult;
import com.njzscloud.supervisory.sys.user.pojo.entity.UserEntity;
@ -51,7 +52,6 @@ public class AuthService implements IUserService, IResourceService, IRoleService
return authMapper.selectRoleByUserId(userId);
}
/**
*
*/
@ -60,7 +60,9 @@ public class AuthService implements IUserService, IResourceService, IRoleService
UserEntity userEntity = userService.getById(userId);
List<MenuResource> menuResources = authMapper.selectUserMenu(userId);
List<EndpointResource> endpointResources = authMapper.selectUserEndpoint(userId);
return BeanUtil.copyProperties(userEntity, MyResult.class).setMenus(menuResources).setEndpoints(endpointResources);
SearchCompanyResult company = authMapper.selectCompanyInfo(userId);
return BeanUtil.copyProperties(userEntity, MyResult.class).setMenus(menuResources).setEndpoints(endpointResources).setCompany(company);
}
}

View File

@ -152,20 +152,23 @@ public class UserRegisterParam implements Constrained {
private String legalRepresentative;
/**
* ;
* ;
*/
private String province;
/**
* ;
* ;
*/
private String city;
/**
* ;
* ;
*/
private String county;
private String area;
/**
* ;
*/
private String town;
/**
@ -179,12 +182,12 @@ public class UserRegisterParam implements Constrained {
private String cityName;
/**
* ;
* ;
*/
private String countyName;
private String areaName;
/**
* ;
* ;
*/
private String townName;
@ -196,12 +199,12 @@ public class UserRegisterParam implements Constrained {
/**
*
*/
private String lng;
private Double lng;
/**
*
*/
private String lat;
private Double lat;
/**
*

View File

@ -157,8 +157,7 @@ public class UserService extends ServiceImpl<UserMapper, UserEntity> implements
AddBizCompanyParam addBizCompanyParam = BeanUtil
.copyProperties(company, AddBizCompanyParam.class)
.setUserId(userId)
.setBizObj(bizObj);
.setUserId(userId);
bizCompanyService.add(addBizCompanyParam);
return SecurityUtil.registrationToken(userRegisterParam.getAccount().getUsername(), AuthWay.PASSWORD);
}

View File

@ -9,6 +9,7 @@ spring:
- /user/register
- /oss/**
- /district/tree
- /sys_sn_config/add
app:
default-place:

View File

@ -5,128 +5,138 @@
<sql id="base_select">
SELECT a.id,
a.sn,
a.station_id,
a.lane_id,
a.project_id,
a.traffic_company_id,
a.user_id,
a.audit_status,
a.audit_memo,
a.order_category,
a.order_status,
a.checker_id,
a.check_status,
a.truck_id,
a.driver_id,
a.goods_id,
a.discount_money,
a.revise_money,
a.settle_money,
a.payer,
a.payer_category,
a.payment_status,
a.payment_time,
a.customer_memo,
a.checker_memo,
a.cargo_photo,
a.check_photo,
a.creator_id,
a.modifier_id,
a.create_time,
a.modify_time,
a.deleted,
a.cargo_place_id,
a.car_in_out_id,
a.sn,
a.station_id,
a.lane_id,
a.project_id,
a.trans_company_id,
a.user_id,
a.audit_status,
a.audit_memo,
a.order_category,
a.order_status,
a.checker_id,
a.check_status,
a.truck_id,
a.driver_id,
a.goods_id,
a.discount_money,
a.revise_money,
a.settle_money,
a.payer,
a.payer_category,
a.payment_status,
a.payment_time,
a.customer_memo,
a.checker_memo,
a.cargo_photo,
a.check_photo,
a.creator_id,
a.modifier_id,
a.create_time,
a.modify_time,
a.deleted,
a.cargo_place_id,
a.car_in_out_id,
b.province,
b.city,
b.area,
b.town,
b.province_name,
b.city_name,
b.area_name,
b.town_name,
b.address,
b.lng,
b.lat,
b.province,
b.city,
b.area,
b.town,
b.province_name,
b.city_name,
b.area_name,
b.town_name,
b.address,
b.lng,
b.lat,
c.goods_category_id,
c.origin_goods_id,
c.goods_name,
c.unit_price,
c.unit,
c.money_strategy,
c.money_config_id,
c.picture,
c.tax_rate,
c.quantity,
c.total_money,
c.goods_category_id,
c.origin_goods_id,
c.goods_name,
c.unit_price,
c.unit,
c.money_strategy,
c.money_config_id,
c.picture,
c.tax_rate,
c.quantity,
c.total_money,
d.rough_weight,
d.tare_weight,
d.settle_weight,
d.in_front_photo,
d.in_body_photo,
d.out_front_photo,
d.out_body_photo,
d.in_time,
d.out_time,
d.rough_weight,
d.tare_weight,
d.settle_weight,
d.in_front_photo,
d.in_body_photo,
d.out_front_photo,
d.out_body_photo,
d.in_time,
d.out_time,
e.license_plate,
e.truck_license,
e.vn_code,
e.qualification,
e.carrying_capacity,
e.tare_weight history_tare_weight,
e.audit_status,
e.audit_memo,
e.license_plate,
e.truck_license,
e.vn_code,
e.qualification,
e.carrying_capacity,
e.tare_weight history_tare_weight,
e.audit_status,
e.audit_memo,
f.driver_name,
f.phone driver_phone,
f.driving_licence,
f.licence_start_time,
f.licence_end_time,
f.driver_name,
f.phone driver_phone,
f.driving_licence,
f.licence_start_time,
f.licence_end_time,
g.uscc tarffic_company_uscc,
g.company_name tarffic_company_company_name,
g.business_license tarffic_company_business_license,
g.license_start_time tarffic_company_license_start_time,
g.license_end_time tarffic_company_license_end_time,
g.legal_representative tarffic_company_legal_representative,
g.province tarffic_company_province,
g.city tarffic_company_city,
g.area tarffic_company_area,
g.town tarffic_company_town,
g.province_name tarffic_company_province_name,
g.city_name tarffic_company_city_name,
g.area_name tarffic_company_area_name,
g.town_name tarffic_company_town_name,
g.address tarffic_company_address,
g.lng tarffic_company_lng,
g.lat tarffic_company_lat,
g.contacts tarffic_company_contacts,
g.phone tarffic_company_phone,
h.nickname,
h.phone
g.uscc tarffic_company_uscc,
g.company_name tarffic_company_company_name,
g.business_license tarffic_company_business_license,
g.license_start_time tarffic_company_license_start_time,
g.license_end_time tarffic_company_license_end_time,
g.legal_representative tarffic_company_legal_representative,
g.province tarffic_company_province,
g.city tarffic_company_city,
g.area tarffic_company_area,
g.town tarffic_company_town,
g.province_name tarffic_company_province_name,
g.city_name tarffic_company_city_name,
g.area_name tarffic_company_area_name,
g.town_name tarffic_company_town_name,
g.address tarffic_company_address,
g.lng tarffic_company_lng,
g.lat tarffic_company_lat,
g.contacts tarffic_company_contacts,
g.phone tarffic_company_phone,
h.nickname,
h.phone
FROM order_info a
INNER JOIN order_cargo_place b ON b.id = a.cargo_place_id
INNER JOIN order_goods c ON c.id = a.goods_id
INNER JOIN order_car_in_out d ON d.id = a.car_in_out_id
INNER JOIN biz_truck e ON e.id = a.truck_id
INNER JOIN biz_driver f ON f.id = a.driver_id
INNER JOIN biz_company g ON g.id = a.traffic_company_id
INNER JOIN sys_user h ON h.id = a.user_id
<if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
${ew.customSqlSegment}
</if>
INNER JOIN order_cargo_place b ON b.id = a.cargo_place_id
INNER JOIN order_goods c ON c.id = a.goods_id
INNER JOIN order_car_in_out d ON d.id = a.car_in_out_id
INNER JOIN biz_truck e ON e.id = a.truck_id
INNER JOIN biz_driver f ON f.id = a.driver_id
INNER JOIN biz_company g ON g.id = a.trans_company_id
INNER JOIN sys_user h ON h.id = a.user_id
</sql>
<select id="paging" resultType="com.njzscloud.supervisory.order.pojo.result.OrderPagingResult">
<include refid="base_select"/>
<if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
${ew.customSqlSegment}
</if>
</select>
<select id="detail" resultType="com.njzscloud.supervisory.order.pojo.result.OrderPagingResult">
<include refid="base_select"/>
<if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
${ew.customSqlSegment}
</if>
</select>
<select id="pendingOrder" resultType="com.njzscloud.supervisory.order.pojo.result.OrderPagingResult">
<include refid="base_select"/>
<if test="ew.customSqlSegment != null and ew.customSqlSegment != ''">
${ew.customSqlSegment}
</if>
LIMIT 1
</select>
</mapper>

View File

@ -65,4 +65,32 @@
INNER JOIN sys_user_role b ON b.role_id = a.id AND b.user_id = #{userId}
WHERE a.deleted = 0
</select>
<select id="selectCompanyInfo" resultType="com.njzscloud.supervisory.biz.pojo.result.SearchCompanyResult">
SELECT id,
user_id,
station,
uscc,
company_name,
business_license,
license_start_time,
license_end_time,
legal_representative,
province,
city,
area,
town,
province_name,
city_name,
area_name,
town_name,
address,
lng,
lat,
contacts,
phone,
audit_status,
audit_memo
FROM biz_company
WHERE user_id = #{userId}
</select>
</mapper>

View File

@ -4,7 +4,7 @@
"avatar": "",
"version": "4.9.4",
"createdTime": "2023-4-13 11:53:52",
"updatedTime": "2025-9-12 22:42:33",
"updatedTime": "2025-9-13 11:23:04",
"dbConns": [],
"profile": {
"default": {
@ -10009,16 +10009,16 @@
"id": "F60961B2-DB77-48E3-844D-D9E6A744AA81"
},
{
"defKey": "lane_id",
"defKey": "lane",
"defName": "车道",
"comment": "",
"type": "VARCHAR",
"len": 30,
"scale": "",
"primaryKey": false,
"notNull": true,
"notNull": false,
"autoIncrement": false,
"defaultValue": "'1车道'",
"defaultValue": "",
"hideInGraph": false,
"refDict": "",
"baseType": "AA07828C-4FCB-4EDA-9B51-53A3F264F231",
@ -10144,6 +10144,60 @@
"extProps": {},
"id": "82373BA9-825C-4EBF-ACAF-F520D59A2467"
},
{
"defKey": "target_station_id",
"defName": "对方站点 Id",
"comment": "短驳单有值",
"type": "BIGINT",
"len": "",
"scale": "",
"primaryKey": false,
"notNull": false,
"autoIncrement": false,
"defaultValue": "",
"hideInGraph": false,
"refDict": "",
"extProps": {},
"notes": {},
"attr1": "",
"attr2": "",
"attr3": "",
"attr4": "",
"attr5": "",
"attr6": "",
"attr7": "",
"attr8": "",
"attr9": "",
"id": "6F7DADE7-8171-4822-B489-D51CB3015659",
"baseType": "9B6B9E10-DB11-4409-878B-5868A19CD9B0"
},
{
"defKey": "target_order_id",
"defName": "对方订单 Id",
"comment": "短驳单有值",
"type": "BIGINT",
"len": "",
"scale": "",
"primaryKey": false,
"notNull": false,
"autoIncrement": false,
"defaultValue": "",
"hideInGraph": false,
"refDict": "",
"extProps": {},
"notes": {},
"attr1": "",
"attr2": "",
"attr3": "",
"attr4": "",
"attr5": "",
"attr6": "",
"attr7": "",
"attr8": "",
"attr9": "",
"id": "1CF52CA5-1B99-43F1-BD6F-B12A7DFCA610",
"baseType": "9B6B9E10-DB11-4409-878B-5868A19CD9B0"
},
{
"defKey": "order_category",
"defName": "订单类型",
@ -14186,6 +14240,60 @@
"extProps": {},
"id": "D76BA1D7-C780-497D-9FB0-0F4F1CDAB126"
},
{
"defKey": "audit_status",
"defName": "审核状态",
"comment": "字典代码audit_status",
"type": "VARCHAR",
"len": 32,
"scale": "",
"primaryKey": false,
"notNull": true,
"autoIncrement": false,
"defaultValue": "",
"hideInGraph": false,
"refDict": "F88D246F-A17A-4711-A6AB-500EF85E91E1",
"extProps": {},
"notes": {},
"attr1": "",
"attr2": "",
"attr3": "",
"attr4": "",
"attr5": "",
"attr6": "",
"attr7": "",
"attr8": "",
"attr9": "",
"id": "F6574AFC-C3BF-4123-AEFF-090EB797E4C2",
"baseType": "AA07828C-4FCB-4EDA-9B51-53A3F264F231"
},
{
"defKey": "audit_memo",
"defName": "审核备注",
"comment": "",
"type": "VARCHAR",
"len": 512,
"scale": "",
"primaryKey": false,
"notNull": true,
"autoIncrement": false,
"defaultValue": "''",
"hideInGraph": false,
"refDict": "",
"extProps": {},
"notes": {},
"attr1": "",
"attr2": "",
"attr3": "",
"attr4": "",
"attr5": "",
"attr6": "",
"attr7": "",
"attr8": "",
"attr9": "",
"id": "E4F2B183-A5D1-48B2-812A-7B1860852039",
"baseType": "AA07828C-4FCB-4EDA-9B51-53A3F264F231"
},
{
"defKey": "creator_id",
"defName": "创建人 Id",

View File

@ -4,32 +4,40 @@ Content-Type: application/json
{
"gender": "",
"bizObj": "GeRen",
"nickname": "13115042121",
"account": {
"email": "",
"phone": "2",
"username": "2",
"secret": "",
"code": "00000",
"codeId": "00000"
"phone": "13115042213",
"username": "873143",
"secret": "123456"
},
"company": {
"companyName": "",
"businessLicense": "",
"certification": "",
"businessLicenseDate": [],
"certificationDate": [],
"legalRepresentative": "",
"province": "",
"city": "",
"county": "",
"street": "",
"address": "",
"contacts": "",
"phoneNum": "",
"name": "",
"intro": "",
"sex": "",
"radio": "",
"businessLicenseDate": [
"2025-09-13",
"2025-09-16"
],
"certificationDate": [
"2025-09-13",
"2025-09-19"
],
"bizObj": "QingYunGongSi",
"companyName": "清运公司1",
"uscc": "1",
"legalRepresentative": "张三",
"lat": 31.95266,
"lng": 118.84002,
"county": "江宁区",
"street": "东山街道",
"address": "江宁区上元大街369号",
"contacts": "张三",
"phone": "13115042213",
"scopeList": []
}
},
"bizObj": "QingYunGongSi",
"nickname": "873143"
}
### 登录