Package com.thetransactioncompany.jsonrpc2

Source Code of com.thetransactioncompany.jsonrpc2.JSONRPC2Request

package com.thetransactioncompany.jsonrpc2;


import java.util.List;
import java.util.Map;

import net.minidev.json.JSONObject;


/**
* Represents a JSON-RPC 2.0 request.
*
* <p>A request carries four pieces of data:
* <ul>
*     <li>{@code method} The name of the remote method to call.
*     <li>{@code params} The required method parameters (if any), which can
*         be packed into a JSON array or object.
*     <li>{@code id} An identifier which is echoed back to the client with
*         the response.
*     <li>{@code jsonrpc} A string indicating the JSON-RPC protocol version
*         set to "2.0".
* </ul>
*
* <p>Here is a sample JSON-RPC 2.0 request string:
*
* <pre>
* { 
*    "method"  : "makePayment",
*    "params"  : { "recipient" : "Penny Adams", "amount":175.05 },
*    "id"      : "0001",
*    "jsonrpc" : "2.0"
* }
* </pre>
*
* <p>This class provides two methods to obtain a request object:
* <ul>
*     <li>Pass a JSON-RPC 2.0 request string to the static
*         {@link #parse} method, or
*     <li>Invoke one of the constructors with the appropriate arguments.
* </ul>
*
* <p>Example 1: Parsing a request string:
*
* <pre>
* String jsonString = "{\"method\":\"makePayment\"," +
*                     "\"params\":{\"recipient\":\"Penny Adams\",\"amount\":175.05}," +
*                     "\"id\":\"0001\","+
*                     "\"jsonrpc\":\"2.0\"}";
*
* JSONRPC2Request req = null;
*
* try {
*         req = JSONRPC2Request.parse(jsonString);
*
* } catch (JSONRPC2ParseException e) {
*         // handle exception
* }
* </pre>
*
* <p>Example 2: Recreating the above request:
*
* <pre>
* String method = "makePayment";
* Map&lt;String,Object&gt; params = new HashMap&lt;String,Object&gt;();
* params.put("recipient", "Penny Adams");
* params.put("amount", 175.05);
* String id = "0001";
*
* JSONRPC2Request req = new JSONRPC2Request(method, params, id);
*
* System.out.println(req);
* </pre>
*
* <p id="map">The mapping between JSON and Java entities (as defined by the
* underlying JSON Smart library):
*
* <pre>
*     true|false  <--->  java.lang.Boolean
*     number      <--->  java.lang.Number
*     string      <--->  java.lang.String
*     array       <--->  java.util.List
*     object      <--->  java.util.Map
*     null        <--->  null
* </pre>
*
* <p>The JSON-RPC 2.0 specification and user group forum can be found
* <a href="http://groups.google.com/group/json-rpc">here</a>.
*
* @author Vladimir Dzhuvinov
*/
public class JSONRPC2Request extends JSONRPC2Message {

 
  /**
   * The method name.
   */
  private String method;


  /**
   * The positional parameters, {@code null} if none.
   */
  private List<Object> positionalParams;


