|
|
@@ -2,6 +2,7 @@ package com.xunmei.host.iot.service.impl;
|
|
|
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
import com.alibaba.fastjson.JSONArray;
|
|
|
+import com.alibaba.fastjson.JSONObject;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
|
|
@@ -11,6 +12,7 @@ import com.xunmei.common.core.constant.Constants;
|
|
|
import com.xunmei.common.core.domain.iot.domain.IotAlarmDefenceArea;
|
|
|
import com.xunmei.common.core.domain.iot.domain.IotAlarmSubsystem;
|
|
|
import com.xunmei.common.core.domain.iot.domain.IotServerInfo;
|
|
|
+import com.xunmei.common.core.domain.work.dto.WorkDayDto;
|
|
|
import com.xunmei.common.core.enums.iot.BaseDeviceTypeEnum;
|
|
|
import com.xunmei.common.core.enums.iot.DefenceAreaType;
|
|
|
import com.xunmei.common.core.utils.JacksonUtils;
|
|
|
@@ -30,7 +32,10 @@ import com.xunmei.host.websocket.dto.dvs.SubDeviceInfo;
|
|
|
import com.xunmei.host.websocket.enums.DeviceCacheEnum;
|
|
|
import com.xunmei.host.websocket.enums.DeviceNetStatusEnum;
|
|
|
import com.xunmei.host.websocket.enums.ProductEnums;
|
|
|
+import com.xunmei.host.websocket.enums.TopicTypeEnums;
|
|
|
import com.xunmei.host.websocket.service.RouterService;
|
|
|
+import com.xunmei.host.websocket.utils.IotServerUtils;
|
|
|
+import com.xunmei.host.websocket.utils.WebSocketUtils;
|
|
|
import com.xunmei.system.api.domain.iot.IotDeviceInfo;
|
|
|
import com.xunmei.system.api.domain.iot.IotDeviceInfoExtend;
|
|
|
import com.xunmei.system.api.util.LogUtils;
|
|
|
@@ -40,6 +45,7 @@ import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
+import java.io.IOException;
|
|
|
import java.time.Duration;
|
|
|
import java.time.LocalDateTime;
|
|
|
import java.util.*;
|
|
|
@@ -276,7 +282,7 @@ public class IotDeviceInfoServiceImpl extends ServiceImpl<IotDeviceInfoMapper, I
|
|
|
|
|
|
@Override
|
|
|
public void delData(String iotCode) {
|
|
|
- if (ObjectUtil.isEmpty(iotCode)){
|
|
|
+ if (ObjectUtil.isEmpty(iotCode)) {
|
|
|
return;
|
|
|
}
|
|
|
deleteDeviceByToken(iotCode);
|
|
|
@@ -751,4 +757,17 @@ public class IotDeviceInfoServiceImpl extends ServiceImpl<IotDeviceInfoMapper, I
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+
|
|
|
+ @Override
|
|
|
+ public void startWork(WorkDayDto eto) throws IOException {
|
|
|
+
|
|
|
+ final IotServerInfo serverInfo = iotServerInfoService.selectByOrgId(eto.getOrgId());
|
|
|
+ final String iotCode = serverInfo.getIotCode();
|
|
|
+ final String topic = TopicTypeEnums.formatUrl(TopicTypeEnums.PRODUCT_SERVICE_INVOKE.getUrl(), ProductEnums.DETECTION_HOST.getProductName()[0], ProductEnums.DETECTION_HOST.getProductName()[1]);
|
|
|
+ final JSONObject object = new JSONObject();
|
|
|
+ object.put("dataType", eto.getDataType());
|
|
|
+ final WebsocketResult result = IotServerUtils.invokeHostServer(topic, new JSONObject(), WebSocketConstants.DO_WORK, object);
|
|
|
+ WebSocketUtils.sendMessage(iotCode, JacksonUtils.toJSONString(result));
|
|
|
+
|
|
|
+ }
|
|
|
}
|