MonitorController.java
2.41 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
package com.yoho.rfid.controller;
import com.yoho.rfid.model.req.AppReportReq;
import com.yoho.rfid.model.req.InfoScreenHeartBeatPacket;
import com.yoho.rfid.service.MonitorService;
import com.yoho.rfid.util.ApiResponse;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
/**
* Created by chenchao on 2017/10/16.
*/
@Controller
public class MonitorController {
private Logger logger = LoggerFactory.getLogger(getClass());
@Autowired
private MonitorService monitorService;
@RequestMapping(params = "method=offline.infoScreen.heartbeat")
@ResponseBody
public ApiResponse accept(@RequestParam(value="ip", required=true) String ip,
@RequestParam(value="mac", required=false) String mac,
@RequestParam(value="screenType", required=true) Integer screenType){
InfoScreenHeartBeatPacket.DataBuilder builder = new InfoScreenHeartBeatPacket().new DataBuilder();
InfoScreenHeartBeatPacket packet = builder.setIp(ip).setMac(mac).setScreenType(screenType).build();
logger.info("in offline.infoScreen.heartbeat, packet {}", packet);
monitorService.acceptHeartBeat(packet);
return new ApiResponse.ApiResponseBuilder().code(200).message("accept success").build();
}
@RequestMapping(params = "method=offline.infoScreen.appReport")
@ResponseBody
public ApiResponse appReport(@RequestParam(value="ip", required=true) String ip,
@RequestParam(value="mac", required=false) String mac,
@RequestParam(value="screenType", required=false) Integer screenType,
@RequestParam(value="event") String eventName){
AppReportReq req = new AppReportReq().new DataBuilder().setIp(ip).setMac(mac)
.setScreenType(screenType).setEventName(eventName).build();
logger.info("in offline.infoScreen.appReport, req {}", req);
monitorService.acceptAppReport(req);
return new ApiResponse.ApiResponseBuilder().code(200).message("accept success").build();
}
}