Version

    Data Service HTTP Library Functions

    Functions from Data Service HTTP Library are available in context of Data API jobs.

    addResponseHeader

    void addResponseHeader(string name, string value );

    The addResponseHeader function adds an HTTP response header field. If the fuction is called multiple times, multiple headers will be added.

    The name parameter is a header field name. See list of header field names.

    If name is null or empty string, the response header field is not added.

    The value parameter is a value of the header field. If value is empty string, empty string is used. If value is null the header field is not added.

    Compatibility

    The addResponseHeader(string,string) function is available since CloverETL 4.7.0-M1.

    Example 68.250. Usage of addResponseHeader

    The addResponseHeader("Content-Language", "fr") adds an HTTP header field Content-Language with value fr

    Content-Language: fr

    The addResponseHeader("foo", "") adds header field with empty value

    foo: 

    The addResponseHeder("foo", null) does not add an HTTP header field because of null.


    See also:  containsResponseHeader

    containsResponseHeader

    boolean containsResponseHeader(string headerField);

    The containsResponseHeader() function checks for presence of a user-added header field. It does not check existence of header fields not added by user, e.g. Server: Apache-Coyote/1.1. The check is case insensitive.

    The headerField parameter is a name of HTTP header field.

    Compatibility

    The containsResponseHeader(string) function is available since CloverETL 4.7.0-M1.

    Example 68.251. Usage of containsResponseHeader

    There is no Content-Language header. The containsResponseHeader("Content-Language") returns false.

     

    If the header was added by setResponseHeader() function. The function containsResponseHeader() returns true.

    setResponseHeader("Content-Language", "fr");
    boolean a = containsResponseHeader("Content-Language"); // true

     

    The containsResponseHeader("Server") returns false. The header was not added by user.


    See also:  addResponseHeader

    getRequestBody

    string getRequestBody();

    The getRequestBody() function returns the request body.

    Compatibility

    The getRequestBody() function is available since CloverETL 4.7.0-M1.

    Example 68.252. Usage of getRequestBody

    If you query the data service with

    wget \
        --user=userName \
        --password=password \
        --method=POST \
        --body-data="Once upon a time" \
        "http://${HOST_PORT}/clover/data-service/getRequestBody"

    the getRequestBody() returns Once upon a time.


    See also:  getRequestEncoding

    getRequestClientIPAddress

    string getRequestClientIPAddress();

    The getRequestClientIPAddress() function returns the IP address of client performing the request.

    Compatibility

    The getRequestClientIPAddress() function is available since CloverETL 4.7.0-M1.

    Example 68.253. Usage of getRequestClientIPAddress

    If you run the CloverDX Server locally, the getRequestClientIPAddress() returns IP address corresponding to localhost: "127.0.0.1" or "0:0:0:0:0:0:0:1".


    See also:  getRequestBody

    getRequestContentType

    string getRequestContentType();

    The getRequestContentType() function returns the content type.

    Compatibility

    The getRequestContentType() function is available since CloverETL 4.7.0-M1.

    Example 68.254. Usage of getRequestContentType

    If you query the data service API with

     wget \
        --user=... \
        --password=... \
        --method=POST \
        --body-data="Once upon a time" \
        "http://${HOST_PORT}/clover/data-service/getRequestContentType"

    the getRequestContentType() returns application/x-www-form-urlencoded.


    See also:  getResponseContentType

    getRequestEncoding

    string getRequestEncoding();

    The getRequestEncoding() function encoding specified in Content-Type header.

    If the header does not exist, the function returns null.

    Compatibility

    The getRequestEncoding() function is available since CloverETL 4.7.0-M1.

    Example 68.255. Usage of getRequestEncoding

    If you query the data with

    wget \
        --user=... \
        --password=... \
        --header="Content-Type: text/html; charset=UTF-8" \
        "http://${HOST_PORT}/clover/data-service/getRequestEncoding"

    the getRequestEncoding() function returns UTF-8.


    See also:  setRequestEncoding

    getRequestHeader

    string getRequestHeader(string headerField);

    The getRequestHeader() function returns value of the header field.

    The headerField parameter is HTTP header field name.

    If the header field does not exist, the function returns null.

    Compatibility

    The function getRequestHeader(string) is available since CloverETL 4.7.0-M1.

    Example 68.256. Usage of getRequestHeader

    If you query the service with

    wget \
        --user=... \
        --password=... \
        --header="Accept-Language: de" \
        "http://${HOST_PORT}/clover/data-service/getRequestHeader"

    the getRequestHeader("Accept-Language") returns de.


    See also:  getRequestHeaderNames

    getRequestHeaderNames

    string[] getRequestHeaderNames();

    The getRequestHeaderNames() function returns names of request header fields.

    Compatibility

    The function getRequestHeaderNames() was introduced in CloverETL 4.7.0-M1.

    Example 68.257. Usage of getRequestHeaderNames

    If the data service receives

    GET /clover/data-service/getRequestHeaderNames HTTP/1.1
    User-Agent: Wget/1.19.1 (cygwin)
    Accept: */*
    Accept-Encoding: identity
    Host: 172.22.2.71:33754
    Connection: Keep-Alive
    Accept-Language: es
    Authorization: Basic Y2xvdmVyOmNsb3Zlcg==
    Cookie: JSESSIONID=AE6A63EA112A0BADD046CDE0D068DCC1

    The getRequestHeaderNames() function returns user-agent,accept,accept-encoding,host,connection,accept-language,authorization,cookie (as a list of strings).


    See also:  getRequestHeader, getRequestHeaders

    getRequestHeaders

    map[string,string] getRequestHeaders();

    string[] getRequestHeaders(string param);

    The getRequestHeaders() function returns a map with request headers. The header name is a key, header field value is value.

    The param parameter is header field name.

    Compatibility

    The function getRequestHeaders() is available since CloverETL 4.7.0-M1.

    Example 68.258. Usage of getRequestHeaders

    If you query the data service with>

    curl.exe \
        --user clover:clover \
        --header "Accept-Language: de, en, es, fr" \
        --header "Accept: text/plain" \
        --header "Accept: text/html" \
        --header "Accept: application/xml" \
        --header "Accept: application/json" \
        http://${HOST_PORT}/clover/data-service/getRequestHeaders

    the getRequestHeaders() function returns map with key-value pairs: User-Agent=curl/7.54.1;Accept=application/json;Accept-Language=de, en, es, fr;.... As the function does not return a multimap, the Accept header field contains only one of the received header fields values. To get all received header field values, use the getRequestHeaders(string) function.

    The getRequestHeaders("Accept") function returns list of strings: text/plain;text/html;application/xml;application/json.


    See also:  getRequestHeader, getRequestHeaderNames

    getRequestMethod

    string getRequestMethod();

    The getRequestMethod() function returns the HTTP method: GET, POST, PUT, PATCH or DELETE.

    Compatibility

    The function getRequestMethod() was introduced in CloverETL 4.7.0-M1.

    Example 68.259. Usage of getRequestMethod

    If you query the data service with:

    wget \
        --user=clover \
        --password=clover \
        --method=GET \
        "http://${HOST_PORT}/clover/data-service/getRequestMethod"

    the getRequestMethod() returns GET.


    getRequestParameter

    string getRequestParameter(string param);

    The getRequestParameter() function returns value of GET or POST parameter.

    The param parameter is the parameter name.

    Compatibility

    The function getRequestParameters() was introduced in CloverETL 4.7.0-M1.

    Example 68.260. Usage of getRequestParameter

    If you query the data service with:

    wget \
        --user=clover \
        --password=clover \
        "http://${HOST_PORT}/clover/data-service/getRequestParameter?id=1234&"

    the getRequestParameter("id") returns 1234 (as string).

    If you query data service on .../getRequestParameter/id/{id} URL with

    wget \
        --user=clover \
        --password=clover \
        "http://${HOST_PORT}/clover/data-service/getRequestParameter/id/123"

    the getRequestParameter("id") returns 123 (as string). Note parameters in the URL in data service configuration.

    If you query data service with

    wget \
        --user=clover \
        --password=clover \
        --post-data "id=234&" \
        "http://${HOST_PORT}/clover/data-service/getRequestParameter"

    the getRequestParameter("id") returns 234 (as string).


    See also:  getRequestParameters, getRequestParameterNames

    getRequestParameterNames

    string[] getRequestParameterNames();

    The getRequestParameterNames() function returns names of GET or POST parameters., e.g. http://example.com/?id=123&

    Compatibility

    The function getRequestParameternames() was introduced in CloverETL 4.7.0-M1.

    Example 68.261. Usage of getRequestParameterNames

    If you query the data service with:

    wget \
        --user=clover \
        --password=clover \
        "http://${HOST_PORT}/clover/data-service/getRequestParameterNames?id=123&name=doe&"

    the getRequestParameterNames() returns list containing id and name.

    If you query data service on /getRequestParameterNames2/id/{id}/name/{name} with:

    wget \
        --user=clover \
        --password=clover \
        "http://${HOST_PORT}/clover/data-service/getRequestParameterNames2/id/123/name/doe"

    the getRequestParameterNames() function returns list containing id and name.

    If you query data service with:

    wget \
        --user=clover \
        --password=clover \
        --post-data "name=doe&" \
        "http://${HOST_PORT}/clover/data-service/getRequestParameterNames3?id=234&"

    the getRequestParameterNames() returns list containing id and name.


    See also:  getRequestParameter getRequestParameters

    getRequestParameters

    string[] getRequestParameters(string name);

    map[string,string] getRequestParameters();

    The getRequestParameters() function return map of GET or POST request parameters and request parameter values. The parameters are from URL: www.example.com/getRequestParameters?id=123&name=doe&name=john&

    The name parameter is name of the parameter.

    Compatibility

    The function getRequestParameters() was introduced in CloverETL 4.7.0-M1.

    Example 68.262. Usage of getRequestParameters

    If you query data service with:

    wget \
        --user=clover \
        --password=clover \
        "http://${HOST_PORT}/clover/data-service/getReqPar?id=123&name=doe&name=john&"

    The getRequestParameters() returns map. The key is parameter name, the value is the parameter value.

    The getRequestParameters("name") returns list containing doe and john.


    See also:  getRequestParameter getRequestParameterNames

    getRequestPartFilename

    string getRequestPartFilename(string paramName);

    The getRequestPartFilename() function returns name of file received in multipart entity. Usually, it is a file name from HTML form.

    The paramName parameter is name of HTML input field containing the file.

    Compatibility

    The function getRequestPartFileName(string) is available since CloverETL 4.7.0-M1.

    Example 68.263. Usage of getRequestPartFilename

    If you query the web service with:

    curl -F name=@/tmp/filename \
        http://example.com:8080/clover/data-service/getRequestPartFilename \
        --user clover:clover

    the getRequestPartFilename("name") returns somefile.


    getResponseContentType

    string getResponseContentType();

    The getResponseContentType() function retuns response content type - the value of Content-Type response header field.

    Compatibility

    The function getResponseContentType() is available since CloverETL 4.7.0-M1.

    Example 68.264. Usage of getResponseContentType

    The getResponseContentType() returns for example application/json.


    getRequestContentType, setResponseContentType

    getResponseEncoding

    string getResponseEncoding();

    The getResponseEncoding() function returns the response encoding.

    Compatibility

    The function getResponseEncoding() is available since CloverETL 4.7.0-M1.

    Example 68.265. Usage of getResponseEncoding

    E.g. the getResponseEncoding() returns iso-8859-1.


    See also:  getRequestEncoding, setResponseEncoding

    setRequestEncoding

    void setRequestEncoding(string encoding);

    The setRequestEncoding() function sets the encoding to be used in POST request parsing. Call this function in init().

    The encoding parameter is encoding.

    Compatibility

    The function setRequestEncoding(string) is available since CloverETL 4.7.0-M1.

    Example 68.266. Usage of setRequestEncoding

    The setRequestEncoding("utf-8") sets request encoding to UTF-8.

    The setRequestEncoding("iso-8859-2") sets request encoding to latin2.

    The setRequestEncoding("cp1250") sets request encoding to code page 1250.


    See also:  getRequestEncoding

    setResponseBody

    void setResponseBody(string body);

    The setResponseBody() function sets HTTP response body. Consider setting the response body encoding explicitly.

    The body parameter is the content of the body.

    If you try to create response body with setResponsebody() function and with writing to response:body, the later one will be used. You should use only one way to create the response body.

    Compatibility

    The function setResponseBody(string) is available since CloverETL 4.7.0-M1.

    Example 68.267. Usage of getResponseBody

    The setResponseBody("The response") sets the response body.


    See also:  setResponseEncoding

    setResponseContentType

    void setResponseContentType(string contentType);

    The setResponseContentType() function sets the response content type - the value of Content-Type response header field.

    The contentType parameter is the value of Content-Type response header field.

    Compatibility

    The function setResponseContentType(string) is available since CloverETL 4.7.0-M1.

    Example 68.268. Usage of setResponseContentType

    setResponseContentType("text/plain");


    setResponseBody getResponseContentType

    setResponseEncoding

    void setResponseEncoding(string encoding);

    The setResponseEncoding() function sets HTTP response encoding. This encoding is used if you set the response body with the setResponseBody() function.

    The encoding parameter is the response body encoding.

    Compatibility

    The function setResponseEncoding(string) is available since CloverETL 4.7.0-M1.

    Example 68.269. Usage of setResponseEncoding

    The setResponseEncoding("UTF-8"); sets response body encoding to UTF-8.


    See also:  getResponseEncoding setResponseBody

    setResponseHeader

    void setResponseHeader(string field, string value);

    The setResponseHeader() function sets the response header. If the header does not exist, it will be created.

    The field parameter is HTTP header field name.

    The value parameter is HTTP header field value.

    Compatibility

    The function setResponseHeader(string,string) is available since CloverETL 4.7.0-M1.

    Example 68.270. Usage of setResponseHeader

    setResponseHeader("Server", "BOA")


    See also:  addResponseHeader

    setResponseStatus

    void setResponseStatus(integer statusCode);

    void setResponseStatus(integer statusCode, string message);

    The setResponseStatus() function sets the response status code.

    The statusCode parameter is the returned status code.

    The message parameter is a message.

    Compatibility

    The setResponseStatus(string,string) is availables since CloverETL 4.7.0-M1.

    Example 68.271. Usage of setResponseStatus

    The setResponseStatus(403) sets the response status to 403.

     

    The setResponseStatus(414, "URI Too Long") returns a status code 414.

    HTTP/1.1 414 URI Too Long

    See also:  https://en.wikipedia.org/wiki/List_of_HTTP_status_codes https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml