/* * 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.state; import org.elasticsearch.action.ActionListener; import org.elasticsearch.action.support.nodes.NodesOperationRequestBuilder; import org.elasticsearch.client.ClusterAdminClient; /** * Request builder to get state of some Remote river. * * @author Vlastimil Elias (velias at redhat dot com) */ public class JRStateRequestBuilder extends NodesOperationRequestBuilder<JRStateRequest, JRStateResponse, JRStateRequestBuilder> { public JRStateRequestBuilder(ClusterAdminClient client) { super(client, new JRStateRequest()); } /** * Set name of river to get state for. * * @param riverName name of river to force full index update for * @return builder for chaining */ public JRStateRequestBuilder setRiverName(String riverName) { this.request.setRiverName(riverName); return this; } @Override protected void doExecute(ActionListener<JRStateResponse> listener) { if (request.getRiverName() == null) throw new IllegalArgumentException("riverName must be provided for request"); client.execute(JRStateAction.INSTANCE, request, listener); } }