-
Notifications
You must be signed in to change notification settings - Fork 22
Expand file tree
/
Copy pathInfoController.java
More file actions
65 lines (54 loc) · 2.49 KB
/
InfoController.java
File metadata and controls
65 lines (54 loc) · 2.49 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
package org.phoebus.channelfinder.rest.controller;
import co.elastic.clients.elasticsearch.ElasticsearchClient;
import co.elastic.clients.elasticsearch._types.ElasticsearchVersionInfo;
import co.elastic.clients.elasticsearch.core.InfoResponse;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.SerializationFeature;
import java.io.IOException;
import java.util.LinkedHashMap;
import java.util.Map;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.phoebus.channelfinder.rest.api.IInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.RestController;
@CrossOrigin
@RestController
@EnableAutoConfiguration
public class InfoController implements IInfo {
private static final Logger logger = Logger.getLogger(InfoController.class.getName());
@Value("${channelfinder.version:4.7.0}")
private String version;
@Autowired private ElasticsearchClient elasticsearchClient;
private static final ObjectMapper objectMapper =
new ObjectMapper().enable(SerializationFeature.INDENT_OUTPUT);
@Override
public String info() {
Map<String, Object> cfServiceInfo = new LinkedHashMap<>();
cfServiceInfo.put("name", "ChannelFinder Service");
cfServiceInfo.put("version", version);
Map<String, String> elasticInfo = new LinkedHashMap<>();
try {
InfoResponse response = elasticsearchClient.info();
elasticInfo.put("status", "Connected");
elasticInfo.put("clusterName", response.clusterName());
elasticInfo.put("clusterUuid", response.clusterUuid());
ElasticsearchVersionInfo elasticVersion = response.version();
elasticInfo.put("version", elasticVersion.number());
} catch (IOException e) {
logger.log(Level.WARNING, "Failed to create ChannelFinder service info resource.", e);
elasticInfo.put("status", "Failed to connect to elastic " + e.getLocalizedMessage());
}
cfServiceInfo.put("elastic", elasticInfo);
try {
return objectMapper.writeValueAsString(cfServiceInfo);
} catch (JsonProcessingException e) {
logger.log(Level.WARNING, "Failed to create ChannelFinder service info resource.", e);
return "Failed to gather ChannelFinder service info";
}
}
}