net.ravendb.client.documents.operations.indexes.EnableIndexOperation Maven / Gradle / Ivy
package net.ravendb.client.documents.operations.indexes;
import net.ravendb.client.documents.conventions.DocumentConventions;
import net.ravendb.client.documents.operations.IVoidMaintenanceOperation;
import net.ravendb.client.http.IRaftCommand;
import net.ravendb.client.http.ServerNode;
import net.ravendb.client.http.VoidRavenCommand;
import net.ravendb.client.primitives.Reference;
import net.ravendb.client.util.RaftIdGenerator;
import net.ravendb.client.util.UrlUtils;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.client.methods.HttpRequestBase;
public class EnableIndexOperation implements IVoidMaintenanceOperation {
private final String _indexName;
private final boolean _clusterWide;
public EnableIndexOperation(String indexName) {
this(indexName, false);
}
public EnableIndexOperation(String indexName, boolean clusterWide) {
if (indexName == null) {
throw new IllegalArgumentException("IndexName cannot be null");
}
_indexName = indexName;
_clusterWide = clusterWide;
}
@Override
public VoidRavenCommand getCommand(DocumentConventions conventions) {
return new EnableIndexOperation.EnableIndexCommand(_indexName, _clusterWide);
}
private static class EnableIndexCommand extends VoidRavenCommand implements IRaftCommand {
private final String _indexName;
private final boolean _clusterWide;
public EnableIndexCommand(String indexName, boolean clusterWide) {
if (indexName == null) {
throw new IllegalArgumentException("IndexName cannot be null");
}
_indexName = indexName;
_clusterWide = clusterWide;
}
@Override
public HttpRequestBase createRequest(ServerNode node, Reference url) {
url.value = node.getUrl()
+ "/databases/" + node.getDatabase()
+ "/admin/indexes/enable?name=" + UrlUtils.escapeDataString(_indexName)
+ "&clusterWide=" + _clusterWide;
return new HttpPost();
}
@Override
public String getRaftUniqueRequestId() {
return RaftIdGenerator.newId();
}
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy