All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.solr.client.solrj.request.NodeApi Maven / Gradle / Ivy

There is a newer version: 9.8.1
Show newest version
/*
 * 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.client.solrj.request;

import org.apache.solr.client.api.model.DeleteNodeRequestBody;
import org.apache.solr.client.api.model.PublicKeyResponse;
import org.apache.solr.client.api.model.ReplaceNodeRequestBody;
import org.apache.solr.client.api.model.SolrJerseyResponse;
import org.apache.solr.client.solrj.JacksonContentWriter;
import org.apache.solr.client.solrj.JacksonParsingResponse;
import org.apache.solr.client.solrj.ResponseParser;
import org.apache.solr.client.solrj.SolrClient;
import org.apache.solr.client.solrj.SolrRequest;
import org.apache.solr.client.solrj.impl.InputStreamResponseParser;
import org.apache.solr.common.params.ModifiableSolrParams;
import org.apache.solr.common.params.SolrParams;

// WARNING: This class is generated from a Mustache template; any intended
// changes should be made to the underlying template and not this file directly.

public class NodeApi {

  public static class DeleteNodeResponse extends JacksonParsingResponse {
    public DeleteNodeResponse() {
      super(SolrJerseyResponse.class);
    }
  }

  public static class DeleteNode extends SolrRequest {
    private final DeleteNodeRequestBody requestBody;
    private final String nodeName;

    /**
     * Create a DeleteNode request object.
     *
     * @param nodeName Path param - The name of the node to be cleared. Usually of the form
     *     'host:1234_solr'.
     */
    public DeleteNode(String nodeName) {
      super(
          SolrRequest.METHOD.valueOf("POST"),
          "/cluster/nodes/{nodeName}/clear".replace("{" + "nodeName" + "}", nodeName));

      this.nodeName = nodeName;
      this.requestBody = new DeleteNodeRequestBody();
      addHeader("Content-type", "application/json");
    }

    // TODO find a way to add required parameters in the request body to the class constructor
    /**
     * @param async Request ID to track this action which will be processed asynchronously.
     */
    public void setAsync(String async) {
      this.requestBody.async = async;
    }

    @Override
    public RequestWriter.ContentWriter getContentWriter(String expectedType) {
      return new JacksonContentWriter(expectedType, requestBody);
    }

    // TODO Hardcode this for now, but in reality we'll want to parse this out of the Operation data
    // somehow
    @Override
    public String getRequestType() {
      return SolrRequestType.ADMIN.toString();
    }

    @Override
    public SolrParams getParams() {
      final ModifiableSolrParams params = new ModifiableSolrParams();
      return params;
    }

    @Override
    protected DeleteNodeResponse createResponse(SolrClient client) {
      return new DeleteNodeResponse();
    }

    @Override
    public ResponseParser getResponseParser() {
      return new InputStreamResponseParser("json");
    }
  }

  public static class GetPublicKeyResponse extends JacksonParsingResponse {
    public GetPublicKeyResponse() {
      super(PublicKeyResponse.class);
    }
  }

  public static class GetPublicKey extends SolrRequest {

    /** Create a GetPublicKey request object. */
    public GetPublicKey() {
      super(SolrRequest.METHOD.valueOf("GET"), "/node/key");
    }

    // TODO Hardcode this for now, but in reality we'll want to parse this out of the Operation data
    // somehow
    @Override
    public String getRequestType() {
      return SolrRequestType.ADMIN.toString();
    }

    @Override
    public SolrParams getParams() {
      final ModifiableSolrParams params = new ModifiableSolrParams();
      return params;
    }

    @Override
    protected GetPublicKeyResponse createResponse(SolrClient client) {
      return new GetPublicKeyResponse();
    }

    @Override
    public ResponseParser getResponseParser() {
      return new InputStreamResponseParser("json");
    }
  }

  public static class ReplaceNodeResponse extends JacksonParsingResponse {
    public ReplaceNodeResponse() {
      super(SolrJerseyResponse.class);
    }
  }

  public static class ReplaceNode extends SolrRequest {
    private final ReplaceNodeRequestBody requestBody;
    private final String sourceNodeName;

    /**
     * Create a ReplaceNode request object.
     *
     * @param sourceNodeName Path param - The name of the node to be replaced.
     */
    public ReplaceNode(String sourceNodeName) {
      super(
          SolrRequest.METHOD.valueOf("POST"),
          "/cluster/nodes/{sourceNodeName}/replace"
              .replace("{" + "sourceNodeName" + "}", sourceNodeName));

      this.sourceNodeName = sourceNodeName;
      this.requestBody = new ReplaceNodeRequestBody();
      addHeader("Content-type", "application/json");
    }

    // TODO find a way to add required parameters in the request body to the class constructor
    /**
     * @param targetNodeName The target node where replicas will be copied. If this parameter is not
     *     provided, Solr will identify nodes automatically based on policies or number of cores in
     *     each node.
     */
    public void setTargetNodeName(String targetNodeName) {
      this.requestBody.targetNodeName = targetNodeName;
    }
    // TODO find a way to add required parameters in the request body to the class constructor
    /**
     * @param waitForFinalState If true, the request will complete only when all affected replicas
     *     become active. If false, the API will return the status of the single action, which may
     *     be before the new replica is online and active.
     */
    public void setWaitForFinalState(Boolean waitForFinalState) {
      this.requestBody.waitForFinalState = waitForFinalState;
    }
    // TODO find a way to add required parameters in the request body to the class constructor
    /**
     * @param async Request ID to track this action which will be processed asynchronously.
     */
    public void setAsync(String async) {
      this.requestBody.async = async;
    }

    @Override
    public RequestWriter.ContentWriter getContentWriter(String expectedType) {
      return new JacksonContentWriter(expectedType, requestBody);
    }

    // TODO Hardcode this for now, but in reality we'll want to parse this out of the Operation data
    // somehow
    @Override
    public String getRequestType() {
      return SolrRequestType.ADMIN.toString();
    }

    @Override
    public SolrParams getParams() {
      final ModifiableSolrParams params = new ModifiableSolrParams();
      return params;
    }

    @Override
    protected ReplaceNodeResponse createResponse(SolrClient client) {
      return new ReplaceNodeResponse();
    }

    @Override
    public ResponseParser getResponseParser() {
      return new InputStreamResponseParser("json");
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy