org.elasticsearch.xpack.core.ccr.CCRFeatureSet Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of x-pack-core Show documentation
Show all versions of x-pack-core Show documentation
Elasticsearch Expanded Pack Plugin - Core
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0; you may not use this file except in compliance with the Elastic License
* 2.0.
*/
package org.elasticsearch.xpack.core.ccr;
import org.elasticsearch.Version;
import org.elasticsearch.action.ActionListener;
import org.elasticsearch.cluster.metadata.IndexMetadata;
import org.elasticsearch.cluster.metadata.Metadata;
import org.elasticsearch.cluster.service.ClusterService;
import org.elasticsearch.common.Nullable;
import org.elasticsearch.common.inject.Inject;
import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.StreamOutput;
import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.license.XPackLicenseState;
import org.elasticsearch.xpack.core.XPackFeatureSet;
import org.elasticsearch.xpack.core.XPackField;
import org.elasticsearch.xpack.core.XPackSettings;
import java.io.IOException;
import java.time.Instant;
import java.util.Map;
import java.util.Objects;
public class CCRFeatureSet implements XPackFeatureSet {
private final boolean enabled;
private final XPackLicenseState licenseState;
private final ClusterService clusterService;
@Inject
public CCRFeatureSet(Settings settings, @Nullable XPackLicenseState licenseState, ClusterService clusterService) {
this.enabled = XPackSettings.CCR_ENABLED_SETTING.get(settings);
this.licenseState = licenseState;
this.clusterService = clusterService;
}
@Override
public String name() {
return XPackField.CCR;
}
@Override
public boolean available() {
return licenseState != null && licenseState.isAllowed(XPackLicenseState.Feature.CCR);
}
@Override
public boolean enabled() {
return enabled;
}
@Override
public Map nativeCodeInfo() {
return null;
}
@Override
public void usage(ActionListener listener) {
Metadata metadata = clusterService.state().metadata();
int numberOfFollowerIndices = 0;
long lastFollowerIndexCreationDate = 0L;
for (IndexMetadata imd : metadata) {
if (imd.getCustomData("ccr") != null) {
numberOfFollowerIndices++;
if (lastFollowerIndexCreationDate < imd.getCreationDate()) {
lastFollowerIndexCreationDate = imd.getCreationDate();
}
}
}
AutoFollowMetadata autoFollowMetadata = metadata.custom(AutoFollowMetadata.TYPE);
int numberOfAutoFollowPatterns = autoFollowMetadata != null ? autoFollowMetadata.getPatterns().size() : 0;
Long lastFollowTimeInMillis;
if (numberOfFollowerIndices == 0) {
// Otherwise we would return a value that makes no sense.
lastFollowTimeInMillis = null;
} else {
lastFollowTimeInMillis = Math.max(0, Instant.now().toEpochMilli() - lastFollowerIndexCreationDate);
}
Usage usage =
new Usage(available(), enabled(), numberOfFollowerIndices, numberOfAutoFollowPatterns, lastFollowTimeInMillis);
listener.onResponse(usage);
}
public static class Usage extends XPackFeatureSet.Usage {
private final int numberOfFollowerIndices;
private final int numberOfAutoFollowPatterns;
private final Long lastFollowTimeInMillis;
public Usage(boolean available,
boolean enabled,
int numberOfFollowerIndices,
int numberOfAutoFollowPatterns,
Long lastFollowTimeInMillis) {
super(XPackField.CCR, available, enabled);
this.numberOfFollowerIndices = numberOfFollowerIndices;
this.numberOfAutoFollowPatterns = numberOfAutoFollowPatterns;
this.lastFollowTimeInMillis = lastFollowTimeInMillis;
}
public Usage(StreamInput in) throws IOException {
super(in);
numberOfFollowerIndices = in.readVInt();
numberOfAutoFollowPatterns = in.readVInt();
if (in.readBoolean()) {
lastFollowTimeInMillis = in.readVLong();
} else {
lastFollowTimeInMillis = null;
}
}
@Override
public Version getMinimalSupportedVersion() {
return Version.V_6_7_0;
}
public int getNumberOfFollowerIndices() {
return numberOfFollowerIndices;
}
public int getNumberOfAutoFollowPatterns() {
return numberOfAutoFollowPatterns;
}
public Long getLastFollowTimeInMillis() {
return lastFollowTimeInMillis;
}
@Override
public void writeTo(StreamOutput out) throws IOException {
super.writeTo(out);
out.writeVInt(numberOfFollowerIndices);
out.writeVInt(numberOfAutoFollowPatterns);
if (lastFollowTimeInMillis != null) {
out.writeBoolean(true);
out.writeVLong(lastFollowTimeInMillis);
} else {
out.writeBoolean(false);
}
}
@Override
protected void innerXContent(XContentBuilder builder, Params params) throws IOException {
super.innerXContent(builder, params);
builder.field("follower_indices_count", numberOfFollowerIndices);
builder.field("auto_follow_patterns_count", numberOfAutoFollowPatterns);
if (lastFollowTimeInMillis != null) {
builder.field("last_follow_time_in_millis", lastFollowTimeInMillis);
}
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Usage usage = (Usage) o;
return numberOfFollowerIndices == usage.numberOfFollowerIndices &&
numberOfAutoFollowPatterns == usage.numberOfAutoFollowPatterns &&
Objects.equals(lastFollowTimeInMillis, usage.lastFollowTimeInMillis);
}
@Override
public int hashCode() {
return Objects.hash(numberOfFollowerIndices, numberOfAutoFollowPatterns, lastFollowTimeInMillis);
}
}
}