package com.dy.pipIrrWechat.command; 
 | 
  
 | 
import com.alibaba.fastjson2.JSON; 
 | 
import com.alibaba.fastjson2.JSONArray; 
 | 
import com.alibaba.fastjson2.JSONObject; 
 | 
import com.dy.common.multiDataSource.DataSourceContext; 
 | 
import com.dy.common.mw.protocol.Command; 
 | 
import com.dy.common.webUtil.QueryResultVo; 
 | 
import com.dy.pipIrrGlobal.command.ComSupport; 
 | 
import com.dy.pipIrrGlobal.daoPr.PrIntakeMapper; 
 | 
import com.dy.pipIrrGlobal.daoPr.PrIntakeVcMapper; 
 | 
import com.dy.pipIrrGlobal.daoPr.PrWaterPriceMapper; 
 | 
import com.dy.pipIrrGlobal.daoRm.RmCommandHistoryMapper; 
 | 
import com.dy.pipIrrGlobal.daoRm.RmIrrigateProfileMapper; 
 | 
import com.dy.pipIrrGlobal.daoRm.RmOpenCloseValveLastMapper; 
 | 
import com.dy.pipIrrGlobal.daoSe.SeClientCardMapper; 
 | 
import com.dy.pipIrrGlobal.daoSe.SeVirtualCardMapper; 
 | 
import com.dy.pipIrrGlobal.pojoRm.RmCommandHistory; 
 | 
import com.dy.pipIrrGlobal.pojoSe.SeClientCard; 
 | 
import com.dy.pipIrrGlobal.voPr.VoOnLineIntake; 
 | 
import com.dy.pipIrrGlobal.voRm.VoIrrigaterProfile; 
 | 
import com.dy.pipIrrGlobal.voRm.VoUnclosedValve; 
 | 
import com.dy.pipIrrGlobal.voSe.VoVirtualCard; 
 | 
import lombok.RequiredArgsConstructor; 
 | 
import lombok.extern.slf4j.Slf4j; 
 | 
import org.springframework.beans.factory.annotation.Autowired; 
 | 
import org.springframework.core.env.Environment; 
 | 
import org.springframework.stereotype.Service; 
 | 
  
 | 
import java.util.ArrayList; 
 | 
import java.util.HashMap; 
 | 
import java.util.List; 
 | 
import java.util.Map; 
 | 
  
 | 
/** 
 | 
 * @author ZhuBaoMin 
 | 
 * @date 2024-05-30 16:13 
 | 
 * @LastEditTime 2024-05-30 16:13 
 | 
 * @Description 
 | 
 */ 
 | 
  
 | 
@Slf4j 
 | 
@Service 
 | 
@RequiredArgsConstructor 
 | 
public class CommandSv extends ComSupport { 
 | 
    private final RmCommandHistoryMapper rmCommandHistoryMapper; 
 | 
    private final SeVirtualCardMapper seVirtualCardMapper; 
 | 
    private final PrIntakeMapper prIntakeMapper; 
 | 
    private final PrWaterPriceMapper prWaterPriceMapper; 
 | 
    private final PrIntakeVcMapper prIntakeVcMapper; 
 | 
    private final SeClientCardMapper seClientCardMapper; 
 | 
    private final RmIrrigateProfileMapper rmIrrigateProfileMapper; 
 | 
    private RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper; 
 | 
  
