All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.elasticsearch.snapshots.RestoreInfo Maven / Gradle / Ivy

There is a newer version: 8.13.4
Show newest version
/*
 * 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 and the Server Side Public License, v 1; you may not use this file except
 * in compliance with, at your election, the Elastic License 2.0 or the Server
 * Side Public License, v 1.
 */
package org.elasticsearch.snapshots;

import org.elasticsearch.common.Strings;
import org.elasticsearch.common.io.stream.StreamInput;
import org.elasticsearch.common.io.stream.StreamOutput;
import org.elasticsearch.common.io.stream.Writeable;
import org.elasticsearch.rest.RestStatus;
import org.elasticsearch.xcontent.ObjectParser;
import org.elasticsearch.xcontent.ParseField;
import org.elasticsearch.xcontent.ToXContentObject;
import org.elasticsearch.xcontent.XContentBuilder;
import org.elasticsearch.xcontent.XContentParser;

import java.io.IOException;
import java.util.Collections;
import java.util.List;
import java.util.Objects;

/**
 * Information about successfully completed restore operation.
 * 

* Returned as part of {@link org.elasticsearch.action.admin.cluster.snapshots.restore.RestoreSnapshotResponse} */ public class RestoreInfo implements ToXContentObject, Writeable { private String name; private List indices; private int totalShards; private int successfulShards; RestoreInfo() {} public RestoreInfo(String name, List indices, int totalShards, int successfulShards) { this.name = name; this.indices = indices; this.totalShards = totalShards; this.successfulShards = successfulShards; } public RestoreInfo(StreamInput in) throws IOException { name = in.readString(); indices = Collections.unmodifiableList(in.readStringList()); totalShards = in.readVInt(); successfulShards = in.readVInt(); } /** * Snapshot name * * @return snapshot name */ public String name() { return name; } /** * List of restored indices * * @return list of restored indices */ public List indices() { return indices; } /** * Number of shards being restored * * @return number of being restored */ public int totalShards() { return totalShards; } /** * Number of failed shards * * @return number of failed shards */ public int failedShards() { return totalShards - successfulShards; } /** * Number of successful shards * * @return number of successful shards */ public int successfulShards() { return successfulShards; } /** * REST status of the operation * * @return REST status */ public RestStatus status() { return RestStatus.OK; } static final class Fields { static final String SNAPSHOT = "snapshot"; static final String INDICES = "indices"; static final String SHARDS = "shards"; static final String TOTAL = "total"; static final String FAILED = "failed"; static final String SUCCESSFUL = "successful"; } @Override public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException { builder.startObject(); builder.field(Fields.SNAPSHOT, name); builder.startArray(Fields.INDICES); for (String index : indices) { builder.value(index); } builder.endArray(); builder.startObject(Fields.SHARDS); builder.field(Fields.TOTAL, totalShards); builder.field(Fields.FAILED, failedShards()); builder.field(Fields.SUCCESSFUL, successfulShards); builder.endObject(); builder.endObject(); return builder; } private static final ObjectParser PARSER = new ObjectParser<>(RestoreInfo.class.getName(), true, RestoreInfo::new); static { ObjectParser shardsParser = new ObjectParser<>("shards", true, null); shardsParser.declareInt((r, s) -> r.totalShards = s, new ParseField(Fields.TOTAL)); shardsParser.declareInt((r, s) -> { /* only consume, don't set */ }, new ParseField(Fields.FAILED)); shardsParser.declareInt((r, s) -> r.successfulShards = s, new ParseField(Fields.SUCCESSFUL)); PARSER.declareString((r, n) -> r.name = n, new ParseField(Fields.SNAPSHOT)); PARSER.declareStringArray((r, i) -> r.indices = i, new ParseField(Fields.INDICES)); PARSER.declareField(shardsParser::parse, new ParseField(Fields.SHARDS), ObjectParser.ValueType.OBJECT); } public static RestoreInfo fromXContent(XContentParser parser) throws IOException { return PARSER.parse(parser, null); } @Override public void writeTo(StreamOutput out) throws IOException { out.writeString(name); out.writeStringCollection(indices); out.writeVInt(totalShards); out.writeVInt(successfulShards); } /** * Reads optional restore info from {@link StreamInput} * * @param in stream input * @return restore info */ public static RestoreInfo readOptionalRestoreInfo(StreamInput in) throws IOException { return in.readOptionalWriteable(RestoreInfo::new); } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; RestoreInfo that = (RestoreInfo) o; return totalShards == that.totalShards && successfulShards == that.successfulShards && Objects.equals(name, that.name) && Objects.equals(indices, that.indices); } @Override public int hashCode() { return Objects.hash(name, indices, totalShards, successfulShards); } @Override public String toString() { return Strings.toString(this); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy