io.gravitee.management.service.impl.InstanceServiceImpl Maven / Gradle / Ivy
/**
* Copyright (C) 2015 The Gravitee team (http://gravitee.io)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.gravitee.management.service.impl;
import com.fasterxml.jackson.databind.ObjectMapper;
import io.gravitee.management.model.*;
import io.gravitee.management.service.EventService;
import io.gravitee.management.service.InstanceService;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import java.io.IOException;
import java.time.Instant;
import java.time.temporal.ChronoUnit;
import java.util.*;
import java.util.stream.Collectors;
/**
* @author David BRASSELY (brasseld at gmail.com)
* @author GraviteeSource Team
*/
@Component
public class InstanceServiceImpl implements InstanceService {
private static final Logger LOGGER = LoggerFactory.getLogger(InstanceServiceImpl.class);
@Autowired
private EventService eventService;
@Autowired
private ObjectMapper objectMapper;
private static final List instancesAllState = new ArrayList<>();
{
instancesAllState.add(EventType.GATEWAY_STARTED);
instancesAllState.add(EventType.GATEWAY_STOPPED);
}
private static final List instancesRunningOnly = new ArrayList<>();
{
instancesRunningOnly.add(EventType.GATEWAY_STARTED);
}
@Override
public Collection findInstances(boolean includeStopped) {
Set events;
if (includeStopped) {
events = eventService.findByType(instancesAllState);
} else {
events = eventService.findByType(instancesRunningOnly);
}
Instant nowMinusXMinutes = Instant.now().minus(5, ChronoUnit.MINUTES);
return events.stream().map(
event -> {
Map props = event.getProperties();
InstanceListItem instance = new InstanceListItem(props.get("id"));
instance.setEvent(event.getId());
instance.setLastHeartbeatAt(new Date(Long.parseLong(props.get("last_heartbeat_at"))));
instance.setStartedAt(new Date(Long.parseLong(props.get("started_at"))));
if (event.getPayload() != null) {
try {
InstanceInfo info = objectMapper.readValue(event.getPayload(), InstanceInfo.class);
instance.setHostname(info.getHostname());
instance.setIp(info.getIp());
instance.setVersion(info.getVersion());
instance.setTags(info.getTags());
instance.setOperatingSystemName(info.getSystemProperties().get("os.name"));
} catch (IOException ioe) {
LOGGER.error("Unexpected error while getting instance informations from event payload", ioe);
}
}
if (event.getType() == EventType.GATEWAY_STARTED) {
instance.setState(InstanceState.STARTED);
// If last heartbeat timestamp is < now - 5m, set as unknown state
Instant lastHeartbeat = Instant.ofEpochMilli(instance.getLastHeartbeatAt().getTime());
if (lastHeartbeat.isBefore(nowMinusXMinutes)) {
instance.setState(InstanceState.UNKNOWN);
}
} else {
instance.setState(InstanceState.STOPPED);
instance.setStoppedAt(new Date(Long.parseLong(props.get("stopped_at"))));
}
return instance;
}
).collect(Collectors.toList());
}
@Override
public InstanceEntity findById(String eventId) {
EventEntity event = eventService.findById(eventId);
Instant nowMinusXMinutes = Instant.now().minus(5, ChronoUnit.MINUTES);
Map props = event.getProperties();
InstanceEntity instance = new InstanceEntity(props.get("id"));
instance.setLastHeartbeatAt(new Date(Long.parseLong(props.get("last_heartbeat_at"))));
instance.setStartedAt(new Date(Long.parseLong(props.get("started_at"))));
if (event.getPayload() != null) {
try {
InstanceInfo info = objectMapper.readValue(event.getPayload(), InstanceInfo.class);
instance.setHostname(info.getHostname());
instance.setIp(info.getIp());
instance.setVersion(info.getVersion());
instance.setTags(info.getTags());
instance.setSystemProperties(info.getSystemProperties());
instance.setPlugins(info.getPlugins());
} catch (IOException ioe) {
LOGGER.error("Unexpected error while getting instance informations from event payload", ioe);
}
}
if (event.getType() == EventType.GATEWAY_STARTED) {
instance.setState(InstanceState.STARTED);
// If last heartbeat timestamp is < now - 5m, set as unknown state
Instant lastHeartbeat = Instant.ofEpochMilli(instance.getLastHeartbeatAt().getTime());
if (lastHeartbeat.isBefore(nowMinusXMinutes)) {
instance.setState(InstanceState.UNKNOWN);
}
} else {
instance.setState(InstanceState.STOPPED);
instance.setStoppedAt(new Date(Long.parseLong(props.get("stopped_at"))));
}
return instance;
}
private static class InstanceInfo {
private String id;
private String version;
private List tags;
private Set plugins;
private String hostname;
private String ip;
private Map systemProperties;
public String getHostname() {
return hostname;
}
public void setHostname(String hostname) {
this.hostname = hostname;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getIp() {
return ip;
}
public void setIp(String ip) {
this.ip = ip;
}
public Map getSystemProperties() {
return systemProperties;
}
public void setSystemProperties(Map systemProperties) {
this.systemProperties = systemProperties;
}
public List getTags() {
return tags;
}
public void setTags(List tags) {
this.tags = tags;
}
public String getVersion() {
return version;
}
public void setVersion(String version) {
this.version = version;
}
public Set getPlugins() {
return plugins;
}
public void setPlugins(Set plugins) {
this.plugins = plugins;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy