All Downloads are FREE. Search and download functionalities are using the official Maven repository.
Please wait. This can take some minutes ...
Many resources are needed to download a project. Please understand that we have to compensate our server costs. Thank you in advance.
Project price only 1 $
You can buy this project and download/modify it how often you want.
org.elasticsearch.xpack.core.transform.action.GetTransformStatsAction Maven / Gradle / Ivy
/*
* 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.transform.action;
import org.elasticsearch.ElasticsearchException;
import org.elasticsearch.Version;
import org.elasticsearch.action.ActionRequestValidationException;
import org.elasticsearch.action.ActionType;
import org.elasticsearch.action.TaskOperationFailure;
import org.elasticsearch.action.support.tasks.BaseTasksRequest;
import org.elasticsearch.action.support.tasks.BaseTasksResponse;
import org.elasticsearch.cluster.metadata.Metadata;
import org.elasticsearch.common.Strings;
import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.StreamOutput;
import org.elasticsearch.common.xcontent.ToXContentObject;
import org.elasticsearch.common.xcontent.XContentBuilder;
import org.elasticsearch.tasks.Task;
import org.elasticsearch.xpack.core.action.util.PageParams;
import org.elasticsearch.xpack.core.action.util.QueryPage;
import org.elasticsearch.xpack.core.transform.TransformField;
import org.elasticsearch.xpack.core.transform.transforms.TransformStats;
import org.elasticsearch.xpack.core.transform.utils.ExceptionsHelper;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Objects;
import static org.elasticsearch.action.ValidateActions.addValidationError;
public class GetTransformStatsAction extends ActionType {
public static final GetTransformStatsAction INSTANCE = new GetTransformStatsAction();
public static final String NAME = "cluster:monitor/transform/stats/get";
public GetTransformStatsAction() {
super(NAME, GetTransformStatsAction.Response::new);
}
public static class Request extends BaseTasksRequest {
private final String id;
private PageParams pageParams = PageParams.defaultParams();
private boolean allowNoMatch = true;
public static final int MAX_SIZE_RETURN = 1000;
// used internally to expand the queried id expression
private List expandedIds;
public Request(String id) {
if (Strings.isNullOrEmpty(id) || id.equals("*")) {
this.id = Metadata.ALL;
} else {
this.id = id;
}
this.expandedIds = Collections.singletonList(id);
}
public Request(StreamInput in) throws IOException {
super(in);
id = in.readString();
expandedIds = Collections.unmodifiableList(in.readStringList());
pageParams = new PageParams(in);
if (in.getVersion().onOrAfter(Version.V_7_3_0)) {
allowNoMatch = in.readBoolean();
}
}
@Override
public boolean match(Task task) {
// Only get tasks that we have expanded to
return expandedIds.stream()
.anyMatch(transformId -> task.getDescription().equals(TransformField.PERSISTENT_TASK_DESCRIPTION_PREFIX + transformId));
}
public String getId() {
return id;
}
public List getExpandedIds() {
return expandedIds;
}
public void setExpandedIds(List expandedIds) {
this.expandedIds = Collections.unmodifiableList(new ArrayList<>(expandedIds));
}
public final void setPageParams(PageParams pageParams) {
this.pageParams = Objects.requireNonNull(pageParams);
}
public final PageParams getPageParams() {
return pageParams;
}
public boolean isAllowNoMatch() {
return allowNoMatch;
}
public void setAllowNoMatch(boolean allowNoMatch) {
this.allowNoMatch = allowNoMatch;
}
@Override
public void writeTo(StreamOutput out) throws IOException {
super.writeTo(out);
out.writeString(id);
out.writeStringCollection(expandedIds);
pageParams.writeTo(out);
if (out.getVersion().onOrAfter(Version.V_7_3_0)) {
out.writeBoolean(allowNoMatch);
}
}
@Override
public ActionRequestValidationException validate() {
ActionRequestValidationException exception = null;
if (getPageParams() != null && getPageParams().getSize() > MAX_SIZE_RETURN) {
exception = addValidationError(
"Param [" + PageParams.SIZE.getPreferredName() + "] has a max acceptable value of [" + MAX_SIZE_RETURN + "]",
exception
);
}
return exception;
}
@Override
public int hashCode() {
return Objects.hash(id, pageParams, allowNoMatch);
}
@Override
public boolean equals(Object obj) {
if (obj == null) {
return false;
}
if (getClass() != obj.getClass()) {
return false;
}
Request other = (Request) obj;
return Objects.equals(id, other.id) && Objects.equals(pageParams, other.pageParams) && allowNoMatch == other.allowNoMatch;
}
}
public static class Response extends BaseTasksResponse implements ToXContentObject {
private final QueryPage transformsStats;
public Response(List transformStateAndStats, long count) {
this(new QueryPage<>(transformStateAndStats, count, TransformField.TRANSFORMS));
}
public Response(
List transformStateAndStats,
long count,
List taskFailures,
List nodeFailures
) {
this(new QueryPage<>(transformStateAndStats, count, TransformField.TRANSFORMS), taskFailures, nodeFailures);
}
private Response(QueryPage transformsStats) {
this(transformsStats, Collections.emptyList(), Collections.emptyList());
}
private Response(
QueryPage transformsStats,
List taskFailures,
List nodeFailures
) {
super(taskFailures, nodeFailures);
this.transformsStats = ExceptionsHelper.requireNonNull(transformsStats, "transformsStats");
}
public Response(StreamInput in) throws IOException {
super(in);
if (in.getVersion().onOrAfter(Version.V_7_3_0)) {
transformsStats = new QueryPage<>(in, TransformStats::new);
} else {
List stats = in.readList(TransformStats::new);
transformsStats = new QueryPage<>(stats, stats.size(), TransformField.TRANSFORMS);
}
}
public List getTransformsStats() {
return transformsStats.results();
}
public long getCount() {
return transformsStats.count();
}
@Override
public void writeTo(StreamOutput out) throws IOException {
super.writeTo(out);
if (out.getVersion().onOrAfter(Version.V_7_3_0)) {
transformsStats.writeTo(out);
} else {
out.writeList(transformsStats.results());
}
}
@Override
public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException {
builder.startObject();
toXContentCommon(builder, params);
transformsStats.doXContentBody(builder, params);
builder.endObject();
return builder;
}
@Override
public int hashCode() {
return Objects.hash(transformsStats);
}
@Override
public boolean equals(Object other) {
if (this == other) {
return true;
}
if (other == null || getClass() != other.getClass()) {
return false;
}
final Response that = (Response) other;
return Objects.equals(this.transformsStats, that.transformsStats);
}
@Override
public final String toString() {
return Strings.toString(this);
}
}
}