/* * Licensed to Elasticsearch under one or more contributor * license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright * ownership. Elasticsearch licenses this file to you 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 org.elasticsearch.action.admin.cluster.snapshots.get; import org.elasticsearch.action.support.master.MasterNodeOperationRequestBuilder; import org.elasticsearch.client.ElasticsearchClient; import org.elasticsearch.common.util.ArrayUtils; /** * Get snapshots request builder */ public class GetSnapshotsRequestBuilder extends MasterNodeOperationRequestBuilder<GetSnapshotsRequest, GetSnapshotsResponse, GetSnapshotsRequestBuilder> { /** * Constructs the new get snapshot request */ public GetSnapshotsRequestBuilder(ElasticsearchClient client, GetSnapshotsAction action) { super(client, action, new GetSnapshotsRequest()); } /** * Constructs the new get snapshot request with specified repository */ public GetSnapshotsRequestBuilder(ElasticsearchClient client, GetSnapshotsAction action, String repository) { super(client, action, new GetSnapshotsRequest(repository)); } /** * Sets the repository name * * @param repository repository name * @return this builder */ public GetSnapshotsRequestBuilder setRepository(String repository) { request.repository(repository); return this; } /** * Sets list of snapshots to return * * @param snapshots list of snapshots * @return this builder */ public GetSnapshotsRequestBuilder setSnapshots(String... snapshots) { request.snapshots(snapshots); return this; } /** * Makes the request to return the current snapshot * * @return this builder */ public GetSnapshotsRequestBuilder setCurrentSnapshot() { request.snapshots(new String[]{GetSnapshotsRequest.CURRENT_SNAPSHOT}); return this; } /** * Adds additional snapshots to the list of snapshots to return * * @param snapshots additional snapshots * @return this builder */ public GetSnapshotsRequestBuilder addSnapshots(String... snapshots) { request.snapshots(ArrayUtils.concat(request.snapshots(), snapshots)); return this; } /** * Makes the request ignore unavailable snapshots * * @param ignoreUnavailable true to ignore unavailable snapshots. * @return this builder */ public GetSnapshotsRequestBuilder setIgnoreUnavailable(boolean ignoreUnavailable) { request.ignoreUnavailable(ignoreUnavailable); return this; } /** * Set to {@code false} to only show the snapshot names and the indices they contain. * This is useful when the snapshots belong to a cloud-based repository where each * blob read is a concern (cost wise and performance wise), as the snapshot names and * indices they contain can be retrieved from a single index blob in the repository, * whereas the rest of the information requires reading a snapshot metadata file for * each snapshot requested. Defaults to {@code true}, which returns all information * about each requested snapshot. */ public GetSnapshotsRequestBuilder setVerbose(boolean verbose) { request.verbose(verbose); return this; } }