张晓波
2023-10-19 eeeebc2327a6ac25d350504704d93c379199a51a
hd/pipe/StaffManage/src/main/java/com/thhy/staff/modules/biz/face/service/impl/FaceServerImpl.java
@@ -1,18 +1,27 @@
package com.thhy.staff.modules.biz.face.service.impl;
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.thhy.general.utils.DeepCopyUtils;
import com.alibaba.nacos.api.utils.StringUtils;
import com.thhy.staff.config.EmqxConfig;
import com.thhy.staff.config.EmqxProperties;
import com.thhy.staff.modules.biz.face.entity.FaceDevice;
import com.thhy.staff.modules.biz.face.entity.FaceResult;
import com.thhy.staff.modules.biz.face.entity.UserFaceVo;
import com.thhy.staff.modules.biz.face.mapper.FaceDeviceMapper;
import com.thhy.staff.modules.biz.face.service.FaceServer;
import com.thhy.staff.modules.biz.platuser.entity.DoorLis;
import com.thhy.staff.modules.biz.platuser.mapper.PlatUserMapper;
import com.thhy.staff.utils.MqUtils;
import org.checkerframework.checker.units.qual.A;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import java.util.ArrayList;
import java.util.List;
@Service
public class FaceServerImpl implements FaceServer {
@@ -21,7 +30,13 @@
    private FaceDeviceMapper faceDeviceMapper;
    @Autowired
    private PlatUserMapper userMapper;
    @Autowired
    private EmqxConfig emqxConfig;
    @Value("${file.vfprefix}")
    private String vfPrefix;
    private Logger logger = LoggerFactory.getLogger(FaceServer.class);
@@ -38,6 +53,95 @@
        }
        FaceResult faceResult = new FaceResult(true,faceDevice,emqxConfig.toString());
        logger.info("人脸设备返回:++++++++++"+JSON.toJSONString(faceResult));
        return faceResult;
    }
    @Override
    public JSONObject syncPerson(String mess) {
        JSONObject reqJson = JSONObject.parseObject(mess);
        JSONObject paramJson = reqJson.getJSONObject("path_params");
        List<UserFaceVo> faceVoList =  userMapper.queryUserFace(paramJson.getIntValue("offset"),paramJson.getIntValue("limit"));
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("code",0);
        jsonObject.put("msg","OK");
        jsonObject.put("success",true);
        jsonObject.put("offset",paramJson.getIntValue("offset")+paramJson.getIntValue("limit"));
        jsonObject.put("person_list",faceVoList);
        return jsonObject;
    }
    @Override
    public JSONObject syncPersonSingle(String mess) {
        JSONObject reqJson = JSONObject.parseObject(mess);
        JSONObject paramJson = reqJson.getJSONObject("path_params");
        JSONArray userIdArray = paramJson.getJSONArray("person_list");
        String userId = userIdArray.getString(0);
        UserFaceVo userFaceVo = userMapper.queryUserFaceSingle(userId);
        userFaceVo.setTemplateImgUrl(vfPrefix+"/"+userFaceVo.getTemplateImgUrl());
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("code",0);
        jsonObject.put("msg","OK");
        jsonObject.put("success",true);
        jsonObject.put("offset",0);
        List<UserFaceVo> faceVoList = new ArrayList<>();
        faceVoList.add(userFaceVo);
        jsonObject.put("person_list",faceVoList);
        logger.info("设备查询人员结果:"+JSON.toJSONString(faceVoList));
        return jsonObject;
    }
    @Override
    public void personNotify(String mess) {
        JSONObject reqJson = JSONObject.parseObject(mess);
        logger.info("接收设备下发结果通知################"+mess);
        if(reqJson.containsKey("success")&&reqJson.getBooleanValue("success")){
            String userIds = reqJson.getString("successful");
            if(!StringUtils.isEmpty(userIds)){
                String[] userIdArray = new String[]{userIds};
                if(userIds.contains(",")){
                    userIdArray = userIds.split(",");
                }
                userMapper.syncResult(1,userIdArray);
            }
            JSONArray failJsonArray = reqJson.getJSONArray("failed");
            if(failJsonArray.size()>0){
                for(Object obj : failJsonArray){
                    JSONObject failUserInfo = JSON.parseObject(obj.toString());
                    String userId = failUserInfo.getString("person_id");
                    JSONArray failInfoArray = failUserInfo.getJSONArray("info");
                    String failReason = "";
                    if(failInfoArray.size()>0) failReason = failInfoArray.getJSONObject(0).getString("reason");
                    userMapper.syncFail(userId,failReason);
                }
            }
        }
    }
    @Override
    public void record(String mess) {
        JSONObject jsonObject = JSON.parseObject(mess);
        DoorLis doorLis = new DoorLis(jsonObject);
        userMapper.insertDoorLis(doorLis);
    }
    @Override
    public void queryPer(String perId) {
        JSONObject jsonObject = new JSONObject();
        jsonObject.put("method","get_person");
        jsonObject.put("params",new JSONObject());
        JSONObject dataJson = new JSONObject();
        dataJson.put("path",vfPrefix+"/"+"getPersonDetail");
        dataJson.put("person_id",perId);
        jsonObject.put("data",dataJson);
        List<String> sns = faceDeviceMapper.queryDevSn();
        String content = jsonObject.toJSONString();
        logger.info("查询人员"+perId+":"+content);
        MqUtils.createClient(emqxConfig,sns,content);
    }
}