  /**
   * The named parameters, {@code null} if none.
   */
  private Map<String,Object> namedParams;
 
 
  /**
   * The request identifier.
   */
  private Object id;
 
 
  /**
   * Parses a JSON-RPC 2.0 request string. This method is thread-safe.
   *
   * @param jsonString The JSON-RPC 2.0 request string, UTF-8 encoded.
   *                   Must not be {@code null}.
   *
   * @return The corresponding JSON-RPC 2.0 request object.
   *
   * @throws JSONRPC2ParseException With detailed message if parsing
   *                                failed.
   */
  public static JSONRPC2Request parse(final String jsonString)
    throws JSONRPC2ParseException {
   
    return parse(jsonString, false, false, false);
  }
 
 
  /**
   * Parses a JSON-RPC 2.0 request string. This method is thread-safe.
   *
   * @param jsonString    The JSON-RPC 2.0 request string, UTF-8 encoded.
   *                      Must not be {@code null}.
   * @param preserveOrder {@code true} to preserve the order of JSON
   *                      object members in parameters.
   *
   * @return The corresponding JSON-RPC 2.0 request object.
   *
   * @throws JSONRPC2ParseException With detailed message if parsing
   *                                failed.
   */
  public static JSONRPC2Request parse(final String jsonString,
                                final boolean preserveOrder)
    throws JSONRPC2ParseException {
   
    return parse(jsonString, preserveOrder, false, false);
  }
 
 
  /**
   * Parses a JSON-RPC 2.0 request string. This method is thread-safe.
   *
   * @param jsonString    The JSON-RPC 2.0 request string, UTF-8 encoded.
   *                      Must not be {@code null}.
   * @param preserveOrder {@code true} to preserve the order of JSON
   *                      object members in parameters.
   * @param ignoreVersion {@code true} to skip a check of the
   *                      {@code "jsonrpc":"2.0"} version attribute in the
   *                      JSON-RPC 2.0 message.
   *
   * @return The corresponding JSON-RPC 2.0 request object.
   *
   * @throws JSONRPC2ParseException With detailed message if parsing
   *                                failed.
   */
  public static JSONRPC2Request parse(final String jsonString,
                                final boolean preserveOrder,
                                final boolean ignoreVersion)
    throws JSONRPC2ParseException {
   
    return parse(jsonString, preserveOrder, ignoreVersion, false);
  }
 
 
  /**
   * Parses a JSON-RPC 2.0 request string. This method is thread-safe.
   *
   * @param jsonString            The JSON-RPC 2.0 request string, UTF-8
   *                              encoded. Must not be {@code null}.
   * @param preserveOrder         {@code true} to preserve the order of
   *                              JSON object members in parameters.
   * @param ignoreVersion         {@code true} to skip a check of the
   *                              {@code "jsonrpc":"2.0"} version
   *                              attribute in the JSON-RPC 2.0 message.
   * @param parseNonStdAttributes {@code true} to parse non-standard
   *                              attributes found in the JSON-RPC 2.0
   *                              message.
   *
   * @return The corresponding JSON-RPC 2.0 request object.
   *
   * @throws JSONRPC2ParseException With detailed message if parsing
   *                                failed.
   */
  public static JSONRPC2Request parse(final String jsonString,
                                      final boolean preserveOrder,
              final boolean ignoreVersion,
              final boolean parseNonStdAttributes)
    throws JSONRPC2ParseException {
   
    JSONRPC2Parser parser = new JSONRPC2Parser(preserveOrder,
                                         ignoreVersion,
                                         parseNonStdAttributes);
   
    return parser.parseJSONRPC2Request(jsonString);
  }
 
 
  /**
   * Constructs a new JSON-RPC 2.0 request with no parameters.
   *
   * @param method The name of the requested method. Must not be
   *               {@code null}.
   * @param id     The request identifier echoed back to the caller.
   *               The value must <a href="#map">map</a> to a JSON
   *               scalar ({@code null} and fractions, however, should
   *               be avoided).
   */
  public JSONRPC2Request(final String method, final Object id) {
   
    setMethod(method);
    setID(id);
  }
 
 
  /**
   * Constructs a new JSON-RPC 2.0 request with positional (JSON array)
   * parameters.
   *
   * @param method           The name of the requested method. Must not
   *                         be {@code null}.
   * @param positionalParams The positional (JSON array) parameters,
   *                         {@code null} if none.
   * @param id               The request identifier echoed back to the
   *                         caller. The value must <a href="#map">map</a>
   *                         to a JSON scalar ({@code null} and
   *                         fractions, however, should be avoided).
   */
  public JSONRPC2Request(final String method,
                   final List<Object> positionalParams,
                   final Object id) {
   
    setMethod(method);
    setPositionalParams(positionalParams);
    setID(id);
  }
   
 
  /**
   * Constructs a new JSON-RPC 2.0 request with named (JSON object)
   * parameters.
   *
   * @param method      The name of the requested method.
   * @param namedParams The named (JSON object) parameters, {@code null}
   *                    if none.
   * @param id          The request identifier echoed back to the caller.
   *                    The value must <a href="#map">map</a> to a JSON
   *                    scalar ({@code null} and fractions, however,
   *                    should be avoided).
   */
  public JSONRPC2Request(final String method,
                   final Map <String,Object> namedParams,
                   final Object id) {
   
    setMethod(method);
    setNamedParams(namedParams);
    setID(id);
  }
 
 
  /**
   * Gets the name of the requested method.
   *
   * @return The method name.
   */
  public String getMethod() {
   
    return method;
  }
 
 
  /**
   * Sets the name of the requested method.
   *
   * @param method The method name. Must not be {@code null}.
   */
  public void setMethod(final String method) {
   
    // The method name is mandatory
    if (method == null)
      throw new IllegalArgumentException("The method name must not be null");

    this.method = method;
  }
 
 
  /**
   * Gets the parameters type ({@link JSONRPC2ParamsType#ARRAY positional},
   * {@link JSONRPC2ParamsType#OBJECT named} or
   * {@link JSONRPC2ParamsType#NO_PARAMS none}).
   *
   * @return The parameters type.
   */
  public JSONRPC2ParamsType getParamsType() {
 
    if (positionalParams == null && namedParams == null)
      return JSONRPC2ParamsType.NO_PARAMS;

    if (positionalParams != null)
      return JSONRPC2ParamsType.ARRAY;

    if (namedParams != null)
      return JSONRPC2ParamsType.OBJECT;

    else
      return JSONRPC2ParamsType.NO_PARAMS;
  }
 
 
  /**
   * Gets the request parameters.
   *
   * <p>This method was deprecated in version 1.30. Use
   * {@link #getPositionalParams} or {@link #getNamedParams} instead.
   *
   * @return The parameters as {@code List<Object>} for positional (JSON
   *         array), {@code Map<String,Object>} for named (JSON object),
   *         or {@code null} if none.
   */
  @Deprecated
  public Object getParams() {
   
    switch (getParamsType()) {

      case ARRAY:
        return positionalParams;

      case OBJECT:
        return namedParams;

      default:
        return null;
    }
  }


  /**
   * Gets the positional (JSON array) parameters.
   *
   * @since 1.30
   *
   * @return The positional (JSON array) parameters, {@code null} if none
   *         or named.
   */
  public List<Object> getPositionalParams() {

    return positionalParams;
  }


  /**
   * Gets the named parameters.
   *
   * @since 1.30
   *
   * @return The named (JSON object) parameters, {@code null} if none or
   *         positional.
   */
  public Map<String,Object> getNamedParams() {

    return namedParams;
  }
 
 
  /**
   * Sets the request parameters.
   *
   * <p>This method was deprecated in version 1.30. Use
   * {@link #setPositionalParams} or {@link #setNamedParams} instead.
   *
   * @param params The parameters. For positional (JSON array) pass a
   *               {@code List<Object>}. For named (JSON object) pass a
   *               {@code Map<String,Object>}. If there are no
   *               parameters pass {@code null}.
   */
  @Deprecated
  @SuppressWarnings("unchecked")
  public void setParams(final Object params) {
 
    if (params == null)
      return;
     
    else if (params instanceof List)
      positionalParams = (List<Object>)params;
     
    else if (params instanceof Map)
      namedParams = (Map<String,Object>)params;
     
    else
      throw new IllegalArgumentException("The request parameters must be of type List, Map or null");
  }


  /**
   * Sets the positional (JSON array) request parameters.
   *
   * @since 1.30
   *
   * @param positionalParams The positional (JSON array) request
   *                         parameters, {@code null} if none.
   */
  public void setPositionalParams(final List<Object> positionalParams) {

    if (positionalParams == null)
      return;

    this.positionalParams = positionalParams;
  }


  /**
   * Sets the named (JSON object) request parameters.
   *
   * @since 1.30
   *
   * @param namedParams The named (JSON object) request parameters,
   *                    {@code null} if none.
   */
  public void setNamedParams(final Map<String,Object> namedParams) {

    if (namedParams == null)
      return;

    this.namedParams = namedParams;
  }
 
 
  /**
   * Gets the request identifier.
   *
   * @return The request identifier ({@code Number}, {@code Boolean},
   *         {@code String}) or {@code null}.
   */
  public Object getID() {
   
    return id;
  }
 
 
  /**
   * Sets the request identifier (ID).
   *
   * @param id The request identifier echoed back to the caller.
   *           The value must <a href="#map">map</a> to a JSON
   *           scalar ({@code null} and fractions, however, should
   *           be avoided).
   */
  public void setID(final Object id) {
   
    if (   id != null             &&
        ! (id instanceof Boolean) &&
        ! (id instanceof Number ) &&
        ! (id instanceof String )     )
      throw new IllegalArgumentException("The request identifier must map to a JSON scalar");
    this.id = id;
  }
 
 
  @Override
  public JSONObject toJSONObject() {
 
    JSONObject req = new JSONObject();
   
    req.put("method", method);
   
    // The params can be omitted if none
    switch (getParamsType()) {

      case ARRAY:
        req.put("params", positionalParams);
        break;

      case OBJECT:
        req.put("params", namedParams);
        break;
    }
   
    req.put("id", id);
   
    req.put("jsonrpc", "2.0");
   
    Map <String,Object> nonStdAttributes = getNonStdAttributes();
   
    if (nonStdAttributes != null) {
   
      for (final Map.Entry<String,Object> attr: nonStdAttributes.entrySet())
        req.put(attr.getKey(), attr.getValue());
    }
   
    return req;
  }
}
TOP

Related Classes of com.thetransactioncompany.jsonrpc2.JSONRPC2Request

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.