WuweiZoneScheduler.java 1.99 KB
package com.iot.scheduler.zone;

import com.iot.scheduler.service.wuwei.JmDevicePullService;
import com.iot.scheduler.service.wuwei.SyDevicePullService;
import com.iot.scheduler.service.wuwei.WWDeviceReportService;
import com.iot.scheduler.task.AbstractZoneScheduler;
import jakarta.annotation.Resource;
import lombok.extern.slf4j.Slf4j;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;

/**
 * 无为金马设备同步
 */
@Slf4j
@Component
public class WuweiZoneScheduler extends AbstractZoneScheduler {

    @Resource
    private JmDevicePullService jmDevicePullService;
    @Resource
    private WWDeviceReportService wwDeviceReportService;
    @Resource
    private SyDevicePullService syDevicePullService;

    @Override
    protected String getZoneName() {
        return "WuWei (无为园区)";
    }

    @Scheduled(cron = "${scheduler.jmdq.pull:0 0/1 * * * ?}")
    public void pullDevicesFromThirdParty() {
        String taskName = "Pull Devices (3rd Party -> IoT)";
        logStart(taskName);
        try {
            // TODO: Implement actual logic
            log.info("[{}] Simulating pulling devices...", getZoneName());
            jmDevicePullService.pullDeviceAndPushToIot();
            jmDevicePullService.pullCreateDeviceInfo();
            syDevicePullService.pullDeviceAndPushToIot();;
            Thread.sleep(1000);
        } catch (Exception e) {
            logError(taskName, e);
        } finally {
            logEnd(taskName);
        }
    }

    @Scheduled(cron = "${scheduler.jmdq.push:0 0/10 * * * ?}")
    public void pushJmDevicesToThirdParty() {
        String taskName = "PJ Devices (IoT -> 3rd Party)";
        logStart(taskName);
        try {
            log.info("[{}] PJ pushing devices...", getZoneName());
            wwDeviceReportService.deviceReport();
            Thread.sleep(1000);
        } catch (Exception e) {
            logError(taskName, e);
        } finally {
            logEnd(taskName);
        }
    }
}