java110 пре 4 година
родитељ
комит
f813148af9

+ 1 - 0
java110-utils/src/main/java/com/java110/utils/constant/KafkaConstant.java

@@ -22,4 +22,5 @@ public class KafkaConstant {
 
 
     public final static String TOPIC_API_SEND_WEB = "webSentMessageTopic";
+    public final static String TOPIC_API_SEND_PARKING_AREA_WEB = "webSentParkingAreaTopic";
 }

+ 22 - 0
service-api/src/main/java/com/java110/api/kafka/FrontServiceKafka.java

@@ -2,6 +2,7 @@ package com.java110.api.kafka;
 
 import com.alibaba.fastjson.JSONObject;
 import com.java110.api.websocket.MessageWebsocket;
+import com.java110.api.websocket.ParkingAreaWebsocket;
 import com.java110.core.base.controller.BaseController;
 import com.java110.utils.constant.KafkaConstant;
 import org.apache.kafka.clients.consumer.ConsumerRecord;
@@ -39,5 +40,26 @@ public class FrontServiceKafka extends BaseController {
         }
     }
 
+    /**
+     * 像前段返回内容
+     *
+     * @param record
+     */
+    @KafkaListener(topics = {KafkaConstant.TOPIC_API_SEND_PARKING_AREA_WEB})
+    public void listenParkingArea(ConsumerRecord<?, ?> record) {
+        logger.info("kafka的key: " + record.key());
+        logger.info("kafka的value: " + record.value().toString());
+
+        JSONObject param = null;
+        try {
+            param = JSONObject.parseObject(record.value().toString());
+            ParkingAreaWebsocket.sendInfo(param.toJSONString(), param.getString("paId"));
+        } catch (Exception e) {
+            logger.error("发送消息失败", e);
+        } finally {
+
+        }
+    }
+
 
 }

+ 6 - 0
service-common/src/main/java/com/java110/common/api/MachineApi.java

@@ -10,9 +10,14 @@ import com.java110.dto.machine.MachineDto;
 import com.java110.dto.machine.MachineRecordDto;
 import com.java110.dto.machine.MachineTranslateDto;
 import com.java110.dto.machineTranslateError.MachineTranslateErrorDto;
+import com.java110.utils.constant.KafkaConstant;
+import com.java110.utils.kafka.KafkaFactory;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
 import com.java110.utils.util.DateUtil;
+import com.java110.vo.ResultVo;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.http.ResponseEntity;
 import org.springframework.web.bind.annotation.*;
@@ -25,6 +30,7 @@ import org.springframework.web.bind.annotation.*;
 @RestController
 @RequestMapping(value = "/machine")
 public class MachineApi {
+    private static Logger logger = LoggerFactory.getLogger(MachineApi.class);
 
     private static final String USER_ROLE_OWNER = "owner";
     @Autowired

+ 62 - 0
service-common/src/main/java/com/java110/common/cmd/machine/OpenParkingAreaDoorControlLogCmd.java

@@ -0,0 +1,62 @@
+/*
+ * Copyright 2017-2020 吴学文 and java110 team.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.java110.common.cmd.machine;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.AbstractServiceCmdListener;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.utils.constant.KafkaConstant;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.kafka.KafkaFactory;
+import com.java110.vo.ResultVo;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+
+/**
+ * 类表述:保存
+ * 服务编码:machine.openParkingAreaDoorControlLog
+ * 请求路劲:/app/machine.openParkingAreaDoorControlLog
+ * add by 吴学文 at 2021-09-18 13:35:13 mail: 928255095@qq.com
+ * open source address: https://gitee.com/wuxw7/MicroCommunity
+ * 官网:http://www.homecommunity.cn
+ * 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
+ * // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
+ */
+@Java110Cmd(serviceCode = "machine.openParkingAreaDoorControlLog")
+public class OpenParkingAreaDoorControlLogCmd extends AbstractServiceCmdListener {
+
+    private static Logger logger = LoggerFactory.getLogger(OpenParkingAreaDoorControlLogCmd.class);
+
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
+
+
+    }
+
+    @Override
+    public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+
+        try {
+            KafkaFactory.sendKafkaMessage(KafkaConstant.TOPIC_API_SEND_PARKING_AREA_WEB, reqJson);
+        } catch (Exception e) {
+            logger.error("发送停车场信息失败", e);
+        }
+        cmdDataFlowContext.setResponseEntity(ResultVo.success());
+    }
+}