ChizhouZoneScheduler.java 2.03 KB
package com.iot.scheduler.zone;

import com.iot.scheduler.service.*;
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 ChizhouZoneScheduler extends AbstractZoneScheduler {

    @Resource
    private HnDeviceReportService hnDeviceReportService;
    @Resource
    private ShDevicePullService shDevicePullService;
    @Resource
    private SlDevicePullService slDevicePullService;
    @Resource
    private GhDevicePullService ghDevicePullService;
    @Resource
    private ShzzDevicePullService shzzDevicePullService;

    @Override
    protected String getZoneName() {
        return "Huaining (怀宁经开区)";
    }

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

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