org.graylog2.indexer.cluster.ClusterAdapter Maven / Gradle / Ivy
/*
* Copyright (C) 2020 Graylog, Inc.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the Server Side Public License, version 1,
* as published by MongoDB, Inc.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* Server Side Public License for more details.
*
* You should have received a copy of the Server Side Public License
* along with this program. If not, see
* .
*/
package org.graylog2.indexer.cluster;
import org.graylog2.indexer.cluster.health.ClusterAllocationDiskSettings;
import org.graylog2.indexer.cluster.health.NodeDiskUsageStats;
import org.graylog2.indexer.cluster.health.NodeFileDescriptorStats;
import org.graylog2.indexer.indices.HealthStatus;
import org.graylog2.rest.models.system.indexer.responses.ClusterHealth;
import org.graylog2.system.stats.elasticsearch.ClusterStats;
import org.graylog2.system.stats.elasticsearch.ShardStats;
import java.util.Collection;
import java.util.Optional;
import java.util.Set;
public interface ClusterAdapter {
Optional health(Collection indices);
Set fileDescriptorStats();
Set diskUsageStats();
ClusterAllocationDiskSettings clusterAllocationDiskSettings();
Optional nodeIdToName(String nodeId);
Optional nodeIdToHostName(String nodeId);
boolean isConnected();
Optional clusterName(Collection indices);
Optional clusterHealthStats(Collection indices);
ClusterStats clusterStats();
PendingTasksStats pendingTasks();
ShardStats shardStats(Collection indices);
}