org.apache.solr.handler.admin.api.ListCollectionSnapshotsAPI Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of solr-core Show documentation
Show all versions of solr-core Show documentation
Apache Solr (module: core)
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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.apache.solr.handler.admin.api;
import static org.apache.solr.client.solrj.impl.BinaryResponseParser.BINARY_CONTENT_TYPE_V2;
import static org.apache.solr.security.PermissionNameProvider.Name.COLL_READ_PERM;
import com.fasterxml.jackson.annotation.JsonProperty;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.media.Schema;
import jakarta.inject.Inject;
import jakarta.ws.rs.GET;
import jakarta.ws.rs.Path;
import jakarta.ws.rs.PathParam;
import jakarta.ws.rs.Produces;
import java.util.Collection;
import java.util.Map;
import org.apache.solr.client.api.model.AsyncJerseyResponse;
import org.apache.solr.common.cloud.SolrZkClient;
import org.apache.solr.common.util.CollectionUtil;
import org.apache.solr.core.CoreContainer;
import org.apache.solr.core.snapshots.CollectionSnapshotMetaData;
import org.apache.solr.core.snapshots.SolrSnapshotManager;
import org.apache.solr.jersey.PermissionName;
import org.apache.solr.request.SolrQueryRequest;
import org.apache.solr.response.SolrQueryResponse;
/** V2 API for Listing Collection Snapshots. */
@Path("/collections/{collName}/snapshots")
public class ListCollectionSnapshotsAPI extends AdminAPIBase {
@Inject
public ListCollectionSnapshotsAPI(
CoreContainer coreContainer,
SolrQueryRequest solrQueryRequest,
SolrQueryResponse solrQueryResponse) {
super(coreContainer, solrQueryRequest, solrQueryResponse);
}
/** This API is analogous to V1's (POST /solr/admin/collections?action=LISTSNAPSHOTS) */
@GET
@Produces({"application/json", "application/xml", BINARY_CONTENT_TYPE_V2})
@PermissionName(COLL_READ_PERM)
public ListSnapshotsResponse listSnapshots(
@Parameter(description = "The name of the collection.", required = true)
@PathParam("collName")
String collName)
throws Exception {
final ListSnapshotsResponse response = instantiateJerseyResponse(ListSnapshotsResponse.class);
final CoreContainer coreContainer = fetchAndValidateZooKeeperAwareCoreContainer();
recordCollectionForLogAndTracing(collName, solrQueryRequest);
final String collectionName = resolveCollectionName(collName, true);
SolrZkClient client = coreContainer.getZkController().getZkClient();
Collection m =
SolrSnapshotManager.listSnapshots(client, collectionName);
Map snapshots = CollectionUtil.newHashMap(m.size());
for (CollectionSnapshotMetaData metaData : m) {
snapshots.put(metaData.getName(), metaData);
}
response.snapshots = snapshots;
return response;
}
/** The Response for {@link ListCollectionSnapshotsAPI}'s {@link #listSnapshots(String)} */
public static class ListSnapshotsResponse extends AsyncJerseyResponse {
@Schema(description = "The snapshots for the collection.")
@JsonProperty(SolrSnapshotManager.SNAPSHOTS_INFO)
public Map snapshots;
}
}