MonitorController.java
4 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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
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;
import java.util.Map;
/**
* 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();
}
@RequestMapping(params = "method=offline.infoScreen.appReportData")
@ResponseBody
public ApiResponse appReportDetail(@RequestParam(value="ip", required=false) String ip
){
AppReportReq req = new AppReportReq().new DataBuilder().setIp(ip).build();
logger.info("in offline.infoScreen.appReportData, req {}", req);
Map<String, AppReportReq> data = monitorService.getAppReport(req);
return new ApiResponse.ApiResponseBuilder().code(200).data(data).message("get appReportData success").build();
}
@RequestMapping(params = "method=offline.infoScreen.heartbeatData")
@ResponseBody
public ApiResponse acceptHeartbeatDetail(@RequestParam(value="ip", required=false) String ip){
InfoScreenHeartBeatPacket.DataBuilder builder = new InfoScreenHeartBeatPacket().new DataBuilder();
InfoScreenHeartBeatPacket packet = builder.setIp(ip).build();
logger.info("in offline.infoScreen.heartbeatData, packet {}", packet);
Map<String,InfoScreenHeartBeatPacket> data = monitorService.getHeartBeat(packet);
return new ApiResponse.ApiResponseBuilder().code(200).data(data).message("get heartbeatData success").build();
}
@RequestMapping(params = "method=showWorkThreads")
@ResponseBody
public ApiResponse showWorkThreads(){
logger.info("in showWorkThreads");
return new ApiResponse.ApiResponseBuilder().code(200)
.data(monitorService.getThreadNodeList()).message("invoke showWorkThreads success").build();
}
}