package org.fastcatsearch.http.action.management.indexing; import java.io.Writer; import org.fastcatsearch.cluster.Node; import org.fastcatsearch.cluster.NodeService; import org.fastcatsearch.control.ResultFuture; import org.fastcatsearch.http.ActionAuthority; import org.fastcatsearch.http.ActionAuthorityLevel; import org.fastcatsearch.http.ActionMapping; import org.fastcatsearch.http.action.ActionRequest; import org.fastcatsearch.http.action.ActionResponse; import org.fastcatsearch.http.action.AuthAction; import org.fastcatsearch.ir.IRService; import org.fastcatsearch.ir.config.CollectionContext; import org.fastcatsearch.job.indexing.CollectionDatasourceDumpJob; import org.fastcatsearch.service.ServiceManager; import org.fastcatsearch.util.ResponseWriter; @ActionMapping(value = "/datasource/full/dump", authority = ActionAuthority.Collections, authorityLevel = ActionAuthorityLevel.WRITABLE ) public class RunFullDatasourceDumpAction extends AuthAction { @Override public void doAuthAction(ActionRequest request, ActionResponse response) throws Exception { String collectionId = request.getParameter("collectionId"); IRService irService = ServiceManager.getInstance().getService(IRService.class); CollectionContext collectionContext = irService.collectionContext(collectionId); String indexNodeId = collectionContext.collectionConfig().getIndexNode(); NodeService nodeService = ServiceManager.getInstance().getService(NodeService.class); Node indexNode = nodeService.getNodeById(indexNodeId); CollectionDatasourceDumpJob job = new CollectionDatasourceDumpJob(); job.setArgs(collectionId); ResultFuture jobResult = nodeService.sendRequest(indexNode, job); Writer writer = response.getWriter(); ResponseWriter resultWriter = getDefaultResponseWriter(writer); resultWriter .object() .key("collectionId").value(collectionId); if(jobResult != null){ resultWriter.key("status").value("0"); }else{ resultWriter.key("status").value("1"); } resultWriter.endObject(); resultWriter.done(); } }