AlarmAdasController.java 2.19 KB
package com.bsth.controller.alaram;

import com.bsth.common.ResponseCode;
import com.bsth.message.entity.AlarmADASVo;
import com.bsth.service.alarm.AlarmAdasService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.*;

@RestController
@RequestMapping("alarm_adas")
public class AlarmAdasController {

    private final static Logger log = LoggerFactory.getLogger(AlarmAdasController.class);

    @Autowired
    private AlarmAdasService alarmAdasService;

    @RequestMapping(value = "/list")
    public Map<String, Object> list(@RequestParam Map<String, String> param,
                                    @RequestParam(defaultValue = "0") int page,
                                    @RequestParam(defaultValue = "15") int size,
                                    @RequestParam(defaultValue = "timestamp") String order,
                                    @RequestParam(defaultValue = "0") int direction) {
        Map<String, Object> result = new HashMap<>();
        try {
            List<AlarmADASVo> alarmADASVoList = alarmAdasService.list(param, page, size, order, direction);
            Collections.sort(alarmADASVoList, new Comparator<AlarmADASVo>() {
                @Override
                public int compare(AlarmADASVo o1, AlarmADASVo o2) {
                    return (int) (o2.getAlarmTimeBegin() - o1.getAlarmTimeBegin());
                }
            });
            int total = alarmADASVoList.size(), start = page * size, end = start + size;
            if (end > total) {
                end = total;
            }
            result.put("list", alarmADASVoList.subList(start, end));
            result.put("totalPages", total % size == 0 ? total / size - 1 : total / size);
            result.put("page", page);
            result.put("status", ResponseCode.SUCCESS);
        } catch (Exception e) {
            result.put("status", ResponseCode.ERROR);
            log.error(e.getMessage(), e);
        }

        return result;
    }
}