/*
* JBoss, Home of Professional Open Source
* Copyright 2012 Red Hat Inc. and/or its affiliates and other contributors
* as indicated by the @authors tag. All rights reserved.
*/
package org.jboss.elasticsearch.river.remote.mgm.lifecycle;
import org.elasticsearch.action.ActionListener;
import org.elasticsearch.action.support.nodes.NodesOperationRequestBuilder;
import org.elasticsearch.client.ClusterAdminClient;
/**
* Request builder to perform lifecycle method of some Remote river.
*
* @author Vlastimil Elias (velias at redhat dot com)
*/
public class JRLifecycleRequestBuilder extends
NodesOperationRequestBuilder<JRLifecycleRequest, JRLifecycleResponse, JRLifecycleRequestBuilder> {
public JRLifecycleRequestBuilder(ClusterAdminClient client) {
super(client, new JRLifecycleRequest());
}
/**
* Set name of river to get state for.
*
* @param riverName name of river to force full index update for
* @return builder for chaining
*/
public JRLifecycleRequestBuilder setRiverName(String riverName) {
this.request.setRiverName(riverName);
return this;
}
/**
* Set command to request.
*
* @param command to be set
* @return builder for chaining
*/
public JRLifecycleRequestBuilder setCommand(JRLifecycleCommand command) {
this.request.setCommand(command);
return this;
}
@Override
protected void doExecute(ActionListener<JRLifecycleResponse> listener) {
if (request.getRiverName() == null)
throw new IllegalArgumentException("riverName must be provided for request");
if (request.getCommand() == null)
throw new IllegalArgumentException("command must be provided for request");
client.execute(JRLifecycleAction.INSTANCE, request, listener);
}
}