 | 
    /** 
 | 
     * pro_mw:属性 
 | 
     * tag从控制器中获取 
 | 
     * key_mw:url的key 
 | 
     */ 
 | 
    private Environment env = null; 
 | 
    private String pro_mw = "mw"; 
 | 
    private String key_mw = "comSendUrl"; 
 | 
    @Autowired 
 | 
    public CommandSv(RmCommandHistoryMapper rmCommandHistoryMapper,RmOpenCloseValveLastMapper rmOpenCloseValveLastMapper, SeVirtualCardMapper seVirtualCardMapper, PrIntakeMapper prIntakeMapper, PrWaterPriceMapper prWaterPriceMapper, PrIntakeVcMapper prIntakeVcMapper, SeClientCardMapper seClientCardMapper, RmIrrigateProfileMapper rmIrrigateProfileMapper, Environment env) { 
 | 
        this.rmCommandHistoryMapper = rmCommandHistoryMapper; 
 | 
        this.rmOpenCloseValveLastMapper = rmOpenCloseValveLastMapper; 
 | 
        this.seVirtualCardMapper = seVirtualCardMapper; 
 | 
        this.prIntakeMapper = prIntakeMapper; 
 | 
        this.prWaterPriceMapper = prWaterPriceMapper; 
 | 
        this.prIntakeVcMapper = prIntakeVcMapper; 
 | 
        this.seClientCardMapper = seClientCardMapper; 
 | 
        this.rmIrrigateProfileMapper = rmIrrigateProfileMapper; 
 | 
        this.env = env; 
 | 
    } 
 | 
    /** 
 | 
     * 虚拟卡ID换虚拟卡对象 
 | 
     * @param vcId 
 | 
     * @return 
 | 
     */ 
 | 
    public VoVirtualCard getVcById(Long vcId) { 
 | 
        return seVirtualCardMapper.getVcById(vcId); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 获取水价 
 | 
     * @return 
 | 
     */ 
 | 
    public Double getPrice() { 
 | 
        return prWaterPriceMapper.getPrice(); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 根据操作员ID获取未关阀记录(包含在线情况) 
 | 
     * @param operator 
 | 
     * @return 
 | 
     */ 
 | 
    public List<VoUnclosedValve> getUnclosedValves(Long operator) { 
 | 
        Command com = new Command() ; 
 | 
        com.id = Command.defaultId; 
 | 
        com.code = "LCD0001"; 
 | 
        com.type = "innerCommand"; 
 | 
        comSendUrl = env.getProperty(pro_mw + "." + DataSourceContext.get() + "." + key_mw); 
 | 
  
 | 
        JSONObject response = (JSONObject) JSON.toJSON(sendCom2Mw(com)); 
 | 
        if(response != null && response.getString("code").equals("0001")) { 
 | 
            JSONObject attachment = response.getJSONObject("content").getJSONObject("attachment").getJSONObject("onLineMap"); 
 | 
  
 | 
            JSONArray jsonArray = new JSONArray(); 
 | 
            if(attachment != null) { 
 | 
                HashMap<String, Boolean> onLineMap = JSON.parseObject(attachment.toJSONString(), HashMap.class); 
 | 
                for (Map.Entry<String, Boolean> entry : onLineMap.entrySet()) { 
 | 
                    JSONObject jsonObject = new JSONObject(); 
 | 
                    jsonObject.put("rtuAddr", entry.getKey()); 
 | 
                    jsonObject.put("isOnLine", entry.getValue()); 
 | 
                    jsonArray.add(jsonObject); 
 | 
                } 
 | 
            } 
 | 
  
 | 
            System.out.println(jsonArray.toJSONString()); 
 | 
            List<VoUnclosedValve> res = rmCommandHistoryMapper.getUnclosedValves(jsonArray.toJSONString(), operator); 
 | 
            if(res != null) { 
 | 
                return res; 
 | 
            } else { 
 | 
                return new ArrayList<>(); 
 | 
            } 
 | 
        } else { 
 | 
            QueryResultVo<List<VoOnLineIntake>> rsVo = new QueryResultVo<>(); 
 | 
            return new ArrayList<>(); 
 | 
        } 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 为指定(阀控器地址、水卡编号、无关阀记录)开关阀最新记录添加关阀时间,使之不在未关阀记录中显示 
 | 
     * @param rtuAddr 
 | 
     * @param icCardNo 
 | 
     * @return 
 | 
     */ 
 | 
    public Integer addClostTime(String rtuAddr, String icCardNo) { 
 | 
        return rmOpenCloseValveLastMapper.addCloseTime(rtuAddr, icCardNo); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 根据取水口ID获取与之绑定虚拟卡ID 
 | 
     * @param intakeId 
 | 
     * @return 
 | 
     */ 
 | 
    public Long getVcIdByIntakeId(Long intakeId) { 
 | 
        return prIntakeVcMapper.getVcIdByIntakeId(intakeId); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 根据水卡编号获取水卡对象,远程充值使用 
 | 
     * @param cardId 
 | 
     * @return 
 | 
     */ 
 | 
    public SeClientCard geClientCardByCardId(Long cardId) { 
 | 
        return seClientCardMapper.selectByPrimaryKey(cardId); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 添加命令日志 
 | 
     * @param po 命令日志对象 
 | 
     * @return 字符串类型的主键 
 | 
     */ 
 | 
    public Long insert(RmCommandHistory po) { 
 | 
        rmCommandHistoryMapper.insert(po); 
 | 
        return po.getComId(); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 修改命令日志信息 
 | 
     * @param po 命令日志对象 
 | 
     * @return 影响记录数量 
 | 
     */ 
 | 
    public Integer update(RmCommandHistory po) { 
 | 
        return rmCommandHistoryMapper.updateByPrimaryKeySelective(po); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 取水口名称换取水口ID,扫码开阀使用 
 | 
     * @param intakeName 
 | 
     * @return 
 | 
     */ 
 | 
    public Long getIntakeIdByName(String intakeName) { 
 | 
        return prIntakeMapper.getIntakeIdByName(intakeName); 
 | 
    } 
 | 
  
 | 
    /** 
 | 
     * 根据配置类型获取配置值 
 | 
     * @param type 
 | 
     * @return 
 | 
     */ 
 | 
    QueryResultVo<List<VoIrrigaterProfile>> getIrrPro(Integer type) { 
 | 
        QueryResultVo<List<VoIrrigaterProfile>> rsVo = new QueryResultVo<>() ; 
 | 
        rsVo.obj = rmIrrigateProfileMapper.getIrrPro(type); 
 | 
        return rsVo ; 
 | 
    } 
 | 
  
 | 
} 
 |