java110
2023-03-31 4e12aa79fa3affb0d0dc3e5f9d368814702f8d2b
service-common/src/main/java/com/java110/common/cmd/machine/SaveAccessControlWhiteCmd.java
@@ -15,6 +15,7 @@
 */
package com.java110.common.cmd.machine;
import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject;
import com.java110.core.annotation.Java110Cmd;
import com.java110.core.annotation.Java110Transactional;
@@ -22,8 +23,13 @@
import com.java110.core.event.cmd.Cmd;
import com.java110.core.event.cmd.CmdEvent;
import com.java110.core.factory.GenerateCodeFactory;
import com.java110.core.smo.IPhotoSMO;
import com.java110.doc.annotation.*;
import com.java110.dto.accessControlWhite.AccessControlWhiteDto;
import com.java110.intf.common.IAccessControlWhiteAuthV1InnerServiceSMO;
import com.java110.intf.common.IAccessControlWhiteV1InnerServiceSMO;
import com.java110.po.accessControlWhite.AccessControlWhitePo;
import com.java110.po.accessControlWhiteAuth.AccessControlWhiteAuthPo;
import com.java110.utils.exception.CmdException;
import com.java110.utils.util.Assert;
import com.java110.utils.util.BeanConvertUtil;
@@ -31,6 +37,45 @@
import org.springframework.beans.factory.annotation.Autowired;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
@Java110CmdDoc(title = "门禁授权白名单",
        description = "主要用于员工,外卖和访客授权门禁白名单",
        httpMethod = "post",
        url = "http://{ip}:{port}/app/machine.saveAccessControlWhite",
        resource = "commonDoc",
        author = "吴学文",
        serviceCode = "machine.saveAccessControlWhite"
)
@Java110ParamsDoc(params = {
        @Java110ParamDoc(name = "communityId", length = 30, remark = "小区ID"),
        @Java110ParamDoc(name = "machineId", length = 30, remark = "门禁ID"),
        @Java110ParamDoc(name = "personName", length = 30, remark = "人员名称"),
        @Java110ParamDoc(name = "tel", length = 30, remark = "电话"),
        @Java110ParamDoc(name = "idCard", length = 30, remark = "身份证"),
        @Java110ParamDoc(name = "personType", length = 30, remark = "人员类型 1001\t员工\n" +
                "2002\t外卖人员\n" +
                "3003\t快递人员\n" +
                "4004\t访客人员\n" +
                "5005\t其他人员"),
        @Java110ParamDoc(name = "startTime", length = 30, remark = "开始时间 YYYY-MM-DD hh24:mi:ss"),
        @Java110ParamDoc(name = "endTime", length = 30, remark = "结束时间 YYYY-MM-DD hh24:mi:ss"),
        @Java110ParamDoc(name = "accessControlKey", length = 30, remark = "门禁卡号 非必填"),
        @Java110ParamDoc(name = "photo", length = 30, remark = "人脸 "),
})
@Java110ResponseDoc(
        params = {
                @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "返回编号,0 成功 其他失败"),
                @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "成功", remark = "描述"),
        }
)
@Java110ExampleDoc(
        reqBody = "{\"machineId\":\"102023012407190005\",\"personName\":\"张快递\",\"tel\":\"18909714562\",\"idCard\":\"\",\"personType\":\"3003\",\"startTime\":\"2023-01-05 02:10:00\",\"endTime\":\"2023-02-08 02:10:00\",\"accessControlKey\":\"\",\"photo\":\"https://java110.oss-cn-beijing.aliyuncs.com/hc/img/20230124/ec4cfb4f-4953-44f2-89ab-383dc955b005.jpg\",\"communityId\":\"2022121921870161\"}",
        resBody = "{\"code\":0,\"msg\":\"成功\"}"
)
/**
 * 类表述:保存
@@ -52,15 +97,36 @@
    @Autowired
    private IAccessControlWhiteV1InnerServiceSMO accessControlWhiteV1InnerServiceSMOImpl;
    @Autowired
    private IAccessControlWhiteAuthV1InnerServiceSMO accessControlWhiteAuthV1InnerServiceSMOImpl;
    @Autowired
    private IPhotoSMO photoSMOImpl;
    @Override
    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
        Assert.hasKeyAndValue(reqJson, "machineId", "请求报文中未包含machineId");
        Assert.hasKey(reqJson, "machineIds", "请求报文中未包含machineId");
        Assert.hasKeyAndValue(reqJson, "communityId", "请求报文中未包含communityId");
        Assert.hasKeyAndValue(reqJson, "personName", "请求报文中未包含personName");
        Assert.hasKeyAndValue(reqJson, "tel", "请求报文中未包含tel");
        Assert.hasKeyAndValue(reqJson, "personType", "请求报文中未包含personType");
        Assert.hasKeyAndValue(reqJson, "startTime", "请求报文中未包含startTime");
        Assert.hasKeyAndValue(reqJson, "endTime", "请求报文中未包含endTime");
        AccessControlWhiteDto accessControlWhiteDto = new AccessControlWhiteDto();
        accessControlWhiteDto.setCommunityId(reqJson.getString("communityId"));
        accessControlWhiteDto.setTel(reqJson.getString("tel"));
        accessControlWhiteDto.setMachineId(reqJson.getString("machineId"));
        int count = accessControlWhiteV1InnerServiceSMOImpl.queryAccessControlWhitesCount(accessControlWhiteDto);
        if (count > 0) {
            throw new CmdException(reqJson.getString("personName") + "-" + reqJson.getString("tel") + ",人员已存在,您可以删除重新添加,或者修改");
        }
        JSONArray machineIds = reqJson.getJSONArray("machineIds");
        if (machineIds == null || machineIds.size() < 1) {
            throw new CmdException("未包含授权设备");
        }
    }
@@ -70,12 +136,34 @@
        AccessControlWhitePo accessControlWhitePo = BeanConvertUtil.covertBean(reqJson, AccessControlWhitePo.class);
        accessControlWhitePo.setAcwId(GenerateCodeFactory.getGeneratorId(CODE_PREFIX_ID));
        accessControlWhitePo.setMachineId("-1");
        int flag = accessControlWhiteV1InnerServiceSMOImpl.saveAccessControlWhite(accessControlWhitePo);
        if (flag < 1) {
            throw new CmdException("保存数据失败");
        }
        JSONArray machineIds = reqJson.getJSONArray("machineIds");
        AccessControlWhiteAuthPo accessControlWhiteAuthPo = null;
        for (int machineIndex = 0; machineIndex < machineIds.size(); machineIndex++) {
            accessControlWhiteAuthPo = new AccessControlWhiteAuthPo();
            accessControlWhiteAuthPo.setAcwaId(GenerateCodeFactory.getGeneratorId(CODE_PREFIX_ID));
            accessControlWhiteAuthPo.setAcwId(accessControlWhitePo.getAcwId());
            accessControlWhiteAuthPo.setCommunityId(accessControlWhitePo.getCommunityId());
            accessControlWhiteAuthPo.setMachineId(machineIds.getString(machineIndex));
            flag = accessControlWhiteAuthV1InnerServiceSMOImpl.saveAccessControlWhiteAuth(accessControlWhiteAuthPo);
            if (flag < 1) {
                throw new CmdException("保存数据失败");
            }
        }
        photoSMOImpl.savePhoto(reqJson, accessControlWhitePo.getAcwId(), reqJson.getString("communityId"));
        cmdDataFlowContext.setResponseEntity(ResultVo.success());
    }
}