yangys
2025-11-14 fca5c28c79b061f4db3658f6d9e043024f326962
collect/src/main/java/com/qianwen/mdc/collect/handler/DeviceStatusDataHandler.java
@@ -1,34 +1,28 @@
package com.qianwen.mdc.collect.handler;
import java.util.ArrayList;
import java.util.List;
import java.util.Arrays;
import java.util.Date;
import org.apache.iotdb.tsfile.file.metadata.enums.TSDataType;
import org.apache.iotdb.tsfile.write.record.Tablet;
import org.apache.iotdb.tsfile.write.schema.MeasurementSchema;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import com.qianwen.mdc.collect.cache.WorkstationCache;
import com.qianwen.mdc.collect.config.IotDBSessionConfig;
import com.qianwen.mdc.collect.constants.IOTDBConstant;
import com.qianwen.mdc.collect.dto.PackedTelemetryData;
import com.qianwen.mdc.collect.entity.iotdb.DeviceState;
import com.qianwen.mdc.collect.entity.mgr.GlobalWcsOfRps;
import com.qianwen.mdc.collect.enums.FeedbackTimePointEnum;
import com.qianwen.mdc.collect.service.IotDBCommonService;
import com.qianwen.mdc.collect.service.DeviceStateService;
@Component
public class DeviceStatusDataHandler implements TelemetryDataHandler {
    private static final Logger log = LoggerFactory.getLogger(DeviceStatusDataHandler.class);
    @Autowired
    private WorkstationCache workstationCache;
    @Autowired
   private IotDBSessionConfig iotdbCfg;
    @Autowired
    private IotDBCommonService iotDBCommonService;
    private DeviceStateService deviceStateService;
    @Override
    public void handleData(PackedTelemetryData data) {
       DeviceState state = new DeviceState();
@@ -42,17 +36,23 @@
       state.setIsFixPoint(false);
       state.setIsSync(false);
       state.setIsDeleted(false);
       //state.setEmployeeId(WorkstationCache.getBelongToEmployeeForWorkstation(entity.getWorkstationId(), new Date(entity.getTs().longValue())));
       state.setEmployeeId(workstationCache.getBelongToEmployeeForWorkstation(data.getWorkstationId(), new Date(data.getTime())));
       state.setFeedbackPointType(FeedbackTimePointEnum.NO_FEED_BACK_POINT.getValue());
       //WorkstationState propertyData = (WorkstationState) Objects.requireNonNull(BeanUtil.copy(entity, WorkstationState.class));
       state.setValueCollect(Integer.valueOf(data.getValue()));
       state.setValueCollect(translateStatus(data.getValue()));
       state.setWcs(state.getValueCollect());
       state.setWorkstationId(data.getWorkstationId());
       state.setShiftIndex(data.getShiftIndex());
       state.setShiftTimeType(data.getShiftTimeType());
        fillWorkStationCondition(data, state);
       
        insertState(state);
        deviceStateService.saveDeviceStates(Arrays.asList(state));
        
        log.info("状态聚合聚合完成:数据");
        log.info("设备状态保存完成");
    }
    
    private void fillWorkStationCondition(PackedTelemetryData data, DeviceState state) {
@@ -65,57 +65,34 @@
       
    }
    
    void insertState(DeviceState state){
       String deviceId = IOTDBConstant.DB_PREFIX+IOTDBConstant.TEMPLATE_STATE+"_"+state.getWorkstationId();
       try {
          iotDBCommonService.setTemmplateIfNotSet(IOTDBConstant.TEMPLATE_STATE, deviceId);
          List<MeasurementSchema> schemas = new ArrayList<>();
          schemas.add(new MeasurementSchema("workstation_id", TSDataType.INT64));
          schemas.add(new MeasurementSchema("value_collect", TSDataType.INT32));
          schemas.add(new MeasurementSchema("calendar_code", TSDataType.TEXT));
          schemas.add(new MeasurementSchema("factory_year", TSDataType.INT32));
          schemas.add(new MeasurementSchema("factory_month", TSDataType.INT32));
          schemas.add(new MeasurementSchema("factory_week", TSDataType.INT32));
          schemas.add(new MeasurementSchema("factory_date", TSDataType.INT32));
          schemas.add(new MeasurementSchema("shift_index", TSDataType.INT32));
          schemas.add(new MeasurementSchema("shift_time_type", TSDataType.INT32));
          schemas.add(new MeasurementSchema("wcs", TSDataType.INT32));
          schemas.add(new MeasurementSchema("rps", TSDataType.INT32));
          schemas.add(new MeasurementSchema("is_plan", TSDataType.INT32));
          schemas.add(new MeasurementSchema("feedback_point_type", TSDataType.INT32));
          schemas.add(new MeasurementSchema("feedback_id", TSDataType.INT64));
          schemas.add(new MeasurementSchema("is_deleted", TSDataType.BOOLEAN));
          schemas.add(new MeasurementSchema("employee_id", TSDataType.INT64));
          Tablet tablet = new Tablet(deviceId, schemas);
          int rowIndex = tablet.rowSize++;
          tablet.timestamps[rowIndex] = state.getTime();
          tablet.addValue("workstation_id", rowIndex, state.getWorkstationId());
          tablet.addValue("value_collect", rowIndex, state.getValueCollect());
          tablet.addValue("calendar_code", rowIndex, state.getCalendarCode());
          tablet.addValue("factory_year", rowIndex, state.getFactoryYear());
          tablet.addValue("factory_month", rowIndex, state.getFactoryMonth());
          tablet.addValue("factory_week", rowIndex, state.getFactoryWeek());
          tablet.addValue("factory_date", rowIndex, state.getFactoryDate());
          tablet.addValue("shift_index", rowIndex, state.getShiftIndex());
          tablet.addValue("shift_time_type", rowIndex, state.getShiftTimeType());
          tablet.addValue("wcs", rowIndex, state.getWcs());
          tablet.addValue("rps", rowIndex, state.getRps());
          tablet.addValue("is_plan", rowIndex, state.getIsPlan());
          tablet.addValue("feedback_point_type", rowIndex, state.getFeedbackPointType());
          tablet.addValue("feedback_id", rowIndex, state.getFeedbackId());
          tablet.addValue("is_deleted", rowIndex, state.getIsDeleted());
          tablet.addValue("employee_id", rowIndex, state.getEmployeeId());
          iotdbCfg.getSessionPool().insertAlignedTablet(tablet);
          log.info("状态汇总完成");
      } catch (Exception e) {
         log.error("聚合产量IODDB入库失败", e);
      }
    int translateStatus(String statusVal) {
       int oriStatus = Integer.valueOf(statusVal);
       int result = oriStatus;
       /*
       //西门子828d,   cnc_run_status: 运行状态(0:RESET,1:STOP,2:HOLD,3:START,4:SPENDLE_CW_CCW,5:OTHER)
       switch(oriStatus) {
          case 3://START
             result = 2;
             break;
          case 0://,reset
          case 2://hold
             result = 3;//3待机
             break;
          case 4://   SPENDLE_CW_CCW
             result = 2;
             break;
          case 5://其他
             result = oriStatus;
             break;
          default:
              result = oriStatus;
       }
       log.info("statusconvert,ori={},result={}",oriStatus,result);
       if(result == 0) {
          result = 2;//
       }*/
       return result;
    }
}