Rest Delphi ActiveX Reference Documentation
TChilkatRest
Current Version: 11.1.0
API for implementing RESTful Web API's.
Importing the Chilkat ActiveX into Delphi
Important: When upgrading to a new version of Chilkat, make sure to re-imported ActiveX DLL into Delphi to regenerate the files described below.
Chilkat v9.5.*: If using Chilkat v9.5.*, then use "Chilkat_v9_5_0_TLB" instead of "Chilkat_TLB", and the DLLs are named ChilkatAx-9.5.0-win32.dll (or ChilkatAx-9.5.0-x64.dll).
Two things are required to use an ActiveX in Delphi:
- The ActiveX DLL needs to be registered via regsvr32 on the system where the Delphi application runs. See How To Register ActiveX DLLs for detailed information.
- See also: ActiveX Registration Tutorial
- The ActiveX component needs to be "imported". Use the Delphi Import Component Wizard to import the Chilkat type library. This creates the following files: Chilkat_TLB.pas and Chilkat_TLB.dcr. The Chilkat_TLB.pas should be added to your project.
To import the Chilkat type library, do the following:
- In the Delphi RAD Studio, select the menu item "Component" --> "Import a Type Library".
- Find "Chilkat ActiveX" in the list and select it. This will only appear in the list if the ChilkatAx-win32.dll (or ChilkatAx-x64.dll) has been registered w/ regsvr32.
- Check the "Generate Component Wrappers" checkbox.
- Select a directory where the unit files (.pas and .dcr) should be generated.
- Select "Create Unit" and then "Finish".
- Add the .pas to your Delphi project.
To use a Chilkat ActiveX object in your Delphi code, add "Chilkat_TLB" to the "uses" statement. For example:
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, Chilkat_TLB;
Object Creation
var obj: TChilkatRest; ... begin obj := TChilkatRest.Create(Self); ... // When finished, free the object instance. obj.Free();
Properties
AllowHeaderFolding
If this property is set to 0, then no MIME header folding will be automatically applied to any request header.  The default is 1.   This property is provided to satisfy certain providers, such as Quickbooks, that require all MIME headers to be single unfolded lines regardless of length.
AllowHeaderQB
Controls whether non us-ascii HTTP request headers are automatically Q/B encoded.  The default value is 1. 
Q/B encoded headers explicitly indicate the charset and byte representation, and appear as such:  =?utf-8?Q?...?=  or =?utf-8?B?...?=, where the charset may be utf-8 or any other possible charset.
If this property is set to 0, then no Q/B encoding is applied to any request header.
Authorization
ConnectFailReason
If the Connect method fails, this property can be checked to determine the reason for failure.
Possible values are:
0 = success Normal (non-SSL) sockets: 1 = empty hostname 2 = DNS lookup failed 3 = DNS timeout 4 = Aborted by application. 5 = Internal failure. 6 = Connect Timed Out 7 = Connect Rejected (or failed for some other reason) 99 = Chilkat not unlocked / trial expired. SSL/TLS: 100 = TLS internal error. 101 = Failed to send client hello. 102 = Unexpected handshake message. 103 = Failed to read server hello. 104 = No server certificate. 105 = Unexpected TLS protocol version. 106 = Server certificate verify failed (the server certificate is expired or the cert's signature verification failed). 107 = Unacceptable TLS protocol version. 109 = Failed to read handshake messages. 110 = Failed to send client certificate handshake message. 111 = Failed to send client key exchange handshake message. 112 = Client certificate's private key not accessible. 113 = Failed to send client cert verify handshake message. 114 = Failed to send change cipher spec handshake message. 115 = Failed to send finished handshake message. 116 = Server's Finished message is invalid.top
ConnectTimeoutMs
The maximum amount of time to wait for the connection to be accepted by the HTTP server.
topDebugLogFilePath
If set to a file path, this property logs the LastErrorText of each Chilkat method or property call to the specified file. This logging helps identify the context and history of Chilkat calls leading up to any crash or hang, aiding in debugging.
Enabling the VerboseLogging property provides more detailed information. This property is mainly used for debugging rare instances where a Chilkat method call causes a hang or crash, which should generally not happen.
Possible causes of hangs include:
- A timeout property set to 0, indicating an infinite timeout.
- A hang occurring within an event callback in the application code.
- An internal bug in the Chilkat code causing the hang.
DebugMode
If 1  then all calls to Send* or FullRequest* methods will not actually send a request.  Instead, the request will be written to a memory buffer which can then be retrieved by calling GetLastDebugRequest.
HeartbeatMs
The interval in milliseconds between each AbortCheck event callback, which enables an application to abort certain method calls before they complete. By default, HeartbeatMs is set to 0, meaning no AbortCheck event callbacks will trigger.
Host
The value of the Host HTTP request header.
topIdleTimeoutMs
The maximum amount of time to wait for additional incoming data when receiving, or the max time to wait to send additional data. The default value is 30000 (30 seconds). This is not an overall max timeout. Rather, it is the maximum time to wait when receiving or sending has halted.
topLastBinaryResult
This property is mainly used in SQL Server stored procedures to retrieve binary data from the last method call that returned binary data. It is only accessible if Chilkat.Global.KeepBinaryResult is set to 1. This feature allows for the retrieval of large varbinary results in an SQL Server environment, which has restrictions on returning large data via method calls, though temp tables can handle binary properties.
LastErrorHtml
Provides HTML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastErrorText
Provides plain text information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
LastErrorXml
Provides XML-formatted information about the last called method or property. If a method call fails or behaves unexpectedly, check this property for details. Note that information is available regardless of the method call's success.
topLastMethodSuccess
Indicates the success or failure of the most recent method call: 1 means success, 0 means failure. This property remains unchanged by property setters or getters.  This method is present to address challenges in checking for null or Nothing returns in certain programming languages.
LastRedirectUrl
This property holds the redirect URL from the most recent response. If the last response was not a redirect, the property is empty. The redirect URL corresponds to the Location header in the HTTP response.
LastRequestHeader
The full MIME header (not including the HTTP start line which contains the status code and status text), of the last request sent.
topLastRequestStartLine
The full start line of the last request sent. (The start line begins with the HTTP verb, such as GET, POST, etc., is followed by the URI path, and ends with the HTTP version.)
topLastStringResult
In SQL Server stored procedures, this property holds the string return value of the most recent method call that returns a string. It is accessible only when Chilkat.Global.KeepStringResult is set to TRUE. SQL Server has limitations on string lengths returned from methods and properties, but temp tables can be used to access large strings.
LastStringResultLen
The length, in characters, of the string contained in the LastStringResult property.
topNumResponseHeaders
The number of response header fields. The first response header field is at index 0.
topPartSelector
This property is for multipart requests, specifying the target MIME part for operations like AddHeader, RemoveHeader, SetMultipartBodyBinary, SetMultipartBodyString, SetMultipartBodyStream, and others. An empty string () targets the top-level header. 1 refers to the first sub-part, 2 to the second sub-part, and so on. For deeper nesting, uncommon as it is, use the format {part}.{part}.{part}... For instance, 1.2 targets the second sub-part within the first sub-part.
PercentDoneOnSend
This property only applies to the FullRequest* methods, which are methods that both send an HTTP request and receive the response.  (It also only applies to programming languages that support event callbacks.)  It determines whether percentage completion is tracked for the sending of the HTTP request, or for the downloading the HTTP response.  The default value is 0, which is to measure the percent completion when receiving the response.
For example:  If the REST request is to download a file, then this property should remain at the default value of 0.   If the REST request is to upload a file (using a Full* method), then set this property to 1.  Also note if a server sends an HTTP response in the chunked encoding, it is not possible to measure percent completion because the HTTP client has no way of knowing the total size of the HTTP response.
ResponseHeader
The full response MIME header (not including the HTTP start line which contains the status code and status text).
topResponseStatusCode
ResponseStatusText
StreamNonChunked
If 1, then methods that upload data are sent non-chunked if possible.  For example, if the FullRequestStream method is called where the stream is a file stream, then the size of the content is known and the HTTP request will be sent using a Content-Length header instead of using a Transfer-Encoding: chunked upload.    If 0, then the chunked transfer encoding is used.  The default value of this property is 1.
UncommonOptions
This is a catch-all property to be used for uncommon needs. This property defaults to the empty string and should typically remain empty. Can be set to a list of the following comma separated keywords:
- AllowDuplicateQueryParams - Affects the AddQueryParam method. If the query parameter to be added already exists, it is not replaced and instead an additional param with the same name is added.
- AllowInsecureBasicAuth - Introduced in v9.5.0.80. Allows HTTP Basic authentication over non-TLS connections. (HTTP Basic authentication puts the login:password in the Authorization header field in base64 encoding. If transmitted over an insecure connection, it is potentially visible to anything sniffing the traffic. By default, Chilkat disallows HTTP Basic authentication except for SSL/TLS connections, SSH tunneled connections, or connections to localhost.)
- DisableTls13 Disables TLS 1.3 so that only TLS 1.2 or lower is used.
- ProtectFromVpn - Introduced in v9.5.0.80. On Android systems, will bypass any VPN that may be installed or active.
VerboseLogging
If set to 1, then the contents of LastErrorText (or LastErrorXml, or LastErrorHtml) may contain more verbose information. The default value is 0.  Verbose logging should only be used for debugging.  The potentially large quantity of logged information may adversely affect peformance.
Version
Methods
AddHeader
Adds an HTTP request header. If the header field already exists, then it is replaced.
Returns 1 for success, 0 for failure.
topAddMwsSignature
Computes the Amazon MWS signature using the mwsSecretKey and adds the Signature parameter to the request.  This method should be called for all Amazon Marketplace Web Service (Amazon MWS) HTTP requests.   It should be called after all request parameters have been added.
Important: The Chilkat v9.5.0.75 release accidentally breaks Amazon MWS (not AWS) authentication. If you need MWS with 9.5.0.75, send email to support@chilkatsoft.com for a hotfix, or revert back to v9.5.0.73, or update to a version after 9.5.0.75.
The domain should be the domain of the request, such as one of the following:
- mws.amazonservices.com
- mws-eu.amazonservices.com
- mws.amazonservices.in
- mws.amazonservices.com.cn
- mws.amazonservices.jp
The httpVerb should be the HTTP verb, such as GET, POST, etc.  The uriPath is the URI path, such as /Feeds/2009-01-01.  In general, the httpVerb and uriPath should be identical to the 1st two args passed to methods such as FullRequestFormUrlEncoded.
Note: This method also automatically adds or replaces the existing Timestamp parameter to the current system date/time.
Returns 1 for success, 0 for failure.
AddPathParam
Adds or replaces a path parameter.   A path parameter is a string that will be replaced in any uriPath string passed to a method.   For example, if name is fileId and value is 1R_70heIyzIAu1_u0prXbYcaIiJRVkgBl, then a uriPath argument of /drive/v3/files/fileId will be transformed to /drive/v3/files/1R_70heIyzIAu1_u0prXbYcaIiJRVkgBl in a method call.
Returns 1 for success, 0 for failure.
AddQueryParam
Adds a query parameter. If the query parameter already exists, then it is replaced.
To allow duplicates, you can add the keyword AllowDuplicateQueryParams to the UncommonOptions property value. In other words, if the query parameter already exists, it is not replaced and instead an additional param with the same name is added.
Returns 1 for success, 0 for failure.
AddQueryParams
Adds the query parameters from the queryString. The queryString is a query string of the format field1=value1&field2=value2&field3=value3... where each value is URL encoded.
Returns 1 for success, 0 for failure.
AddQueryParamSb
Adds a query parameter. If the query parameter already exists, then it is replaced. The parameter value is passed in a StringBuilder object.
Returns 1 for success, 0 for failure.
topClearAllHeaders
ClearAllParts
Removes all sub-parts from a request. This is useful when preparing the REST object to send a new request after a multipart request has just been sent.
Returns 1 for success, 0 for failure.
ClearAllPathParams
ClearAllQueryParams
ClearAuth
ClearResponseBodyStream
Connect
Establishes an initial connection to a REST server.  The hostname can be a domain name or an IP address.  Both IPv4 and IPv6 addresses are supported. The port is the port, which is typically 80 or 443.   If SSL/TLS is required, then tls should be set to 1.   The autoReconnect indicates whether connection should automatically be established as needed for subsequent REST requests.
Note: This method is for simple connections that do not require any proxies (HTTP or SOCKS), or SSH tunneling. If a proxy, SSH tunnel, or any other advanced socket feature is required, the Chilkat Socket API can be used to establish the connection. The UseConnection method can then be called to use the pre-established socket connection.
text-danger>IMPORTANT: The hostname argument should be just the domain or IP address.  It is NOT the full URL.  If your URL is https://www.example.com/something/123, then pass www.example.com in the 1st argument.
Returns 1 for success, 0 for failure.
ConnectAsync (1)
Creates an asynchronous task to call the Connect method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
Disconnect
Closes the connection with the HTTP server if one is open. This method can be called to ensure the connection is closed. The maxWaitMs is the maximum time in milliseconds to wait for a clean close. If the connection is through an SSH tunnel, this closes the logical channel within the SSH tunnel, and not the connection with the SSH server itself.
Returns 1 for success, 0 for failure.
topDisconnectAsync (1)
Creates an asynchronous task to call the Disconnect method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestBd
Sends a complete REST request (header + binary body) and receives the full response. The binary body of the request is passed in binData. The response body is returned in responseBody (replacing whatever contents responseBody may have previously held).
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
FullRequestBdAsync (1)
Creates an asynchronous task to call the FullRequestBd method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestBinary
Sends a complete REST request (header + body) and receives the full response. It is assumed that the request body is binary, and the response body is a string (such as JSON or XML). The response body is returned.
This method is the equivalent of making the following calls in sequence: SendReqBinaryBody, ReadResponseHeader, ReadRespBodyString.
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns a zero-length WideString on failure
FullRequestBinaryAsync (1)
Creates an asynchronous task to call the FullRequestBinary method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestFormUrlEncoded
Sends a complete application/x-www-form-urlencoded HTTP request and receives the full response. The request body is composed of the URL encoded query params. It is assumed that the response body is a string (such as JSON or XML). The response body is returned.
This method is the equivalent of making the following calls in sequence: SendReqFormUrlEncoded, ReadResponseHeader, ReadRespBodyString.
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns a zero-length WideString on failure
FullRequestFormUrlEncodedAsync (1)
Creates an asynchronous task to call the FullRequestFormUrlEncoded method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestMultipart
Sends a complete multipart REST request (header + multipart body) and receives the full response. It is assumed that the response body is a string (such as JSON or XML). The response body is returned.
This method is the equivalent of making the following calls in sequence: SendReqMultipart, ReadResponseHeader, ReadRespBodyString.
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns a zero-length WideString on failure
FullRequestMultipartAsync (1)
Creates an asynchronous task to call the FullRequestMultipart method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestNoBody
Sends a complete REST request and receives the full response. It is assumed that the response body is a string (such as JSON or XML). The response body is returned.
This method is the equivalent of making the following calls in sequence: SendReqNoBody, ReadResponseHeader, ReadRespBodyString.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns a zero-length WideString on failure
FullRequestNoBodyAsync (1)
Creates an asynchronous task to call the FullRequestNoBody method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestNoBodyBd
The same as FullRequestNoBody, except returns the response body in the binData. This method is useful for downloading binary files.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
FullRequestNoBodyBdAsync (1)
Creates an asynchronous task to call the FullRequestNoBodyBd method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestNoBodySb
The same as FullRequestNoBody, except returns the response body in the sb.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
FullRequestNoBodySbAsync (1)
Creates an asynchronous task to call the FullRequestNoBodySb method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestSb
Sends a complete REST request (header + body string) and receives the full response. The body of the request is passed in requestBody. The response body is returned in responseBody (replacing whatever contents responseBody may have previously held).
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topFullRequestSbAsync (1)
Creates an asynchronous task to call the FullRequestSb method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestStream
Sends a complete REST request and receives the full response. It is assumed that the response body is a string (such as JSON or XML). The response body is returned.
This method is the equivalent of making the following calls in sequence: SendReqStream, ReadResponseHeader, ReadRespBodyString.
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns a zero-length WideString on failure
FullRequestStreamAsync (1)
Creates an asynchronous task to call the FullRequestStream method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
FullRequestString
Sends a complete REST request (header + body string) and receives the full response. It is assumed that both the request and response bodies are strings (such as JSON or XML). The response body is returned.
This method is the equivalent of making the following calls in sequence: SendReqStringBody, ReadResponseHeader, ReadRespBodyString.
Note: If your application wishes to receive percent-done callbacks, make sure the PercentDoneOnSend property is set to indicate whether percent-done applies to sending or receiving.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns a zero-length WideString on failure
FullRequestStringAsync (1)
Creates an asynchronous task to call the FullRequestString method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
GetLastDebugRequest
Returns the fully composed HTTP request that would've been sent had the DebugMode been turned off. The request is returned in bd.
Returns 1 for success, 0 for failure.
GetLastJsonData
Provides information about what transpired in the last method called on this object instance. For many methods, there is no information. However, for some methods, details about what occurred can be obtained by getting the LastJsonData right after the method call returns.
topLoadTaskCaller
ReadRespBd
Reads the response body. Should only be called after ReadResponseHeader has been called, and should only be called when it is already known that the response body is binary, such as for JPG images or other non-text binary file types. The response body is received into responseBody (replacing whatever contents responseBody may have previously held).
Returns 1 for success, 0 for failure.
ReadRespBdAsync (1)
Creates an asynchronous task to call the ReadRespBd method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
ReadRespBodyBinary
Reads the response body. Should only be called after ReadResponseHeader has been called, and should only be called when it is already known that the response body is binary, such as for JPG images or other non-text binary file types.
Returns a zero-length byte array (as an OleVariant) on failure.
An empty array will have a VarArrayHighBound of -1 meaning 0 elements.
ReadRespBodyBinaryAsync (1)
Creates an asynchronous task to call the ReadRespBodyBinary method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
ReadRespBodyStream
Reads the response body to the stream.   If autoSetStreamCharset is 1, then the stream's StringCharset property will automatically get set based on the charset, if any, indicated in the response header.  If the response is binary, then autoSetStreamCharset is ignored.
Returns 1 for success, 0 for failure.
ReadRespBodyStreamAsync (1)
Creates an asynchronous task to call the ReadRespBodyStream method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
ReadRespBodyString
Reads the response body. Should only be called after ReadResponseHeader has been called, and should only be called when it is already known that the response body will be a string (such as XML, JSON, etc.)
Returns a zero-length WideString on failure
ReadRespBodyStringAsync (1)
Creates an asynchronous task to call the ReadRespBodyString method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
ReadRespChunkBd
Reads the a chunk of the response. The received data is appended to bd. Will not return until at least minSize bytes are received. The last chunk of the response may be less than minSize bytes, or even 0 bytes.
Returns one of the following values:
- -1 - Failed. Check the contents of the LastErrorText for more information.
- 0 - Successfully returned the remaining bytes of the response.
- 1 - Returned a chunk of response bytes. The response is not yet finished.
Returns 1 for success, 0 for failure.
ReadRespChunkBdAsync (1)
Creates an asynchronous task to call the ReadRespChunkBd method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
ReadResponseHeader
Reads the HTTP response header. If the HTTP response includes a body, then the application must call the desired method to read the response body. Otherwise, the HTTP request / response is finished after reading the response header (such as for a GET request). The contents of the response header are available in various properties and methods.
The HTTP response status code is returned (such as 200 for a typical success response). If an error occurred such that no response was received, then a value of -1 is returned.
ReadResponseHeaderAsync (1)
Creates an asynchronous task to call the ReadResponseHeader method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
ReadRespSb
Reads the response body. Should only be called after ReadResponseHeader has been called, and should only be called when it is already known that the response body will be a string (such as XML, JSON, etc.) The response body is stored in responseBody. (replacing whatever contents responseBody may have previously held).
Returns 1 for success, 0 for failure.
topReadRespSbAsync (1)
Creates an asynchronous task to call the ReadRespSb method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
RemoveHeader
RemoveQueryParam
ResponseHdrByName
Returns the value of the response header indicated by name.
Returns a zero-length WideString on failure
ResponseHdrName
Returns the name of the Nth response header field. (Chilkat always uses 0-based indexing. The first header field is at index 0.)
Returns a zero-length WideString on failure
ResponseHdrValue
Returns the value of the Nth response header field. (Chilkat always uses 0-based indexing. The first header field is at index 0.)
Returns a zero-length WideString on failure
SendReqBd
Sends a REST request that cotnains a binary body.  The httpVerb is the HTTP verb (also known as the HTTP method), such as PUT.   The uriPath is the path of the resource URI.  The body contains the bytes of the HTTP request body.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topSendReqBdAsync (1)
Creates an asynchronous task to call the SendReqBd method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqBinaryBody
Sends a REST request that cotnains a binary body.  The httpVerb is the HTTP verb (also known as the HTTP method), such as PUT.   The uriPath is the path of the resource URI.  The body contains the bytes of the HTTP request body.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topSendReqBinaryBodyAsync (1)
Creates an asynchronous task to call the SendReqBinaryBody method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqFormUrlEncoded
Sends an application/x-www-form-urlencoded HTTP request where the body is composed of the URL encoded query params.  The httpVerb is the HTTP verb (also known as the HTTP method), such as POST.   The uriPath is the path of the resource URI.  If the Content-Type header was set, it is ignored and instead the Content-Type of the  request will be application/x-www-form-urlencoded.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topSendReqFormUrlEncodedAsync (1)
Creates an asynchronous task to call the SendReqFormUrlEncoded method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqMultipart
Sends a multipart REST request.  The httpVerb is the HTTP verb (also known as the HTTP method), such as GET.   The uriPath is the path of the resource URI.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topSendReqMultipartAsync (1)
Creates an asynchronous task to call the SendReqMultipart method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqNoBody
Sends a REST request that cotnains no body.  The httpVerb is the HTTP verb (also known as the HTTP method), such as GET.   The uriPath is the path of the resource URI.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topSendReqNoBodyAsync (1)
Creates an asynchronous task to call the SendReqNoBody method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqSb
Sends a REST request that cotnains a text body, such as XML or JSON.  The httpVerb is the HTTP verb (also known as the HTTP method), such as PUT.   The uriPath is the path of the resource URI.  The bodySb contains the text of the HTTP request body.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
topSendReqSbAsync (1)
Creates an asynchronous task to call the SendReqSb method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqStreamBody
Sends a REST request that cotnains a binary or text body that is obtained by reading from the stream.  The httpVerb is the HTTP verb (also known as the HTTP method), such as PUT.   The uriPath is the path of the resource URI.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
SendReqStreamBodyAsync (1)
Creates an asynchronous task to call the SendReqStreamBody method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SendReqStringBody
Sends a REST request that cotnains a text body, such as XML or JSON.  The httpVerb is the HTTP verb (also known as the HTTP method), such as PUT.   The uriPath is the path of the resource URI.  The bodyText contains the text of the HTTP request body.
text-danger>IMPORTANT: The uriPath argument should be just the path part of the URL.  It is NOT the full URL.  If your URL is https://www.example.com/something/123?xyz=1, then the uriPath is /something/123?xyz=1.
Returns 1 for success, 0 for failure.
SendReqStringBodyAsync (1)
Creates an asynchronous task to call the SendReqStringBody method with the arguments provided.
Note: Async method event callbacks happen in the background thread. Accessing and updating UI elements existing in the main thread may require special considerations.
Returns nil on failure
SetAuthAws
Sets the authorization service provider for Amazon AWS REST requests. An application that sets an AWS authentication provider need not explicitly set the Authorization property. Each REST request is automatically signed and authenticated using the authProvider.
Returns 1 for success, 0 for failure.
SetAuthAzureSas
Provides the information for Azure SAS (Shared Access Signature) authorization.   Calling this method will cause the Authorization: SharedAccessSignature ... header to be automatically added to all requests.
Returns 1 for success, 0 for failure.
SetAuthAzureStorage
Sets the authorization service provider for Azure Storage Service requests.
Returns 1 for success, 0 for failure.
SetAuthBasic
Sets the username and password to be used for Basic authentication.  This method should be called when Basic authentication is required.  It should only be used with secure SSL/TLS connections.   Calling this method will cause the Authorization: Basic ... header to be automatically added to all requests.   In many cases, a REST API will support Basic authentication where the username is a client ID or account ID, and the password is a client secret or token.
Returns 1 for success, 0 for failure.
SetAuthBasicSecure
The same as SetAuthBasic, but provides a more secure means for passing the arguments as secure string objects.
Returns 1 for success, 0 for failure.
SetAuthGoogle
Sets the authorization service provider for Google API requests.
Returns 1 for success, 0 for failure.
topSetAuthOAuth1
Sets the authentication provider for REST API requests needing OAuth 1.0 (and OAuth 1.0a) authentication.   If useQueryParams is 1, then the OAuth1 authentication information and signature  is passed in query parameters.  Otherwise it is passed in an Authorization header.
Returns 1 for success, 0 for failure.
SetAuthOAuth2
Causes the Authorization: Bearer <access_token> header to be added to each request.  The authProvider should have been loaded with an OAuth2 access token, which is JSON that looks similar to this:
{
  "access_token": "...",
  "refresh_token": "...",
  "expires_in": 14400,
  "scope": "...",
  "token_type": "bearer",
  "expires_on": "1611099058"
}
Your access token may contain different JSON members, but it should contain the two required members access_token and token_type.  The token_type should be bearer (case-insensitive).
Note: It is also possible to manually add the Authorization header in the same way as any other header by calling the AddHeader method. If the Authorization header is added via AddHeader, then don't use this method.
Returns 1 for success, 0 for failure.
topSetMultipartBodyBd
Only used for multipart requests. Sets the binary content of the multipart body indicated by the PartSelector.
Returns 1 for success, 0 for failure.
SetMultipartBodyBinary
Only used for multipart requests. Sets the binary content of the multipart body indicated by the PartSelector.
Returns 1 for success, 0 for failure.
topSetMultipartBodySb
Only used for multipart requests. Sets the text content of the multipart body indicated by the PartSelector.
Returns 1 for success, 0 for failure.
SetMultipartBodyStream
Only used for multipart requests. Sets the stream source of the multipart body indicated by the PartSelector.
Returns 1 for success, 0 for failure.
SetMultipartBodyString
Only used for multipart requests. Sets the text content of the multipart body indicated by the PartSelector.
Returns 1 for success, 0 for failure.
topSetResponseBodyStream
Only applies to the Full* methods, such as FullRequestNoBody, FullRequestBinary, FullRequestStream, etc. When set, the response body is streamed directly to responseStream, if (and only if) the HTTP response status code equals expectedStatus.
If the response body was streamed to responseStream, then the string return value of the Full* method instead becomes OK for success.  If an attempt was made to stream the response body but it failed, then FAIL is returned.   If the response body was not streamed because the response status code was not equal to expectedStatus, then the returned string  contains the server's error response.
 If autoSetStreamCharset is 1, then the expectedStatus's StringCharset property will automatically get set based on the charset, if any, indicated in the response header.  If the response is binary, then autoSetStreamCharset is ignored.
Starting in v9.5.0.75, the expectedStatus may be passed as a negative number to specify a range of expected (success) status codes. For example:
- -200: Allow status codes 200 - 299
- -210: Allow status codes 210 - 219
- -220: Allow status codes 220 - 229
- etc.
Returns 1 for success, 0 for failure.
UseConnection
Sets the connection to be used for sending the REST request. The connection should be an already-connected socket. It may be a TLS connection, an unencrypted connection, through an HTTP proxy, a SOCKS proxy, or even through SSH tunnels. All of the connection related functionality is handled by the Chilkat Socket API.
The autoReconnect indicates whether connection should automatically be established as needed for subsequent REST requests.
Important: The UseConnection method is provided as a means for handling more complicated connections -- such as connections through proxies, tunnels, etc. If your application is connecting directly to the HTTP server, then simply call this class's Connect method.
Returns 1 for success, 0 for failure.
Events
AbortCheck
Enables a method call to be aborted by triggering the AbortCheck event at intervals defined by the HeartbeatMs property. If HeartbeatMs is set to its default value of 0, no events will occur. For instance, set HeartbeatMs to 200 to trigger 5 AbortCheck events per second. 
Delphi ActiveX Event callback implementation:
procedure TForm1.restAbortCheck(ASender: TObject;  out abort: Integer);
begin
    // Application code goes here...
end;
procedure TForm1.Button1Click(Sender: TObject);
var
  rest: TChilkatRest;
begin
  rest := TChilkatRest.Create(Self);
  rest.OnAbortCheck := restAbortCheck;
  // ...PercentDone
This provides the percentage completion for any method involving network communications or time-consuming processing, assuming the progress can be measured as a percentage. This event is triggered only when it's possible and logical to express the operation's progress as a percentage. The pctDone argument will range from 1 to 100. For methods that finish quickly, the number of PercentDone callbacks may vary, but the final callback will have pctDone equal to 100. For longer operations, callbacks will not exceed one per percentage point (e.g., 1, 2, 3, ..., 98, 99, 100).
The PercentDone callback also acts as an AbortCheck event. For fast methods where PercentDone fires, an AbortCheck event may not trigger since the PercentDone callback already provides an opportunity to abort. For longer operations, where time between PercentDone callbacks is extended, AbortCheck callbacks enable more responsive operation termination.
        To abort the operation, set the abort output argument to 1. This will cause the method to terminate and return a failure status or corresponding failure value.
Delphi ActiveX Event callback implementation:
procedure TForm1.restPercentDone(ASender: TObject;  pctDone: Integer; out abort: Integer);
begin
    // Application code goes here...
end;
procedure TForm1.Button1Click(Sender: TObject);
var
  rest: TChilkatRest;
begin
  rest := TChilkatRest.Create(Self);
  rest.OnPercentDone := restPercentDone;
  // ...ProgressInfo
This event callback provides tag name/value pairs that detail what occurs during a method call. To discover existing tag names, create code to handle the event, emit the pairs, and review them. Most tag names are self-explanatory.
Delphi ActiveX Event callback implementation:
procedure TForm1.restProgressInfo(ASender: TObject;  const name: WideString; const value: WideString);
begin
    // Application code goes here...
end;
procedure TForm1.Button1Click(Sender: TObject);
var
  rest: TChilkatRest;
begin
  rest := TChilkatRest.Create(Self);
  rest.OnProgressInfo := restProgressInfo;
  // ...TaskCompleted
Called from the background thread when an asynchronous task completes.
Delphi ActiveX Event callback implementation:
procedure TForm1.restTaskCompleted(ASender: TObject; const task: IChilkatTask); begin // Application code goes here... end; procedure TForm1.Button1Click(Sender: TObject); var rest: TChilkatRest; begin rest := TChilkatRest.Create(Self); rest.OnTaskCompleted := restTaskCompleted; // ...
Deprecated
LastJsonData
This method is deprecated. Call GetLastJsonData instead.
Provides information about what transpired in the last method called on this object instance. For many methods, there is no information. However, for some methods, details about what occurred can be obtained by getting the LastJsonData right after the method call returns.
Returns nil on failure
RedirectUrl
Applications should instead access the LastRedirectUrl property.
If the response was a redirect and contains a Location header field, this method returns the redirect URL.
Returns nil on failure