Enum DSProtocol

java.lang.Object
java.lang.Enum<DSProtocol>
com.smartgwt.client.types.DSProtocol
All Implemented Interfaces:
ValueEnum, Serializable, Comparable<DSProtocol>, Constable

public enum DSProtocol extends Enum<DSProtocol> implements ValueEnum
OperationBinding.dataProtocol affects how the data in the DSRequest (DSRequest.data) is sent to the DataSource.dataURL. Listed below are the valid values for OperationBinding.dataProtocol and their behavior.

Note that, when using the Smart GWT server, data is automatically translated from JavaScript to Java according to the rules described here; dataProtocol does not apply and is ignored.

If you are integrating with a REST server that requires the more obscure RPCRequest.httpMethods of "PUT", "DELETE" or "HEAD", you can specify these httpMethod settings via OperationBinding.requestProperties. dataProtocol settings that mention "GET" or "POST" are compatible with these additional HTTP methods as well. Typical operationBindings for a REST server that uses "PUT" and "DELETE" are as follows:

     operationBindings:[
        {operationType:"fetch", dataProtocol:"getParams"},
        {operationType:"add", dataProtocol:"postParams"},
        {operationType:"remove", dataProtocol:"getParams", requestProperties:{httpMethod:"DELETE"}},
        {operationType:"update", dataProtocol:"postParams", requestProperties:{httpMethod:"PUT"}}
     ],
  
  • Enum Constant Details

    • GETPARAMS

      public static final DSProtocol GETPARAMS
      Data is added to the dataURL, with each property in the data becoming an HTTP parameter, eg http://service.com/search?keyword=foo

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "getParams".

    • POSTPARAMS

      public static final DSProtocol POSTPARAMS
      Data is POST'd to the dataURL, with each property becoming an HTTP parameter, exactly as an HTML form would submit them if it had one input field per property in the data.

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "postParams".

    • POSTJSON

      public static final DSProtocol POSTJSON
      Data is serialized as a JSON string and POST'd to the dataURL.

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "postJSON".

    • POSTXML

      public static final DSProtocol POSTXML
      Data is serialized as XML via DataSource.xmlSerialize() and POST'd as the HTTP request body with contentType "text/xml".

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "postXML".

    • SOAP

      public static final DSProtocol SOAP
      Data is serialized as XML via DataSource.xmlSerialize(), wrapped in a SOAP envelope, and POST'd as the HTTP request body with contentType "text/xml". Generally only used in connection with a WSDL web service.

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "soap".

    • POSTMESSAGE

      public static final DSProtocol POSTMESSAGE
      dsRequest.data is assumed to be a String set up by DataSource.transformRequest() and is POST'd as the HTTP request body.

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "postMessage".

    • CLIENTCUSTOM

      public static final DSProtocol CLIENTCUSTOM
      This setting entirely bypasses the Smart GWT comm system. Instead of the DataSource sending an HTTP request to a URL, the developer is expected to implement DataSource.transformRequest() to perform their own custom logic, and then call DataSource.processResponse() to handle the results of this action. This dataProtocol setting can be used to implement access to in-browser resources such as HTML5 "localStorage", native APIs available to applications packaged as native applications, or to implement the DataSource Facade pattern.

      If this enumerated value is used in a Component XML file or server-side DataSource descriptor (.ds.xml file), use the value "clientCustom".

  • Method Details

    • values

      public static DSProtocol[] values()
      Returns an array containing the constants of this enum type, in the order they are declared.
      Returns:
      an array containing the constants of this enum type, in the order they are declared
    • valueOf

      public static DSProtocol valueOf(String name)
      Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)
      Parameters:
      name - the name of the enum constant to be returned.
      Returns:
      the enum constant with the specified name
      Throws:
      IllegalArgumentException - if this enum type has no constant with the specified name
      NullPointerException - if the argument is null
    • getValue

      public String getValue()
      Specified by:
      getValue in interface ValueEnum