Http Tcl Reference Documentation
Http
Current Version: 10.1.0
Class for sending HTTP requests and receiving server responses.
- Supports GET, POST, HEAD, PUT, DELETE, WebDav, and custom HTTP request methods.
- HTTP Authentication: Basic, NTLM, Digest, Negotiate
- HTTPS (SSL/TLS) with client-side certificate capabilities.
- Cookie caching, auto-resend, persisting to XML files.
- Content caching.
- Supports HTTP proxies
- Auto-follow redirects if desired.
- Amazon S3 methods.
- XML HTTP Request
- HTTP file upload capabilities
- Asynchronous features -- putting HTTP requests in background threads.
- Supports SOCK5/SOCKS4 proxies.
- IPv6 capable.
Object Creation
set myHttp [new CkHttp]
Properties
AbortCurrent
set boolVal [CkHttp_get_AbortCurrent $myHttp]
CkHttp_put_AbortCurrent $myHttp $boolVal
When set to 1, causes the currently running method to abort. Methods that always finish quickly (i.e.have no length file operations or network communications) are not affected. If no method is running, then this property is automatically reset to 0 when the next method is called. When the abort occurs, this property is reset to 0. Both synchronous and asynchronous method calls can be aborted. (A synchronous method call could be aborted by setting this property from a separate thread.)
topAccept
# ckStr is a CkString
CkHttp_get_Accept $myHttp $ckStr
set strVal [CkHttp_get_ck_accept $myHttp]
CkHttp_put_Accept $myHttp $strVal
The Accept header field to be automatically included with GET requests issued by QuickGet or QuickGetStr. The default value is "*/*".
topAcceptCharset
# ckStr is a CkString
CkHttp_get_AcceptCharset $myHttp $ckStr
set strVal [CkHttp_get_acceptCharset $myHttp]
CkHttp_put_AcceptCharset $myHttp $strVal
The Accept-Charset header field to be automatically included with GET requests issued by QuickGet or QuickGetStr. The default value is the empty string, which means no Accept-Charset header is included.
topAcceptLanguage
# ckStr is a CkString
CkHttp_get_AcceptLanguage $myHttp $ckStr
set strVal [CkHttp_get_acceptLanguage $myHttp]
CkHttp_put_AcceptLanguage $myHttp $strVal
The Accept-Language header field to be automatically included with GET requests issued by QuickGet or QuickGetStr. The default value is "en-us,en;q=0.5".
topAllowGzip
set boolVal [CkHttp_get_AllowGzip $myHttp]
CkHttp_put_AllowGzip $myHttp $boolVal
Controls whether the "Accept-Encoding: gzip" header is added to HTTP requests sent via any method that sends an HTTP request without using the HttpRequest object (such as QuickGetStr). If 0, then the empty Accept-Encoding header is added which means the server response should contain the uncompressed content. The default value is 1, which means the server, if it chooses, may send a gzipped response.
topAllowHeaderFolding
set boolVal [CkHttp_get_AllowHeaderFolding $myHttp]
CkHttp_put_AllowHeaderFolding $myHttp $boolVal
If this property is set to 0, then no MIME header folding will be automatically applied to any request header. The default is 1.
topAuthSignature
# ckStr is a CkString
CkHttp_get_AuthSignature $myHttp $ckStr
set strVal [CkHttp_get_authSignature $myHttp]
CkHttp_put_AuthSignature $myHttp $strVal
If set, then automatically adds the Authorization: Signature keyId="...", algorithm="...", headers="...", signature="..." header to all requests. This property should be set to a JSON string containing the information needed to compute and automatically add the HTTP Signature. See the example(s) below.
AuthToken
# ckStr is a CkString
CkHttp_get_AuthToken $myHttp $ckStr
set strVal [CkHttp_get_authToken $myHttp]
CkHttp_put_AuthToken $myHttp $strVal
If set, then automatically adds the "Authorization: Bearer
AutoAddHostHeader
set boolVal [CkHttp_get_AutoAddHostHeader $myHttp]
CkHttp_put_AutoAddHostHeader $myHttp $boolVal
If set to true, the "Host" header field will automatically be added to the request header for any QuickGet or QuickGetStr method calls. The value of the Host header field is taken from the hostname part of the URL passed to QuickGet/QuickGetStr.
topAwsAccessKey
# ckStr is a CkString
CkHttp_get_AwsAccessKey $myHttp $ckStr
set strVal [CkHttp_get_awsAccessKey $myHttp]
CkHttp_put_AwsAccessKey $myHttp $strVal
The AWS Access Key to be used with the Amazon S3 methods listed below.
topAwsEndpoint
# ckStr is a CkString
CkHttp_get_AwsEndpoint $myHttp $ckStr
set strVal [CkHttp_get_awsEndpoint $myHttp]
CkHttp_put_AwsEndpoint $myHttp $strVal
The regional endpoint (domain) to be used for Amazon S3 method calls. The default value is "s3.amazonaws.com". This can be set to any valid Amazon S3 endpoint, such as "s3-eu-west-1.amazonaws.com", or the endpoints for S3-API compatible services from other different providers.
AwsRegion
# ckStr is a CkString
CkHttp_get_AwsRegion $myHttp $ckStr
set strVal [CkHttp_get_awsRegion $myHttp]
CkHttp_put_AwsRegion $myHttp $strVal
The AWS (S3) region, such as "us-east-1", "us-west-2", "eu-west-1", "eu-central-1", etc. This propery defaults to "us-east-1". It is only used when the AwsSignatureVersion property is set to 4. When the AwsSignatureVersion property is set to 2, then this property is unused.
topAwsSecretKey
# ckStr is a CkString
CkHttp_get_AwsSecretKey $myHttp $ckStr
set strVal [CkHttp_get_awsSecretKey $myHttp]
CkHttp_put_AwsSecretKey $myHttp $strVal
The AWS Secret Key to be used with the Amazon S3 methods listed below.
topAwsSessionToken
# ckStr is a CkString
CkHttp_get_AwsSessionToken $myHttp $ckStr
set strVal [CkHttp_get_awsSessionToken $myHttp]
CkHttp_put_AwsSessionToken $myHttp $strVal
This is only used if a set of temporary security credentials were obtained by calling the AssumeRole action of the AWS Security Token Service.
topAwsSignatureVersion
set intVal [CkHttp_get_AwsSignatureVersion $myHttp]
CkHttp_put_AwsSignatureVersion $myHttp $intVal
Selects the AWS Signature Version algorithm. The default value is 4. May be set to 2 to select AWS Signature Version 2. (The only valid choices are 2 and 4.)
topAwsSubResources
# ckStr is a CkString
CkHttp_get_AwsSubResources $myHttp $ckStr
set strVal [CkHttp_get_awsSubResources $myHttp]
CkHttp_put_AwsSubResources $myHttp $strVal
The AWS sub-resources to be used with the Amazon S3 methods listed below.
If the S3 request needs to address a sub-resource, like ?versioning, ?policy, ?location, ?acl, or ?torrent, or ?versionid append the sub-resource and its value if it has one. Note that in case of multiple sub-resources, sub-resources must be lexicographically sorted by sub-resource name and separated by '&'. e.g. "acl&versionId=value"
The list of sub-resources that can be included are: acl, location, logging, notification, partNumber, policy, requestPayment, torrent, uploadId, uploads, versionId, versioning, versions and website.
topBandwidthThrottleDown
set intVal [CkHttp_get_BandwidthThrottleDown $myHttp]
CkHttp_put_BandwidthThrottleDown $myHttp $intVal
If non-zero, limits (throttles) the download bandwidth to approximately this maximum number of bytes per second. The default value of this property is 0.
topBandwidthThrottleUp
set intVal [CkHttp_get_BandwidthThrottleUp $myHttp]
CkHttp_put_BandwidthThrottleUp $myHttp $intVal
If non-zero, limits (throttles) the upload bandwidth to approximately this maximum number of bytes per second. The default value of this property is 0.
topBasicAuth
set boolVal [CkHttp_get_BasicAuth $myHttp]
CkHttp_put_BasicAuth $myHttp $boolVal
If HTTP basic authentication is needed, this property must be set to 1. The HTTP protocol allows for several different types of authentication schemes, such as NTLM, Digest, OAuth1, etc. A given server will support (or allow) certain authentication schemes (also known as authentication methods). Except for the "Basic" authentication method, the other forms of authentication do not involve sending the login and password in plain unencrypted text over the connection. The Basic authentication method is insecure in that it sends the login/password for all to see. If the connection is SSL/TLS, then this might be considered OK. Chilkat takes the safe approach and will not allow Basic authentication unless this property has been explicitly set to 1. The default value of this property is 0.
Note: It is not required to know the authentication methods accepted by the server beforehand (except for the case of Basic authentication). When authentication is required, Chilkat will first send the request without the Authorization header, receive back the 401 Authorization Required response along with information about what authentication methods are accepted, and then re-send with an accepted authentication method. If the authentication method is known in advance, then an application may set the appropriate property, such as NtlmAuth to 1 so that the extra (internal) round-trip is not required.
Note: The login and password is sent using the utf-8 byte representation. Some servers expect the ANSI byte representation (typically Windows-1252). Starting in Chilkat v9.5.0.87, to send the login/password using ANSI, add the "AnsiLogin" keyword to the UncommonOptions property.
ClientIpAddress
# ckStr is a CkString
CkHttp_get_ClientIpAddress $myHttp $ckStr
set strVal [CkHttp_get_clientIpAddress $myHttp]
CkHttp_put_ClientIpAddress $myHttp $strVal
The IP address to use for computers with multiple network interfaces or IP addresses. For computers with a single network interface (i.e. most computers), this property should not be set. For multihoming computers, the default IP address is automatically used if this property is not set.
The IP address is a string such as in dotted notation using numbers, not domain names, such as "165.164.55.124".
ConnectFailReason
set intVal [CkHttp_get_ConnectFailReason $myHttp]
This property will be set to the status of the last HTTP connection made (or failed to be made) by any HTTP method.
Possible values are:
0 = success Normal (non-TLS) 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) 50 = HTTP proxy authentication failure. 98 = Async operation in progress. 99 = Product is not unlocked. 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. 108 = App-defined server certificate requirements failure. 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. 125 = Peer tried to connect using older SSL 2.0 protocol version. 126 = TLS Pin Set Mismatch. 127 = TLS 1.3 handshake error.top
Connection
# ckStr is a CkString
CkHttp_get_Connection $myHttp $ckStr
set strVal [CkHttp_get_connection $myHttp]
CkHttp_put_Connection $myHttp $strVal
The Connection header field to be automatically included with GET requests issued by QuickGet or QuickGetStr. The default value is "Keep-Alive". To prevent the Connection header from being added to the HTTP header, set this property to the empty string.
topConnectTimeout
set intVal [CkHttp_get_ConnectTimeout $myHttp]
CkHttp_put_ConnectTimeout $myHttp $intVal
The amount of time in seconds to wait before timing out when connecting to an HTTP server. The default ConnectTimeout is 30 seconds.
Note: This is the maximum number of seconds to wait for a server to accept a TCP connection. Once the connection is accepted, and bytes begin flowing back-and-forth, then it is the ReadTimeout property that applies. It is the ReadTimeout that applies when receiving data, which includes the reads that occur during a TLS handshake.
topCookieDir
# ckStr is a CkString
CkHttp_get_CookieDir $myHttp $ckStr
set strVal [CkHttp_get_cookieDir $myHttp]
CkHttp_put_CookieDir $myHttp $strVal
Specifies a directory where cookies are automatically persisted if the Http.SaveCookies property is turned on. Cookies are stored in XML formatted files, one per domain, to main it easy for other programs to understand and parse. May be set to the string "memory" to cache cookies in memory.
DebugLogFilePath
# ckStr is a CkString
CkHttp_get_DebugLogFilePath $myHttp $ckStr
set strVal [CkHttp_get_debugLogFilePath $myHttp]
CkHttp_put_DebugLogFilePath $myHttp $strVal
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.
DefaultFreshPeriod
set intVal [CkHttp_get_DefaultFreshPeriod $myHttp]
CkHttp_put_DefaultFreshPeriod $myHttp $intVal
The default freshness period (in minutes) for cached documents when the FreshnessAlgorithm property is set to 0. The default value is 10080 (1 week).
topDigestAuth
set boolVal [CkHttp_get_DigestAuth $myHttp]
CkHttp_put_DigestAuth $myHttp $boolVal
Setting this property to 1 causes the HTTP component to use digest authentication. The default value is 0.
FetchFromCache
set boolVal [CkHttp_get_FetchFromCache $myHttp]
CkHttp_put_FetchFromCache $myHttp $boolVal
Set to true if pages should be fetched from cache when possible. Only HTTP GET requests are cached. HTTP responses that include Set-Cookie headers are not cached. A page is fetched from the disk cache if it is present and it is "fresh" according to the FreshnessAlgorithm property. If a page exists in cache but is not fresh, the HTTP component will issue a revalidate request and update the cache appropriately according to the response.
FinalRedirectUrl
# ckStr is a CkString
CkHttp_get_FinalRedirectUrl $myHttp $ckStr
set strVal [CkHttp_get_finalRedirectUrl $myHttp]
If an HTTP GET was redirected (as indicated by the WasRedirected property), this property will contain the final redirect URL, assuming the FollowRedirects property is 1.
Note: Starting in v9.5.0.49, this property will contain the redirect URL for 301/302 responses even if FollowRedirects is not set to 1.
topFollowRedirects
set boolVal [CkHttp_get_FollowRedirects $myHttp]
CkHttp_put_FollowRedirects $myHttp $boolVal
If true, then 301, 302, 303, 307, and 308 redirects are automatically followed when calling QuickGet and QuickGetStr. FollowRedirects is true by default.
topFreshnessAlgorithm
set intVal [CkHttp_get_FreshnessAlgorithm $myHttp]
CkHttp_put_FreshnessAlgorithm $myHttp $intVal
The freshness algorithm to use when determining the freshness of a cached HTTP GET response. A value of 1 causes an LM-factor algorithm to be used. This is the default. The LMFactor property is a value between 1 and 100 indicating the percentage of time based on the last-modified date of the HTML page. For example, if the LMFactor is 50, and an HTML page was modified 10 days ago, then the page will expire (i.e. no longer be fresh) in 5 days (50% of 10 days). This only applies to HTTP responses that do not have page expiration information. If the FreshnessAlgorithm = 0, then a constant expire time period determined by the DefaultFreshPeriod property is used.
topIgnoreMustRevalidate
set boolVal [CkHttp_get_IgnoreMustRevalidate $myHttp]
CkHttp_put_IgnoreMustRevalidate $myHttp $boolVal
Some HTTP responses contain a "Cache-Control: must-revalidate" header. If this is present, the server is requesting that the client always issue a revalidate HTTP request instead of serving the page directly from cache. If IgnoreMustRevalidate is set to 1, then Chilkat HTTP will serve the page directly from cache without revalidating until the page is no longer fresh.
The default value of this property is 0.
topIgnoreNoCache
set boolVal [CkHttp_get_IgnoreNoCache $myHttp]
CkHttp_put_IgnoreNoCache $myHttp $boolVal
Some HTTP responses contain headers of various types that indicate that the page should not be cached. Chilkat HTTP will adhere to this unless this property is set to 1.
The default value of this property is 0.
topKeepResponseBody
set boolVal [CkHttp_get_KeepResponseBody $myHttp]
CkHttp_put_KeepResponseBody $myHttp $boolVal
If 1, then the response body, if text, is saved to the LastResponseBody property for all methods that do not return an HttpResponse object. The default value of this property is 0.
LastContentType
# ckStr is a CkString
CkHttp_get_LastContentType $myHttp $ckStr
set strVal [CkHttp_get_lastContentType $myHttp]
The content-type of the last HTTP response received by the HTTP component.
topLastErrorHtml
# ckStr is a CkString
CkHttp_get_LastErrorHtml $myHttp $ckStr
set strVal [CkHttp_get_lastErrorHtml $myHttp]
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
# ckStr is a CkString
CkHttp_get_LastErrorText $myHttp $ckStr
set strVal [CkHttp_get_lastErrorText $myHttp]
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
# ckStr is a CkString
CkHttp_get_LastErrorXml $myHttp $ckStr
set strVal [CkHttp_get_lastErrorXml $myHttp]
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.
topLastFromCache
set boolVal [CkHttp_get_LastFromCache $myHttp]
LastHeader
# ckStr is a CkString
CkHttp_get_LastHeader $myHttp $ckStr
set strVal [CkHttp_get_lastHeader $myHttp]
The text of the last HTTP header sent by any of this class's methods. The purpose of this property is to allow the developer to examine the exact HTTP header for debugging purposes.
topLastMethodSuccess
set boolVal [CkHttp_get_LastMethodSuccess $myHttp]
CkHttp_put_LastMethodSuccess $myHttp $boolVal
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.
topLastModDate
# ckStr is a CkString
CkHttp_get_LastModDate $myHttp $ckStr
set strVal [CkHttp_get_lastModDate $myHttp]
The value of the Last-Modified header in the last HTTP response received by the HTTP component.
topLastResponseBody
# ckStr is a CkString
CkHttp_get_LastResponseBody $myHttp $ckStr
set strVal [CkHttp_get_lastResponseBody $myHttp]
The response body of the last HTTP response received by the HTTP component (for methods that do not return an HttpResponse object). The last response body is only saved to this property IF the KeepResponseBody property is set to 1.
topLastResponseHeader
# ckStr is a CkString
CkHttp_get_LastResponseHeader $myHttp $ckStr
set strVal [CkHttp_get_lastResponseHeader $myHttp]
The entire response header for the last HTTP response received by the HTTP component (for methods that do not return an HttpResponse object).
LastStatus
set intVal [CkHttp_get_LastStatus $myHttp]
The last HTTP status value received by the HTTP component. This only applies to methods that do not return an HTTP response object. For methods that return an HTTP response object, such as SynchronousRequest, the status code is found in the StatusCode property of the response object.
topLastStatusText
# ckStr is a CkString
CkHttp_get_LastStatusText $myHttp $ckStr
set strVal [CkHttp_get_lastStatusText $myHttp]
The last HTTP status text received by the HTTP component. This only applies to methods that do not return an HTTP response object. For methods that return an HTTP response object, such as SynchronousRequest, the status text is found in the StatusText property of the response object.
topLMFactor
set intVal [CkHttp_get_LMFactor $myHttp]
CkHttp_put_LMFactor $myHttp $intVal
An integer between 1 and 100 that indicates the percentage of time from the HTTP page's last-modified date that will be used for the freshness period. The default value is 25. For example, if a page is fetched with a last-modified date of 4 weeks ago, and the LMFactor = 25, then the page will be considered fresh in the cache for 1 week (25% of 4 weeks).
topLogin
# ckStr is a CkString
CkHttp_get_Login $myHttp $ckStr
set strVal [CkHttp_get_login $myHttp]
CkHttp_put_Login $myHttp $strVal
The HTTP login for pages requiring a login/password. Chilkat HTTP can do Basic, Digest, and NTLM HTTP authentication. (NTLM is also known as SPA (or Windows Integrated Authentication). To use Basic authentication, the BasicAuth property must be set equal to 1. It is not necessary to set the NtlmAuth or DigestAuth properties beforehand if NTLM or Digest authentication is needed. However, it is most efficient to pre-set these properties when the type of authentication is known in advance.
Important: If NTLM authentication is used, it may be incorrect to set the Login property equal to "mydomain\mylogin". Instead, set the LoginDomain property equal to "mydomain", and set this property equal to "mylogin".
Note: When the Login and Password properties are set, and the type of authentication is specified by setting one of the following properties equal to 1 (BasicAuth, DigestAuth, NtlmAuth), Chilkat will automatically add the "Authorization: ..." header in the correct format.
LoginDomain
# ckStr is a CkString
CkHttp_get_LoginDomain $myHttp $ckStr
set strVal [CkHttp_get_loginDomain $myHttp]
CkHttp_put_LoginDomain $myHttp $strVal
The optional domain name to be used with NTLM / Negotiate authentication.
topMaxConnections
set intVal [CkHttp_get_MaxConnections $myHttp]
CkHttp_put_MaxConnections $myHttp $intVal
The maximum number of simultaneous open HTTP connections managed by the HTTP component. The Chilkat HTTP component automatically manages HTTP connections. If the number of open HTTP connections is about to be exceeded, the connection with the least recent activity is automatically closed.
topMaxFreshPeriod
set intVal [CkHttp_get_MaxFreshPeriod $myHttp]
CkHttp_put_MaxFreshPeriod $myHttp $intVal
Limits the amount of time a document can be kept "fresh" in the cache. The MaxFreshPeriod is specified in minutes, and the default value is 525600 which is equal to 1 year.
topMaxResponseSize
set intVal [CkHttp_get_MaxResponseSize $myHttp]
CkHttp_put_MaxResponseSize $myHttp $intVal
The maximum HTTP response size to be accepted by the calling program. A value of 0 (the default) indicates that there is no maximum value.
topMaxUrlLen
set intVal [CkHttp_get_MaxUrlLen $myHttp]
CkHttp_put_MaxUrlLen $myHttp $intVal
The Http class will automatically fail any URL longer than this length. The default MaxUrlLen is 2000 characters.
topMimicFireFox
set boolVal [CkHttp_get_MimicFireFox $myHttp]
CkHttp_put_MimicFireFox $myHttp $boolVal
If set to 1, then the appropriate headers to mimic Mozilla/FireFox are automatically added to requests sent via the QuickGet and QuickGetStr methods.
topMimicIE
set boolVal [CkHttp_get_MimicIE $myHttp]
CkHttp_put_MimicIE $myHttp $boolVal
If set to 1, then the appropriate headers to mimic Internet Explorer are automatically added to requests sent via the QuickGet and QuickGetStr methods.
topMinFreshPeriod
set intVal [CkHttp_get_MinFreshPeriod $myHttp]
CkHttp_put_MinFreshPeriod $myHttp $intVal
The freshness period for a document in cache will not be less than this value (in minutes). The default value is 30.
topNegotiateAuth
set boolVal [CkHttp_get_NegotiateAuth $myHttp]
CkHttp_put_NegotiateAuth $myHttp $boolVal
Set this property equal to 1 for Negotiate authentication.
Note: The NegotiateAuth property is only available for the Microsoft Windows operating system.
NtlmAuth
set boolVal [CkHttp_get_NtlmAuth $myHttp]
CkHttp_put_NtlmAuth $myHttp $boolVal
Setting this property to 1 causes the HTTP component to use NTLM authentication (also known as IWA -- or Integrated Windows Authentication) when authentication with an HTTP server. The default value is 0.
NumCacheLevels
set intVal [CkHttp_get_NumCacheLevels $myHttp]
CkHttp_put_NumCacheLevels $myHttp $intVal
The number of directory levels to be used under each cache root. The default is 0, meaning that each cached HTML page is stored in a cache root directory. A value of 1 causes each cached page to be stored in one of 255 subdirectories named "0","1", "2", ..."255" under a cache root. A value of 2 causes two levels of subdirectories ("0..255/0..255") under each cache root. The HTTP control automatically creates subdirectories as needed. The reason for mutliple levels is to alleviate problems that may arise with unrelated software when huge numbers of files are stored in a single directory. For example, Windows Explorer does not behave well when trying to display the contents of directories with thousands of files.
NumCacheRoots
set intVal [CkHttp_get_NumCacheRoots $myHttp]
The number of cache roots to be used for the HTTP cache. This allows the disk cache spread out over multiple disk drives. Each cache root is a string indicating the drive letter and directory path. For example, "E:\Cache". An example of a very large low-cost cache might be four USB external drives. To create a cache with four roots, call AddCacheRoot once for each directory root.
topOAuth1
set boolVal [CkHttp_get_OAuth1 $myHttp]
CkHttp_put_OAuth1 $myHttp $boolVal
If 1 then causes an OAuth Authorization header to be added to any request sent by the HTTP object. For example:
Authorization: OAuth realm="http://sp.example.com/", oauth_consumer_key="0685bd9184jfhq22", oauth_token="ad180jjd733klru7", oauth_signature_method="HMAC-SHA1", oauth_signature="wOJIO9A2W5mFwDgiDvZbTSMK%2FPY%3D", oauth_timestamp="137131200", oauth_nonce="4572616e48616d6d65724c61686176", oauth_version="1.0"The information used to compute the OAuth Authorization header is obtained from the other OAuth* properties, such as OAuthConsumerKey, OAuthConsumerSecret, OAuthRealm, etc.
OAuthBodyHash
set boolVal [CkHttp_get_OAuthBodyHash $myHttp]
CkHttp_put_OAuthBodyHash $myHttp $boolVal
If set to 1, then the oauth_body_hash is automatically added to an OAuth1 Authorization header. The oauth_body_hash contains the SHA-256 hash of the HTTP request body that is sent.
topOAuthCallback
# ckStr is a CkString
CkHttp_get_OAuthCallback $myHttp $ckStr
set strVal [CkHttp_get_oAuthCallback $myHttp]
CkHttp_put_OAuthCallback $myHttp $strVal
The OAuth 1.0 callback URL. Defaults to "oob".
topOAuthConsumerKey
# ckStr is a CkString
CkHttp_get_OAuthConsumerKey $myHttp $ckStr
set strVal [CkHttp_get_oAuthConsumerKey $myHttp]
CkHttp_put_OAuthConsumerKey $myHttp $strVal
The OAuth consumer key to be used in the Authorization header.
topOAuthConsumerSecret
# ckStr is a CkString
CkHttp_get_OAuthConsumerSecret $myHttp $ckStr
set strVal [CkHttp_get_oAuthConsumerSecret $myHttp]
CkHttp_put_OAuthConsumerSecret $myHttp $strVal
The OAuth consumer secret to be used in computing the contents of the Authorization header.
topOAuthRealm
# ckStr is a CkString
CkHttp_get_OAuthRealm $myHttp $ckStr
set strVal [CkHttp_get_oAuthRealm $myHttp]
CkHttp_put_OAuthRealm $myHttp $strVal
The OAuth realm to be used in the Authorization header.
topOAuthSigMethod
# ckStr is a CkString
CkHttp_get_OAuthSigMethod $myHttp $ckStr
set strVal [CkHttp_get_oAuthSigMethod $myHttp]
CkHttp_put_OAuthSigMethod $myHttp $strVal
The OAuth signature method, such as "HMAC-SHA1" to be used in the Authorization header. The default is "HMAC-SHA1". It is also possible to choose "HMAC-SHA256", "RSA-SHA1" or "RSA-SHA2". For RSA algorithms, an RSA private key would need to be provided via the SetOAuthRsaKey method.
Note: RSA-SHA2 is supported starting in Chilkat v9.5.0.56
topOAuthToken
# ckStr is a CkString
CkHttp_get_OAuthToken $myHttp $ckStr
set strVal [CkHttp_get_oAuthToken $myHttp]
CkHttp_put_OAuthToken $myHttp $strVal
The OAuth1 token to be used in the Authorization header. Note: This is for OAuth1. Use the AuthToken property for OAuth2.
OAuthTokenSecret
# ckStr is a CkString
CkHttp_get_OAuthTokenSecret $myHttp $ckStr
set strVal [CkHttp_get_oAuthTokenSecret $myHttp]
CkHttp_put_OAuthTokenSecret $myHttp $strVal
The OAuth token secret to be used in computing the Authorization header.
topOAuthVerifier
# ckStr is a CkString
CkHttp_get_OAuthVerifier $myHttp $ckStr
set strVal [CkHttp_get_oAuthVerifier $myHttp]
CkHttp_put_OAuthVerifier $myHttp $strVal
The OAuth verifier to be used in the Authorization header.
topPassword
# ckStr is a CkString
CkHttp_get_Password $myHttp $ckStr
set strVal [CkHttp_get_password $myHttp]
CkHttp_put_Password $myHttp $strVal
The HTTP password for pages requiring a login/password. Chilkat HTTP can do Basic, Digest, and NTLM HTTP authentication. (NTLM is also known as SPA (or Windows Integrated Authentication). To use Basic authentication, the BasicAuth property must be set equal to 1. It is not necessary to set the NtlmAuth or DigestAuth properties beforehand if NTLM or Digest authentication is needed. However, it is most efficient to pre-set these properties when the type of authentication is known in advance.
Note: When the Login and Password properties are set, and the type of authentication is specified by setting one of the following properties equal to 1 (BasicAuth, DigestAuth, NtlmAuth), Chilkat will automatically add the "Authorization: ..." header in the correct format.
topPreferIpv6
set boolVal [CkHttp_get_PreferIpv6 $myHttp]
CkHttp_put_PreferIpv6 $myHttp $boolVal
If 1, then use IPv6 over IPv4 when both are supported for a particular domain. The default value of this property is 0, which will choose IPv4 over IPv6.
topProxyAuthMethod
# ckStr is a CkString
CkHttp_get_ProxyAuthMethod $myHttp $ckStr
set strVal [CkHttp_get_proxyAuthMethod $myHttp]
CkHttp_put_ProxyAuthMethod $myHttp $strVal
Set this to "basic" if you know in advance that Basic authentication is to be used for the HTTP proxy. Otherwise leave this property unset. Note: It is not necessary to set this property. The HTTP component will automatically handle proxy authentication for any of the supported authentication methods: NTLM, Digest, or Basic. Setting this property equal to "basic" prevents the 407 response which is automatically handled internal to Chilkat and never seen by your application.
Note: If NTLM authentication does not succeed, set the Global.DefaultNtlmVersion property equal to 1 and then retry.
topProxyDirectTls
set boolVal [CkHttp_get_ProxyDirectTls $myHttp]
CkHttp_put_ProxyDirectTls $myHttp $boolVal
Set to 1 if the proxy server expects a direct TLS connection. (This is where the initial connection to the HTTP proxy server is TLS. See Squid Direct TLS Connection. The default value of this property is 0.
ProxyDomain
# ckStr is a CkString
CkHttp_get_ProxyDomain $myHttp $ckStr
set strVal [CkHttp_get_proxyDomain $myHttp]
CkHttp_put_ProxyDomain $myHttp $strVal
The domain name of a proxy host if an HTTP proxy is used. This can also be set to an IP address.
ProxyLogin
# ckStr is a CkString
CkHttp_get_ProxyLogin $myHttp $ckStr
set strVal [CkHttp_get_proxyLogin $myHttp]
CkHttp_put_ProxyLogin $myHttp $strVal
If an HTTP proxy is used and it requires authentication, this property specifies the HTTP proxy login.
topProxyLoginDomain
# ckStr is a CkString
CkHttp_get_ProxyLoginDomain $myHttp $ckStr
set strVal [CkHttp_get_proxyLoginDomain $myHttp]
CkHttp_put_ProxyLoginDomain $myHttp $strVal
The NTLM authentication domain (optional) if NTLM authentication is used.
topProxyPassword
# ckStr is a CkString
CkHttp_get_ProxyPassword $myHttp $ckStr
set strVal [CkHttp_get_proxyPassword $myHttp]
CkHttp_put_ProxyPassword $myHttp $strVal
If an HTTP proxy is used and it requires authentication, this property specifies the HTTP proxy password.
ProxyPort
set intVal [CkHttp_get_ProxyPort $myHttp]
CkHttp_put_ProxyPort $myHttp $intVal
The port number of a proxy server if an HTTP proxy is used.
topReadTimeout
set intVal [CkHttp_get_ReadTimeout $myHttp]
CkHttp_put_ReadTimeout $myHttp $intVal
The amount of time in seconds to wait before timing out when reading from an HTTP server. The ReadTimeout is the amount of time that needs to elapse while no additional data is forthcoming. During a long download, if the data stream halts for more than this amount, it will timeout. Otherwise, there is no limit on the length of time for the entire download.
The default value is 60 seconds. Note: Prior to v9.5.0.76, the default was 20 seconds.
topReceivedCertReq
set boolVal [CkHttp_get_ReceivedCertReq $myHttp]
Indicates whether the last HTTPS connection received a TLS CertificateRequest handshake message indicating that the server may require a client certificate.
topRedirectVerb
# ckStr is a CkString
CkHttp_get_RedirectVerb $myHttp $ckStr
set strVal [CkHttp_get_redirectVerb $myHttp]
CkHttp_put_RedirectVerb $myHttp $strVal
Indicates the HTTP verb, such as GET, POST, PUT, etc. to be used for a redirect when the FollowRedirects property is set to 1. The default value of this property is "GET". This will produce the same behavior as a web browser (such as FireFox). If this property is set to the empty string, then it will cause the same verb as the original HTTP request to be used.
Note: Prior to version 9.5.0.44, the default value of this property was the empty string.
topReferer
# ckStr is a CkString
CkHttp_get_Referer $myHttp $ckStr
set strVal [CkHttp_get_referer $myHttp]
CkHttp_put_Referer $myHttp $strVal
The Referer header field to be automatically included with GET requests issued by QuickGet or QuickGetStr. The default value is the empty string which causes the Referer field to be omitted from the request header.
topRequiredContentType
# ckStr is a CkString
CkHttp_get_RequiredContentType $myHttp $ckStr
set strVal [CkHttp_get_requiredContentType $myHttp]
CkHttp_put_RequiredContentType $myHttp $strVal
If set, then any HTTP response to any POST or GET, including downloads, will be rejected if the content-type in the response header does not match this setting. If the content-type does not match, only the header of the HTTP response is read, the connection to the HTTP server is closed, and the remainder of the response is never read.
This property is empty (zero-length string) by default.
Some typical content-types are "text/html", "text/xml", "image/gif", "image/jpeg", "application/zip", "application/msword", "application/pdf", etc.
topRequireSslCertVerify
set boolVal [CkHttp_get_RequireSslCertVerify $myHttp]
CkHttp_put_RequireSslCertVerify $myHttp $boolVal
If 1, then the HTTP client will verify the server's SSL certificate. The certificate is expired, or if the cert's signature is invalid, the connection is not allowed. The default value of this property is 0.
S3Ssl
set boolVal [CkHttp_get_S3Ssl $myHttp]
CkHttp_put_S3Ssl $myHttp $boolVal
If 1, then all S3_* methods will use a secure SSL/TLS connection for communications. The default value is 1.
topSaveCookies
set boolVal [CkHttp_get_SaveCookies $myHttp]
CkHttp_put_SaveCookies $myHttp $boolVal
If this property is 1, cookies are automatically persisted to XML files in the directory specified by the CookiesDir property (or in memory if CookieDir = "memory"). Both CookiesDir and SaveCookies must be set for cookies to be persisted.
SendBufferSize
set intVal [CkHttp_get_SendBufferSize $myHttp]
CkHttp_put_SendBufferSize $myHttp $intVal
The buffer size to be used with the underlying TCP/IP socket for sending. The default value is 65535.
topSendCookies
set boolVal [CkHttp_get_SendCookies $myHttp]
CkHttp_put_SendCookies $myHttp $boolVal
If 1, then cookies previously persisted to the CookiesDir are automatically added to all HTTP requests. Only cookies matching the domain and path are added.
SessionLogFilename
# ckStr is a CkString
CkHttp_get_SessionLogFilename $myHttp $ckStr
set strVal [CkHttp_get_sessionLogFilename $myHttp]
CkHttp_put_SessionLogFilename $myHttp $strVal
Enables file-based session logging. If set to a filename (or relative/absolute filepath), then the exact HTTP requests and responses are logged to a file. The file is created if it does not already exist, otherwise it is appended.
SniHostname
# ckStr is a CkString
CkHttp_get_SniHostname $myHttp $ckStr
set strVal [CkHttp_get_sniHostname $myHttp]
CkHttp_put_SniHostname $myHttp $strVal
Specifies the SNI hostname to be used in the TLS ClientHello. This property is only needed when the domain is specified via a dotted IP address and an SNI hostname is desired. (Normally, Chilkat automatically uses the domain name in the SNI hostname TLS ClientHello extension.)
topSocksHostname
# ckStr is a CkString
CkHttp_get_SocksHostname $myHttp $ckStr
set strVal [CkHttp_get_socksHostname $myHttp]
CkHttp_put_SocksHostname $myHttp $strVal
The SOCKS4/SOCKS5 hostname or IPv4 address (in dotted decimal notation). This property is only used if the SocksVersion property is set to 4 or 5).
SocksPassword
# ckStr is a CkString
CkHttp_get_SocksPassword $myHttp $ckStr
set strVal [CkHttp_get_socksPassword $myHttp]
CkHttp_put_SocksPassword $myHttp $strVal
The SOCKS5 password (if required). The SOCKS4 protocol does not include the use of a password, so this does not apply to SOCKS4.
topSocksPort
set intVal [CkHttp_get_SocksPort $myHttp]
CkHttp_put_SocksPort $myHttp $intVal
The SOCKS4/SOCKS5 proxy port. The default value is 1080. This property only applies if a SOCKS proxy is used (if the SocksVersion property is set to 4 or 5).
topSocksUsername
# ckStr is a CkString
CkHttp_get_SocksUsername $myHttp $ckStr
set strVal [CkHttp_get_socksUsername $myHttp]
CkHttp_put_SocksUsername $myHttp $strVal
The SOCKS4/SOCKS5 proxy username. This property is only used if the SocksVersion property is set to 4 or 5).
SocksVersion
set intVal [CkHttp_get_SocksVersion $myHttp]
CkHttp_put_SocksVersion $myHttp $intVal
SocksVersion May be set to one of the following integer values:
0 - No SOCKS proxy is used. This is the default.
4 - Connect via a SOCKS4 proxy.
5 - Connect via a SOCKS5 proxy.
SoRcvBuf
set intVal [CkHttp_get_SoRcvBuf $myHttp]
CkHttp_put_SoRcvBuf $myHttp $intVal
Sets the receive buffer size socket option. Normally, this property should be left unchanged. The default value is 4194304.
This property can be increased if download performance seems slow. It is recommended to be a multiple of 4096.
SoSndBuf
set intVal [CkHttp_get_SoSndBuf $myHttp]
CkHttp_put_SoSndBuf $myHttp $intVal
Sets the send buffer size socket option. Normally, this property should be left unchanged. The default value is 262144.
This property can be increased if upload performance seems slow. It is recommended to be a multiple of 4096. Testing with sizes such as 512K and 1MB is reasonable.
SslAllowedCiphers
# ckStr is a CkString
CkHttp_get_SslAllowedCiphers $myHttp $ckStr
set strVal [CkHttp_get_sslAllowedCiphers $myHttp]
CkHttp_put_SslAllowedCiphers $myHttp $strVal
Provides a means for setting a list of ciphers that are allowed for SSL/TLS connections. The default (empty string) indicates that all implemented ciphers are possible. The TLS ciphers supported in Chilkat v9.5.0.55 and later are:
TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256 TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256 TLS_DHE_RSA_WITH_CHACHA20_POLY1305_SHA256 TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA384 TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384 TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA TLS_DHE_RSA_WITH_AES_256_CBC_SHA256 TLS_DHE_RSA_WITH_AES_256_GCM_SHA384 TLS_DHE_RSA_WITH_AES_256_CBC_SHA TLS_RSA_WITH_AES_256_CBC_SHA256 TLS_RSA_WITH_AES_256_GCM_SHA384 TLS_RSA_WITH_AES_256_CBC_SHA TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256 TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256 TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA TLS_DHE_RSA_WITH_AES_128_CBC_SHA256 TLS_DHE_RSA_WITH_AES_128_GCM_SHA256 TLS_DHE_RSA_WITH_AES_128_CBC_SHA TLS_RSA_WITH_AES_128_CBC_SHA256 TLS_RSA_WITH_AES_128_GCM_SHA256 TLS_RSA_WITH_AES_128_CBC_SHA TLS_ECDHE_RSA_WITH_3DES_EDE_CBC_SHA TLS_DHE_RSA_WITH_3DES_EDE_CBC_SHA TLS_RSA_WITH_3DES_EDE_CBC_SHA TLS_ECDHE_RSA_WITH_RC4_128_SHA TLS_RSA_WITH_RC4_128_SHA TLS_RSA_WITH_RC4_128_MD5 TLS_DHE_RSA_WITH_DES_CBC_SHA TLS_RSA_WITH_DES_CBC_SHATo restrict SSL/TLS connections to one or more specific ciphers, set this property to a comma-separated list of ciphers such as "TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA384, TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384". The order should be in terms of preference, with the preferred algorithms listed first. (Note that the client cannot specifically choose the algorithm is picked because it is the server that chooses. The client simply provides the server with a list from which to choose.)
The property can also disallow connections with servers having certificates with RSA keys less than a certain size. By default, server certificates having RSA keys of 512 bits or greater are allowed. Add the keyword "rsa1024" to disallow connections with servers having keys smaller than 1024 bits. Add the keyword "rsa2048" to disallow connections with servers having keys smaller than 2048 bits.
Note: Prior to Chilkat v9.5.0.55, it was not possible to explicitly list allowed cipher suites. The deprecated means for indicating allowed ciphers was both incomplete and unprecise. For example, the following keywords could be listed to allow matching ciphers: "aes256-cbc", "aes128-cbc", "3des-cbc", and "rc4". These keywords will still be recognized, but programs should be updated to explicitly list the allowed ciphers.
secure-renegotiation: Starting in Chilkat v9.5.0.55, the keyword "secure-renegotiation" may be added to require that all renegotions be done securely (as per RFC 5746).
best-practices: Starting in Chilkat v9.5.0.55, this property may be set to the single keyword "best-practices". This will allow ciphers based on the current best practices. As new versions of Chilkat are released, the best practices may change. Changes will be noted here. The current best practices are:
- If the server uses an RSA key, it must be 1024 bits or greater.
- All renegotations must be secure renegotiations.
- All ciphers using RC4, DES, or 3DES are disallowed.
Example: The following string would restrict to 2 specific cipher suites, require RSA keys to be 1024 bits or greater, and require secure renegotiations: "TLS_DHE_RSA_WITH_AES_256_CBC_SHA256, TLS_RSA_WITH_AES_256_CBC_SHA, rsa1024, secure-renegotiation"
topSslProtocol
# ckStr is a CkString
CkHttp_get_SslProtocol $myHttp $ckStr
set strVal [CkHttp_get_sslProtocol $myHttp]
CkHttp_put_SslProtocol $myHttp $strVal
Selects the SSL/TLS protocol version to be used for connections. Possible values are:
defaultThe default value is "default" which allows for the protocol to be selected dynamically at runtime based on the requirements of the server. Choosing an exact protocol will cause the connection to fail unless that exact protocol is negotiated. It is better to choose "X or higher" than an exact protocol. The "default" is effectively "SSL 3.0 or higher". top
TLS 1.3
TLS 1.2
TLS 1.1
TLS 1.0
SSL 3.0
TLS 1.3 or higher
TLS 1.2 or higher
TLS 1.1 or higher
TLS 1.0 or higher
StreamResponseBodyPath
# ckStr is a CkString
CkHttp_get_StreamResponseBodyPath $myHttp $ckStr
set strVal [CkHttp_get_streamResponseBodyPath $myHttp]
CkHttp_put_StreamResponseBodyPath $myHttp $strVal
Allows for the HTTP response body to be streamed directly into a file. If this property is set, then any method returning an HTTP response object will stream the response body directly to the file path specified. The HTTP response object will still contain the response header. (This property is useful when the HTTP response is too large to fit into memory.)
topTlsCipherSuite
# ckStr is a CkString
CkHttp_get_TlsCipherSuite $myHttp $ckStr
set strVal [CkHttp_get_tlsCipherSuite $myHttp]
Contains the current or last negotiated TLS cipher suite. If no TLS connection has yet to be established, or if a connection as attempted and failed, then this will be empty. A sample cipher suite string looks like this: TLS_DHE_RSA_WITH_AES_256_CBC_SHA256.
topTlsPinSet
# ckStr is a CkString
CkHttp_get_TlsPinSet $myHttp $ckStr
set strVal [CkHttp_get_tlsPinSet $myHttp]
CkHttp_put_TlsPinSet $myHttp $strVal
Specifies a set of pins for Public Key Pinning for TLS connections. This property lists the expected SPKI fingerprints for the server certificates. If the server's certificate (sent during the TLS handshake) does not match any of the SPKI fingerprints, then the TLS handshake is aborted and the connection fails. The format of this string property is as follows:
hash_algorithm, encoding, SPKI_fingerprint_1, SPKI_fingerprint_2, ...For example, the following string specifies a single sha256 base64-encoded SPKI fingerprint:
"sha256, base64, lKg1SIqyhPSK19tlPbjl8s02yChsVTDklQpkMCHvsTE="This example specifies two SPKI fingerprints:
"sha256, base64, 4t37LpnGmrMEAG8HEz9yIrnvJV2euVRwCLb9EH5WZyI=, 68b0G5iqMvWVWvUCjMuhLEyekM5729PadtnU5tdXZKs="Any of the following hash algorithms are allowed:.sha1, sha256, sha384, sha512, md2, md5, haval, ripemd128, ripemd160,ripemd256, or ripemd320.
The following encodings are allowed: base64, hex, and any of the encodings indicated in the link below.
TlsVersion
# ckStr is a CkString
CkHttp_get_TlsVersion $myHttp $ckStr
set strVal [CkHttp_get_tlsVersion $myHttp]
Contains the current or last negotiated TLS protocol version. If no TLS connection has yet to be established, or if a connection as attempted and failed, then this will be empty. Possible values are "SSL 3.0", "TLS 1.0", "TLS 1.1", "TLS 1.2", and "TLS 1.3".
topUncommonOptions
# ckStr is a CkString
CkHttp_get_UncommonOptions $myHttp $ckStr
set strVal [CkHttp_get_uncommonOptions $myHttp]
CkHttp_put_UncommonOptions $myHttp $strVal
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:
- "QuickDisconnect" - Introduced in v9.5.0.77. In the call to CloseAllConnections, do not disconnect cleanly. Instead just disconnect as quickly as possible.
- "ProtectFromVpn" - Introduced in v9.5.0.80. On Android systems, will bypass any VPN that may be installed or active.
- "TlsNoClientRootCert" - Introduced in v9.5.0.82. Will exclude root CA certs from being included in the client certificate chain that is sent to the server for client-side authentication. This must be set prior to calling SetSslClientCert.
- "AllowEmptyHeaders" - Introduced in v9.5.0.82. If present, an empty value string passed to SetHeaderField will cause the header to be added with an empty value. Otherwise, for historical purposes and backward compatibility, the header field is removed when an empty value string is passed.
- "AnsiLogin" - Introduced in v9.5.0.87. For HTTP basic authentication, the login and password is sent using the utf-8 byte representation. Some servers expect the ANSI byte representation (typically Windows-1252). Use this keyword to send the login/password using ANSI.
UpdateCache
set boolVal [CkHttp_get_UpdateCache $myHttp]
CkHttp_put_UpdateCache $myHttp $boolVal
Controls whether the cache is automatically updated with the responses from HTTP GET requests.
UseIEProxy
set boolVal [CkHttp_get_UseIEProxy $myHttp]
CkHttp_put_UseIEProxy $myHttp $boolVal
If 1, the proxy address/port used by Internet Explorer will also be used by Chilkat HTTP. Note: This property only pays attention to the proxy address and port, and does not pay attention to additional information such as IE proxy server exceptions.
topUserAgent
# ckStr is a CkString
CkHttp_get_UserAgent $myHttp $ckStr
set strVal [CkHttp_get_userAgent $myHttp]
CkHttp_put_UserAgent $myHttp $strVal
This property, if set, is the value of the User-Agent header field to be automatically included with GET requests issued by QuickGet or QuickGetStr. The default value is the empty string and no User-Agent header field will be sent.
topUtf8
set boolVal [CkHttp_get_Utf8 $myHttp]
CkHttp_put_Utf8 $myHttp $boolVal
When set to 1, all "const char *" arguments are interpreted as utf-8 strings. If set to 0 (the default), then "const char *" arguments are interpreted as ANSI strings. Also, when set to 1, and Chilkat method returning a "const char *" is returning the utf-8 representation. If set to 0, all "const char *" return values are ANSI strings.
topVerboseLogging
set boolVal [CkHttp_get_VerboseLogging $myHttp]
CkHttp_put_VerboseLogging $myHttp $boolVal
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.
topVersion
# ckStr is a CkString
CkHttp_get_Version $myHttp $ckStr
set strVal [CkHttp_get_version $myHttp]
WasRedirected
set boolVal [CkHttp_get_WasRedirected $myHttp]
Indicates whether the last HTTP request was redirected (i.e. the redirect was automatically followed). If FollowRedirects is 0 and the response status code is 301, 302, 303, 307, or 308, then this property will remain 0 but the FinalRedirectUrl will contain the redirect URL that was not automatically followed.
topMethods
AddCacheRoot
CkHttp_AddCacheRoot $dir
This method must be called at least once if disk caching is to be used. The file path (including drive letter) such as "E:\MyHttpCache\" is passed to AddCacheRoot to specify the root directory. The cache can be spread across multiple disk drives by calling AddCacheRoot multiple times, each with a directory path on a separate disk drive.
ClearHeaders
Removes all headers added via the SetRequestHeader method.
topClearInMemoryCookies
Clears all cookies cached in memory. Calling this only makes sense if the CookieDir property is set to the string "memory".
topClearUrlVars
Clears all URL variable values previously set by one or more calls to SetUrlVar.
topCloseAllConnections
Closes all connections still open from previous HTTP requests.
An HTTP object instance will maintain up to 10 connections. If the HTTP server's response does not include a "Connection: Close" header, the connection will remain open and will be re-used if possible for the next HTTP request to the same hostname:port. (It uses the IP address (in string form) or the domain name, whichever is used in the URL provided by the application.) If 10 connections are already open and another is needed, the object will close the least recently used connection.
Returns 1 for success, 0 for failure.
topCloseAllConnectionsAsync (1)
set ret_task [CkHttp_CloseAllConnectionsAsync]
Creates an asynchronous task to call the CloseAllConnections method with the arguments provided.
Returns NULL on failure
topCreateOcspRequest
# ocspRequest is a CkBinData
set status [CkHttp_CreateOcspRequest $requestDetails $ocspRequest]
Creates an OCSP request for one or more certificates. The requestDetails is a JSON document describing the content of the OCSP request to be created. The examples in the links below show how to build the JSON request details.
Note: This method only creates an OCSP request. After creating, it may be sent to a server to get the OCSP response.
Returns 1 for success, 0 for failure.
CreateTimestampRequest
# hashVal is a string
# reqPolicyOid is a string
# addNonce is a boolean
# reqTsaCert is a boolean
# timestampToken is a CkBinData
set status [CkHttp_CreateTimestampRequest $hashAlg $hashVal $reqPolicyOid $addNonce $reqTsaCert $timestampToken]
Creates an RFC 3161 time-stamp request and returns the binary request token in timestampToken. The hashAlg can be "sha1", "sha256", "sha384", "sha512", or "md5", The hashVal is the base64 hash of the data to be timestamped. The optional reqPolicyOid is the requested policy OID in a format such as "1.3.6.1.4.1.47272.1.2". The addNonce indicates whether to auto-generate and include a nonce in the request. It may be 1 or 0. The reqTsaCert determines whether or not to request the TSA's certificate (1 = Yes, 0 = No).
Note: This method only creates a timestamp request. After creating, it may be sent to a server to get the binary timestamp token.
Returns 1 for success, 0 for failure.
DnsCacheClear
Clears the Chilkat-wide in-memory hostname-to-IP address DNS cache. Chilkat automatically maintains this in-memory cache to prevent redundant DNS lookups. If the TTL on the DNS A records being accessed are short and/or these DNS records change frequently, then this method can be called clear the internal cache. Note: The DNS cache is used/shared among all Chilkat objects in a program, and clearing the cache affects all Chilkat objects.
topDownload
# localFilePath is a string
set status [CkHttp_Download $url $localFilePath]
Retrieves the content at a URL and saves to a file. All content is saved in streaming mode such that the memory footprint is small and steady. HTTPS is fully supported, as it is with all the methods of this class.
Returns 1 for success, 0 for failure.
DownloadAsync (1)
# url is a string
# localFilePath is a string
set ret_task [CkHttp_DownloadAsync $url $localFilePath]
Creates an asynchronous task to call the Download method with the arguments provided.
Returns NULL on failure
topDownloadAppend
# filename is a string
set status [CkHttp_DownloadAppend $url $filename]
Same as the Download method, but the output file is open for append.
Returns 1 for success, 0 for failure.
DownloadAppendAsync (1)
# url is a string
# filename is a string
set ret_task [CkHttp_DownloadAppendAsync $url $filename]
Creates an asynchronous task to call the DownloadAppend method with the arguments provided.
Returns NULL on failure
topDownloadBd
# binData is a CkBinData
set status [CkHttp_DownloadBd $url $binData]
Downloads the content at the url into a BinData object.
Returns 1 for success, 0 for failure.
DownloadBdAsync (1)
# url is a string
# binData is a CkBinData
set ret_task [CkHttp_DownloadBdAsync $url $binData]
Creates an asynchronous task to call the DownloadBd method with the arguments provided.
Returns NULL on failure
topDownloadHash
# hashAlgorithm is a string
# encoding is a string
# outStr is a CkString (output)
set status [CkHttp_DownloadHash $url $hashAlgorithm $encoding $outStr]
set retStr [CkHttp_downloadHash $myHttp $url $hashAlgorithm $encoding]
Retrieves the content at a URL and computes and returns a hash of the content. The hash is returned as an encoded string according to the encoding, which may be "Base64", "modBase64", "Base32", "UU", "QP" (for quoted-printable), "URL" (for url-encoding), "Hex", "Q", "B", "url_oath", "url_rfc1738", "url_rfc2396", and "url_rfc3986". The hashAlgorithm may be "sha1", "sha256", "sha384", "sha512", "md2", "md5", "haval", "ripemd128", "ripemd160","ripemd256", or "ripemd320".
Returns 1 for success, 0 for failure.
DownloadHashAsync (1)
# url is a string
# hashAlgorithm is a string
# encoding is a string
set ret_task [CkHttp_DownloadHashAsync $url $hashAlgorithm $encoding]
Creates an asynchronous task to call the DownloadHash method with the arguments provided.
Returns NULL on failure
topDownloadSb
# charset is a string
# sb is a CkStringBuilder
set status [CkHttp_DownloadSb $url $charset $sb]
Downloads the content at the url into a Chilkat StringBuilder object. The charset tells Chilkat how to interpret the bytes received. The sb is appended with the downloaded text data.
Returns 1 for success, 0 for failure.
DownloadSbAsync (1)
# url is a string
# charset is a string
# sb is a CkStringBuilder
set ret_task [CkHttp_DownloadSbAsync $url $charset $sb]
Creates an asynchronous task to call the DownloadSb method with the arguments provided.
Returns NULL on failure
topExtractMetaRefreshUrl
# outStr is a CkString (output)
set status [CkHttp_ExtractMetaRefreshUrl $htmlContent $outStr]
set retStr [CkHttp_extractMetaRefreshUrl $myHttp $htmlContent]
Convenience method for extracting the META refresh URL from HTML. For example, if the htmlContent contains a META refresh tag, such as:
<meta http-equiv="refresh" content="5;URL='http://example.com/'">Then the return value of this method would be "http://example.com/".
Returns 1 for success, 0 for failure.
topG_SvcOauthAccessToken
# scope is a string
# subEmail is a string
# numSec is an integer
# cert is a CkCert
# outStr is a CkString (output)
set status [CkHttp_G_SvcOauthAccessToken $iss $scope $subEmail $numSec $cert $outStr]
set retStr [CkHttp_g_SvcOauthAccessToken $myHttp $iss $scope $subEmail $numSec $cert]
Makes an access token request to obtain a Google API OAuth2 access token for a service account. Access tokens issued by the Google OAuth 2.0 Authorization Server expire one hour after they are issued. When an access token expires, then the application should generate another JWT, sign it, and request another access token. The iss is the service account email address of the application making the access token request. The scope is a space-delimited list of the permissions that the application requests. (See https://developers.google.com/accounts/docs/OAuth2ServiceAccount )
The subEmail is the email address of the user for which the application is requesting delegated access. The subEmail may be left empty if there is no such email address.
Returns 1 for success, 0 for failure.
G_SvcOauthAccessTokenAsync (1)
# iss is a string
# scope is a string
# subEmail is a string
# numSec is an integer
# cert is a CkCert
set ret_task [CkHttp_G_SvcOauthAccessTokenAsync $iss $scope $subEmail $numSec $cert]
Creates an asynchronous task to call the G_SvcOauthAccessToken method with the arguments provided.
Returns NULL on failure
topG_SvcOauthAccessToken2
# numSec is an integer
# cert is a CkCert
# outStr is a CkString (output)
set status [CkHttp_G_SvcOauthAccessToken2 $claimParams $numSec $cert $outStr]
set retStr [CkHttp_g_SvcOauthAccessToken2 $myHttp $claimParams $numSec $cert]
The same as the G_SvcOauthAccessToken method, but with added flexibility for more customization. The 1st three args of the G_SvcOauthAccessToken are replaced with claimParams allowing for future expansion of name-value params. See the example below.
Returns 1 for success, 0 for failure.
G_SvcOauthAccessToken2Async (1)
# claimParams is a CkHashtable
# numSec is an integer
# cert is a CkCert
set ret_task [CkHttp_G_SvcOauthAccessToken2Async $claimParams $numSec $cert]
Creates an asynchronous task to call the G_SvcOauthAccessToken2 method with the arguments provided.
Returns NULL on failure
topGenTimeStamp
set status [CkHttp_GenTimeStamp $outStr]
set retStr [CkHttp_genTimeStamp $myHttp]
Returns the current GMT (also known as UTC) date/time in a string that is compliant with RFC 2616 format.
Returns 1 for success, 0 for failure.
topGetCacheRoot
# outStr is a CkString (output)
set status [CkHttp_GetCacheRoot $index $outStr]
set retStr [CkHttp_getCacheRoot $myHttp $index]
Returns the Nth cache root (indexing begins at 0). Cache roots are set by calling AddCacheRoot one or more times.
Returns 1 for success, 0 for failure.
topGetCookieXml
# outStr is a CkString (output)
set status [CkHttp_GetCookieXml $domain $outStr]
set retStr [CkHttp_getCookieXml $myHttp $domain]
Returns the cookies in XML format for a specific domain. Cookies are only persisted if the SaveCookies property is set to 1. If the CookieDir property is set to the keyword "memory", then cookies are saved in-memory.
Returns 1 for success, 0 for failure.
GetDomain
# outStr is a CkString (output)
set status [CkHttp_GetDomain $url $outStr]
set retStr [CkHttp_getDomain $myHttp $url]
Utility method for extracting the domain name from a full URL. For example, if "https://www.chilkatsoft.com/default.asp" is the URL passed in, then "www.chilkatsoft.com" is returned.
Returns 1 for success, 0 for failure.
topGetHead
# url is a string
set ret_httpResponse [CkHttp_GetHead $url]
Sends an HTTP HEAD request for a URL and returns a response object. (Note: HEAD requests will never automatically follow redirects.)
Returns NULL on failure
GetHeadAsync (1) (2)
# url is a string
set ret_task [CkHttp_GetHeadAsync $url]
Creates an asynchronous task to call the GetHead method with the arguments provided.
Returns NULL on failure
topGetRequestHeader
# outStr is a CkString (output)
set status [CkHttp_GetRequestHeader $name $outStr]
set retStr [CkHttp_getRequestHeader $myHttp $name]
Returns the value of a header field that has been pre-defined to be sent with all HTTP GET requests issued by the QuickGet and QuickGetStr methods. By default, this includes header fields such as Accept, AcceptCharset, AcceptLanguage, Connection, UserAgent, etc.
Returns 1 for success, 0 for failure.
topGetServerSslCert
# domain is a string
# port is an integer
set ret_cert [CkHttp_GetServerSslCert $domain $port]
Establishes an SSL/TLS connection with a web server for the purpose of retrieving the server's SSL certificate (public-key only of course...). Nothing is retrieved from the web server. This method simply makes a connection, gets the certificate information, and closes the connection.
Returns NULL on failure
GetServerSslCertAsync (1) (2)
# domain is a string
# port is an integer
set ret_task [CkHttp_GetServerSslCertAsync $domain $port]
Creates an asynchronous task to call the GetServerSslCert method with the arguments provided.
Returns NULL on failure
topGetUrlPath
# outStr is a CkString (output)
set status [CkHttp_GetUrlPath $url $outStr]
set retStr [CkHttp_getUrlPath $myHttp $url]
Returns the path part of a URL. The syntax of a URL is <scheme>://<user>:<password>@<host>:<port>/<path>;<params>?<query>#<frag>. This method returns the "path" part.
Returns 1 for success, 0 for failure.
topHasRequestHeader
set retBool [CkHttp_HasRequestHeader $name]
Returns true if the specified header field is defined such that it will be sent with all GET requests issued by the QuickGet and QuickGetStr methods.
topLastJsonData
set ret_jsonObject [CkHttp_LastJsonData]
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 NULL on failure
topLoadTaskCaller
set status [CkHttp_LoadTaskCaller $task]
OcspCheck
# port is an integer
set retInt [CkHttp_OcspCheck $domain $port]
Gets the server certificate at a domain:port and then sends an OCSP request to the certificate's OCSP URL to determine if the certificate has been revoked. Returns the OCSP status, which has one of the following values:
- -1: Unable to check. See the contents of the LastErrorText property for more informaiton.
- 0: Good
- 1: Revoked
- 2: Unknown
OcspCheckAsync (1)
# domain is a string
# port is an integer
set ret_task [CkHttp_OcspCheckAsync $domain $port]
Creates an asynchronous task to call the OcspCheck method with the arguments provided.
Returns NULL on failure
topParseOcspReply
# replyData is a CkJsonObject
set retInt [CkHttp_ParseOcspReply $ocspReply $replyData]
Parses an OCSP reply. Returns the following possible integer values:
- -1: The ocspReply does not contain a valid OCSP reply.
- 0: Successful - Response has valid confirmations..
- 1: Malformed request - Illegal confirmation request.
- 2: Internal error - Internal error in issuer.
- 3: Try later - Try again later.
- 4: Not used - This value is never returned.
- 5: Sig required - Must sign the request.
- 6: Unauthorized - Request unauthorized.
The binaryOCSP reply is provided in ocspReply. The replyData is populated with data parsed from ocspReply.
PBinary
# verb is a string
# url is a string
# byteData is a CkByteData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_httpResponse [CkHttp_PBinary $verb $url $byteData $contentType $md5 $gzip]
Sends an HTTP request to the url. The verb can be "POST", "PUT", "PATCH", etc. The body of the HTTP request contains the bytes passed in byteData. The contentType is a content type such as "image/gif", "application/pdf", etc. If md5 is 1, then a Content-MD5 header is added with the base64 MD5 hash of the byteData. Servers aware of the Content-MD5 header will perform a message integrity check to ensure that the data has not been corrupted. If gzip is 1, the byteData is compressed using the gzip algorithm. The HTTP request body will contain the GZIP compressed data, and a "Content-Encoding: gzip" header is automatically added to indicate that the request data needs to be ungzipped when received (at the server).
Returns NULL on failure
topPBinaryAsync (1) (2)
# verb is a string
# url is a string
# byteData is a CkByteData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PBinaryAsync $verb $url $byteData $contentType $md5 $gzip]
Creates an asynchronous task to call the PBinary method with the arguments provided.
Returns NULL on failure
topPBinaryBd
# verb is a string
# url is a string
# data is a CkBinData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_httpResponse [CkHttp_PBinaryBd $verb $url $data $contentType $md5 $gzip]
The same as PBinary, but the data to be uploaded is passed in data.
Returns NULL on failure
PBinaryBdAsync (1) (2)
# verb is a string
# url is a string
# data is a CkBinData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PBinaryBdAsync $verb $url $data $contentType $md5 $gzip]
Creates an asynchronous task to call the PBinaryBd method with the arguments provided.
Returns NULL on failure
topPFile
# verb is a string
# url is a string
# localFilePath is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_httpResponse [CkHttp_PFile $verb $url $localFilePath $contentType $md5 $gzip]
Sends an HTTP/HTTPS request to the url. The verb can be "POST", "PUT", "PATCH", etc. The url can begin with "http://" or "https://" depending if TLS is desired. The body of the HTTP request is streamed directly from the localFilePath. The contentType is a content type such as "image/gif", "application/pdf", "text/xml", etc. If md5 is 1, then a Content-MD5 header is added with the base64 MD5 hash of the localFilePath. Servers aware of the Content-MD5 header will perform a message integrity check to ensure that the data has not been corrupted. If gzip is 1, the localFilePath is compressed using the gzip algorithm. The HTTP request body will contain the GZIP compressed data, and a "Content-Encoding: gzip" header is automatically added to indicate that the request data needs to be ungzipped when received (at the server).
Returns NULL on failure
PFileAsync (1) (2)
# verb is a string
# url is a string
# localFilePath is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PFileAsync $verb $url $localFilePath $contentType $md5 $gzip]
Creates an asynchronous task to call the PFile method with the arguments provided.
Returns NULL on failure
topPostBinary
# byteData is a CkByteData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
# outStr is a CkString (output)
set status [CkHttp_PostBinary $url $byteData $contentType $md5 $gzip $outStr]
set retStr [CkHttp_postBinary $myHttp $url $byteData $contentType $md5 $gzip]
Sends an HTTP POST request to the url. The body of the HTTP request contains the bytes passed in byteData. The contentType is a content type such as "image/gif", "application/pdf", etc. If md5 is 1, then a Content-MD5 header is added with the base64 MD5 hash of the byteData. Servers aware of the Content-MD5 header will perform a message integrity check to ensure that the data has not been corrupted. If gzip is 1, the byteData is compressed using the gzip algorithm. The HTTP request body will contain the GZIP compressed data, and a "Content-Encoding: gzip" header is automatically added to indicate that the request data needs to be ungzipped when received (at the server).
Returns the text body of the HTTP response if the HTTP response has a success status code. Otherwise the method is considered to have failed. If more details of the HTTP response are required, call PBinary instead (which returns the HTTP response object).
Note: The HTTP response code is available in the LastStatus property. Other properties having information include LastResponseHeader, LastResponseBody, LastModDate, LastContentType, etc.
Returns 1 for success, 0 for failure.
PostBinaryAsync (1)
# url is a string
# byteData is a CkByteData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PostBinaryAsync $url $byteData $contentType $md5 $gzip]
Creates an asynchronous task to call the PostBinary method with the arguments provided.
Returns NULL on failure
topPostJson
# url is a string
# jsonText is a string
set ret_httpResponse [CkHttp_PostJson $url $jsonText]
A simplified way of sending a JSON POST and receiving the JSON response. The HTTP response is returned in an HTTP response object. The content type of the HTTP request is "application/json". To send a JSON POST using a different content-type, call the PostJson2 method where the content type can be explicitly specified.
Returns NULL on failure
PostJsonAsync (1) (2)
# url is a string
# jsonText is a string
set ret_task [CkHttp_PostJsonAsync $url $jsonText]
Creates an asynchronous task to call the PostJson method with the arguments provided.
Returns NULL on failure
topPostJson2
# url is a string
# contentType is a string
# jsonText is a string
set ret_httpResponse [CkHttp_PostJson2 $url $contentType $jsonText]
The same as PostJson,except it allows for the content type to be explicitly provided. The PostJson method automatically uses "application/jsonrequest". If the application needs for the content type to be "application/json", or some other content type, then PostJson2 provides the means.
Returns NULL on failure
PostJson2Async (1) (2)
# url is a string
# contentType is a string
# jsonText is a string
set ret_task [CkHttp_PostJson2Async $url $contentType $jsonText]
Creates an asynchronous task to call the PostJson2 method with the arguments provided.
Returns NULL on failure
topPostJson3
# url is a string
# contentType is a string
# json is a CkJsonObject
set ret_httpResponse [CkHttp_PostJson3 $url $contentType $json]
The same as PostJson2,except a JSON object is passed in for the request body.
Returns NULL on failure
PostJson3Async (1) (2)
# url is a string
# contentType is a string
# json is a CkJsonObject
set ret_task [CkHttp_PostJson3Async $url $contentType $json]
Creates an asynchronous task to call the PostJson3 method with the arguments provided.
Returns NULL on failure
topPostUrlEncoded
# url is a string
# req is a CkHttpRequest
set ret_httpResponse [CkHttp_PostUrlEncoded $url $req]
Sends a simple URL encoded POST. The form parameters are sent in the body of the HTTP request in x-www-form-urlencoded format. The content-type is "application/x-www-form-urlencoded".
Returns NULL on failure
PostUrlEncodedAsync (1) (2)
# url is a string
# req is a CkHttpRequest
set ret_task [CkHttp_PostUrlEncodedAsync $url $req]
Creates an asynchronous task to call the PostUrlEncoded method with the arguments provided.
Returns NULL on failure
topPostXml
# endpointUrl is a string
# xmlContent is a string
# xmlCharset is a string
set ret_httpResponse [CkHttp_PostXml $endpointUrl $xmlContent $xmlCharset]
A simplified way of posting XML content to a web server. This method is good for making SOAP calls using HTTP POST. The xmlCharset should match the character encoding used in the xmlContent, which is typically "utf-8". The HTTP response is returned in an HTTP response object.
Important: This method sends the POST with a "Content-Type" header value of "application/xml". In rare cases, a server might require the Content-Type header to be "text/xml". To use "text/xml" instead of the default "application/xml", call SetRequestHeader("Content-Type","text/xml") prior to calling this method.
To use HTTPS simply pass an endpointUrl beginning with "https://" instead of "http://". This applies to any Chilkat method where a URL is passed as an argument.
Returns NULL on failure
PostXmlAsync (1) (2)
# endpointUrl is a string
# xmlContent is a string
# xmlCharset is a string
set ret_task [CkHttp_PostXmlAsync $endpointUrl $xmlContent $xmlCharset]
Creates an asynchronous task to call the PostXml method with the arguments provided.
Returns NULL on failure
topPText
# verb is a string
# url is a string
# textData is a string
# charset is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_httpResponse [CkHttp_PText $verb $url $textData $charset $contentType $md5 $gzip]
Sends an HTTP request to the url. The verb can be "POST", "PUT", "PATCH", etc. The body of the HTTP request contains the text passed in textData. The contentType is a content type such as "text/xml", "application/json", etc. If md5 is 1, then a Content-MD5 header is added with the base64 MD5 hash of the textData. Servers aware of the Content-MD5 header will perform a message integrity check to ensure that the data has not been corrupted. If gzip is 1, the contentType is compressed using the gzip algorithm. The HTTP request body will contain the GZIP compressed data, and a "Content-Encoding: gzip" header is automatically added to indicate that the request data needs to be ungzipped when received (at the server).
Returns NULL on failure
PTextAsync (1) (2)
# verb is a string
# url is a string
# textData is a string
# charset is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PTextAsync $verb $url $textData $charset $contentType $md5 $gzip]
Creates an asynchronous task to call the PText method with the arguments provided.
Returns NULL on failure
topPTextSb
# verb is a string
# url is a string
# textData is a CkStringBuilder
# charset is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_httpResponse [CkHttp_PTextSb $verb $url $textData $charset $contentType $md5 $gzip]
The same as PText, but the data to be uploaded is passed in textData.
Returns NULL on failure
PTextSbAsync (1) (2)
# verb is a string
# url is a string
# textData is a CkStringBuilder
# charset is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PTextSbAsync $verb $url $textData $charset $contentType $md5 $gzip]
Creates an asynchronous task to call the PTextSb method with the arguments provided.
Returns NULL on failure
topPutBinary
# byteData is a CkByteData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
# outStr is a CkString (output)
set status [CkHttp_PutBinary $url $byteData $contentType $md5 $gzip $outStr]
set retStr [CkHttp_putBinary $myHttp $url $byteData $contentType $md5 $gzip]
Sends an HTTP PUT request to the url. The body of the HTTP request is byteData. The contentType is a content type such as "image/gif", "application/pdf", etc. If md5 is 1, then a Content-MD5 header is added with the base64 MD5 hash of the byteData. Servers aware of the Content-MD5 header will perform a message integrity check to ensure that the data has not been corrupted. If gzip is 1, the byteData is compressed using the gzip algorithm. The HTTP request body will contain the GZIP compressed data, and a "Content-Encoding: gzip" header is automatically added to indicate that the request data needs to be ungzipped when received (at the server).
Returns the text body of the HTTP response if the HTTP response has a success status code. Otherwise the method is considered to have failed. If more details of the HTTP response are required, call PBinary instead (which returns the HTTP response object).
Returns 1 for success, 0 for failure.
topPutBinaryAsync (1)
# url is a string
# byteData is a CkByteData
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PutBinaryAsync $url $byteData $contentType $md5 $gzip]
Creates an asynchronous task to call the PutBinary method with the arguments provided.
Returns NULL on failure
topPutText
# textData is a string
# charset is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
# outStr is a CkString (output)
set status [CkHttp_PutText $url $textData $charset $contentType $md5 $gzip $outStr]
set retStr [CkHttp_putText $myHttp $url $textData $charset $contentType $md5 $gzip]
Sends an HTTP PUT request to the url. The body of the HTTP request is textData. The charset should be set to a charset name such as "iso-8859-1", "windows-1252", "Shift_JIS", "utf-8", etc. The string "ansi" may also be used as a charset name. The contentType is a content type such as "text/plain", "text/xml", etc. If md5 is 1, then a Content-MD5 header is added with the base64 MD5 hash of the textData. Servers aware of the Content-MD5 header will perform a message integrity check to ensure that the data has not been corrupted. If gzip is 1, the textData is compressed using the gzip algorithm. The HTTP request body will contain the GZIP compressed data, and a "Content-Encoding: gzip" header is automatically added to indicate that the request data needs to be ungzipped when received (at the server).
Returns the text body of the HTTP response if the HTTP response has a success status code. Otherwise the method is considered to have failed. If more details of the HTTP response are required, call PText instead (which returns the HTTP response object).
Returns 1 for success, 0 for failure.
PutTextAsync (1)
# url is a string
# textData is a string
# charset is a string
# contentType is a string
# md5 is a boolean
# gzip is a boolean
set ret_task [CkHttp_PutTextAsync $url $textData $charset $contentType $md5 $gzip]
Creates an asynchronous task to call the PutText method with the arguments provided.
Returns NULL on failure
topQuickDeleteStr
# outStr is a CkString (output)
set status [CkHttp_QuickDeleteStr $url $outStr]
set retStr [CkHttp_quickDeleteStr $myHttp $url]
Same as QuickGetStr, but uses the HTTP DELETE method instead of the GET method.
Note: The HTTP response code is available in the LastStatus property. Other properties having information include LastResponseHeader, LastResponseBody, LastModDate, LastContentType, etc.
Returns 1 for success, 0 for failure.
QuickDeleteStrAsync (1)
# url is a string
set ret_task [CkHttp_QuickDeleteStrAsync $url]
Creates an asynchronous task to call the QuickDeleteStr method with the arguments provided.
Returns NULL on failure
topQuickGet
Sends an HTTP GET request for a URL and returns the binary response body. The URL may contain query parameters. If the SendCookies property is 1, matching cookies previously persisted to the CookiesDir are automatically included in the request. If the FetchFromCache property is 1, the resource may be fetched directly from cache.
Note: The HTTP response code is available in the LastStatus property. Other properties having information include LastResponseHeader, LastResponseBody, LastModDate, LastContentType, etc.
A response code >= 400 is considered a failure. If the error response was textual in nature, then it will also be available in the LastResponseBody property.
Returns 1 for success, 0 for failure.
QuickGetAsync (1)
# url is a string
set ret_task [CkHttp_QuickGetAsync $url]
Creates an asynchronous task to call the QuickGet method with the arguments provided.
Returns NULL on failure
topQuickGetBd
# binData is a CkBinData
set status [CkHttp_QuickGetBd $url $binData]
The same as QuickGet, but returns the content in a Chilkat BinData object. The existing content of binData, if any, is cleared and replaced with the downloaded content.
A response code >= 400 is considered a failure and the method will return 0. However, the error response will still be returned in binData. If the error response was textual in nature, then it will also be available in the LastResponseBody property.
Returns 1 for success, 0 for failure.
QuickGetBdAsync (1)
# url is a string
# binData is a CkBinData
set ret_task [CkHttp_QuickGetBdAsync $url $binData]
Creates an asynchronous task to call the QuickGetBd method with the arguments provided.
Returns NULL on failure
topQuickGetObj
# url is a string
set ret_httpResponse [CkHttp_QuickGetObj $url]
Sends an HTTP GET request for a URL and returns the response object. If the SendCookies property is 1, matching cookies previously persisted to the CookiesDir are automatically included in the request. If the FetchFromCache property is 1, the page could be fetched directly from cache.
Returns NULL on failure
QuickGetObjAsync (1) (2)
# url is a string
set ret_task [CkHttp_QuickGetObjAsync $url]
Creates an asynchronous task to call the QuickGetObj method with the arguments provided.
Returns NULL on failure
topQuickGetSb
# sbContent is a CkStringBuilder
set status [CkHttp_QuickGetSb $url $sbContent]
The same as QuickGetStr, but returns the content in a Chilkat StringBuilder object. The existing content of sbContent, if any, is cleared and replaced with the downloaded content.
If the response status code is >= 400, then this method returns 0, but the body of the HTTP response is still returned in sbContent. This allows for the application to examine the response body for cases where an error is returned, but the expected content is not received.
Returns 1 for success, 0 for failure.
QuickGetSbAsync (1)
# url is a string
# sbContent is a CkStringBuilder
set ret_task [CkHttp_QuickGetSbAsync $url $sbContent]
Creates an asynchronous task to call the QuickGetSb method with the arguments provided.
Returns NULL on failure
topQuickGetStr
# outStr is a CkString (output)
set status [CkHttp_QuickGetStr $url $outStr]
set retStr [CkHttp_quickGetStr $myHttp $url]
Sends an HTTP GET request for a URL and returns the response body as a string. The URL may contain query parameters. If the SendCookies property is 1, matching cookies previously persisted to the CookiesDir are automatically included in the request. If the FetchFromCache property is 1, the page could be fetched directly from cache. If the HTTP request fails, a NULL value is returned and error information can be found in the LastErrorText, LastErrorXml, or LastErrorHtml properties.
Note: The HTTP response code is available in the LastStatus property. Other properties having information include LastResponseHeader, LastResponseBody, LastModDate, LastContentType, etc.
Returns 1 for success, 0 for failure.
QuickGetStrAsync (1)
# url is a string
set ret_task [CkHttp_QuickGetStrAsync $url]
Creates an asynchronous task to call the QuickGetStr method with the arguments provided.
Returns NULL on failure
topQuickPutStr
# outStr is a CkString (output)
set status [CkHttp_QuickPutStr $url $outStr]
set retStr [CkHttp_quickPutStr $myHttp $url]
Same as QuickGetStr, but uses the HTTP PUT method instead of the GET method.
Note: The HTTP response code is available in the LastStatus property. Other properties having information include LastResponseHeader, LastResponseBody, LastModDate, LastContentType, etc.
Returns 1 for success, 0 for failure.
QuickPutStrAsync (1)
# url is a string
set ret_task [CkHttp_QuickPutStrAsync $url]
Creates an asynchronous task to call the QuickPutStr method with the arguments provided.
Returns NULL on failure
topQuickRequest
# verb is a string
# url is a string
set ret_httpResponse [CkHttp_QuickRequest $verb $url]
Sends an HTTP request with no body for a URL and returns the response object. The verb is typically "GET" or "DELETE".
If the SendCookies property is 1, matching cookies previously persisted to the CookiesDir are automatically included in the request. If the FetchFromCache property is 1, the page could be fetched directly from cache.
Returns NULL on failure
QuickRequestAsync (1) (2)
# verb is a string
# url is a string
set ret_task [CkHttp_QuickRequestAsync $verb $url]
Creates an asynchronous task to call the QuickRequest method with the arguments provided.
Returns NULL on failure
topQuickRequestParams
# verb is a string
# url is a string
# json is a CkJsonObject
set ret_httpResponse [CkHttp_QuickRequestParams $verb $url $json]
This is the same as the QuickRequest method, except query params can be provided as non-URL-encoded name/value members in the json.
Returns NULL on failure
QuickRequestParamsAsync (1) (2)
# verb is a string
# url is a string
# json is a CkJsonObject
set ret_task [CkHttp_QuickRequestParamsAsync $verb $url $json]
Creates an asynchronous task to call the QuickRequestParams method with the arguments provided.
Returns NULL on failure
topRemoveRequestHeader
CkHttp_RemoveRequestHeader $name
Removes a header from the internal list of custom header field name/value pairs to be automatically added when HTTP requests are sent via methods that do not use the HTTP request object. (The SetRequestHeader method is called to add custom header fields.)
topRenderGet
# outStr is a CkString (output)
set status [CkHttp_RenderGet $url $outStr]
set retStr [CkHttp_renderGet $myHttp $url]
Same as QuickGet, but does not send the HTTP GET. Instead, it builds the HTTP request that would've been sent and returns it.
Returns 1 for success, 0 for failure.
ResumeDownload
# targetFilename is a string
set status [CkHttp_ResumeDownload $url $targetFilename]
Same as the Download method, except a failed download may be resumed. The targetFilename is automatically checked and if it exists, the download will resume at the point where it previously failed. ResumeDownload may be called any number of times until the full download is complete.
Returns 1 for success, 0 for failure.
topResumeDownloadAsync (1)
# url is a string
# targetFilename is a string
set ret_task [CkHttp_ResumeDownloadAsync $url $targetFilename]
Creates an asynchronous task to call the ResumeDownload method with the arguments provided.
Returns NULL on failure
topResumeDownloadBd
# binData is a CkBinData
set status [CkHttp_ResumeDownloadBd $url $binData]
Same as the DownloadBd method, except a failed download may be resumed. The download will resume at a point based on the number of bytes already contained in binData. ResumeDownloadBd may be called any number of times until the full download is complete.
The incoming data is appended to binData.
Returns 1 for success, 0 for failure.
topResumeDownloadBdAsync (1)
# url is a string
# binData is a CkBinData
set ret_task [CkHttp_ResumeDownloadBdAsync $url $binData]
Creates an asynchronous task to call the ResumeDownloadBd method with the arguments provided.
Returns NULL on failure
topS3_CreateBucket
set status [CkHttp_S3_CreateBucket $bucketPath]
Creates a new Amazon S3 bucket.
Note: x-amz-* headers, including metadata, can be added to any S3 request by adding each header with a call to SetRequestHeader. This applies to all S3 methods, even if not explicitly stated.
Returns 1 for success, 0 for failure.
S3_CreateBucketAsync (1)
# bucketPath is a string
set ret_task [CkHttp_S3_CreateBucketAsync $bucketPath]
Creates an asynchronous task to call the S3_CreateBucket method with the arguments provided.
Returns NULL on failure
topS3_DeleteBucket
set status [CkHttp_S3_DeleteBucket $bucketPath]
Deletes an Amazon S3 bucket.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
S3_DeleteBucketAsync (1)
# bucketPath is a string
set ret_task [CkHttp_S3_DeleteBucketAsync $bucketPath]
Creates an asynchronous task to call the S3_DeleteBucket method with the arguments provided.
Returns NULL on failure
topS3_DeleteMultipleObjects
# bucketName is a string
# objectNames is a CkStringArray
set ret_httpResponse [CkHttp_S3_DeleteMultipleObjects $bucketName $objectNames]
Deletes multiple objects from a bucket using a single HTTP request. The bucketName contains the names (also known as "keys") of the objects to be deleted. To delete a specific version of an object, append a versionId attribute to the object name. For example: "SampleDocument.txt; VersionId="OYcLXagmS.WaD..oyH4KRguB95_YhLs7""
Returns NULL on failure
S3_DeleteMultipleObjectsAsync (1) (2)
# bucketName is a string
# objectNames is a CkStringArray
set ret_task [CkHttp_S3_DeleteMultipleObjectsAsync $bucketName $objectNames]
Creates an asynchronous task to call the S3_DeleteMultipleObjects method with the arguments provided.
Returns NULL on failure
topS3_DeleteObject
# objectName is a string
set status [CkHttp_S3_DeleteObject $bucketPath $objectName]
Deletes a remote file (object) on the Amazon S3 service.
Returns 1 for success, 0 for failure.
S3_DeleteObjectAsync (1)
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_DeleteObjectAsync $bucketPath $objectName]
Creates an asynchronous task to call the S3_DeleteObject method with the arguments provided.
Returns NULL on failure
topS3_DownloadBd
# objectName is a string
# bd is a CkBinData
set status [CkHttp_S3_DownloadBd $bucketPath $objectName $bd]
The same as DownloadFile, except the downloaded file data is appended to bd.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
topS3_DownloadBdAsync (1)
# bucketPath is a string
# objectName is a string
# bd is a CkBinData
set ret_task [CkHttp_S3_DownloadBdAsync $bucketPath $objectName $bd]
Creates an asynchronous task to call the S3_DownloadBd method with the arguments provided.
Returns NULL on failure
topS3_DownloadBytes
# objectName is a string
# outBytes is a CkByteData (output)
set status [CkHttp_S3_DownloadBytes $bucketPath $objectName $outData]
The same as DownloadFile, except the file data is returned directly in-memory instead of being written to a local file.
Returns 1 for success, 0 for failure.
S3_DownloadBytesAsync (1)
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_DownloadBytesAsync $bucketPath $objectName]
Creates an asynchronous task to call the S3_DownloadBytes method with the arguments provided.
Returns NULL on failure
topS3_DownloadFile
# objectName is a string
# localFilePath is a string
set status [CkHttp_S3_DownloadFile $bucketPath $objectName $localFilePath]
Downloads a file from the Amazon S3 service.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
S3_DownloadFileAsync (1)
# bucketPath is a string
# objectName is a string
# localFilePath is a string
set ret_task [CkHttp_S3_DownloadFileAsync $bucketPath $objectName $localFilePath]
Creates an asynchronous task to call the S3_DownloadFile method with the arguments provided.
Returns NULL on failure
topS3_DownloadString
# objectName is a string
# charset is a string
# outStr is a CkString (output)
set status [CkHttp_S3_DownloadString $bucketPath $objectName $charset $outStr]
set retStr [CkHttp_s3_DownloadString $myHttp $bucketPath $objectName $charset]
Downloads a text file (object) from the Amazon S3 service directly into a string variable. The charset specifies the character encoding, such as "utf-8", of the remote text object.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
S3_DownloadStringAsync (1)
# bucketPath is a string
# objectName is a string
# charset is a string
set ret_task [CkHttp_S3_DownloadStringAsync $bucketPath $objectName $charset]
Creates an asynchronous task to call the S3_DownloadString method with the arguments provided.
Returns NULL on failure
topS3_FileExists
# objectName is a string
set retInt [CkHttp_S3_FileExists $bucketPath $objectName]
Determines if a remote object (file) exists. Returns 1 if the file exists, 0 if it does not exist, -1 if there was a failure in checking, or 2 if using in asynchronous mode to indicate that the background task was successfully started.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
S3_FileExistsAsync (1)
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_FileExistsAsync $bucketPath $objectName]
Creates an asynchronous task to call the S3_FileExists method with the arguments provided.
Returns NULL on failure
topS3_GenerateUrl
# path is a string
# expire is a CkDateTime
# outStr is a CkString (output)
set status [CkHttp_S3_GenerateUrl $bucket $path $expire $outStr]
set retStr [CkHttp_s3_GenerateUrl $myHttp $bucket $path $expire]
Generates a temporary pre-signed URL for Amazon S3 using AWS Signature V2. (Call S3_GenerateUrlV4 to generate AWS Signature V4 pre-signed URLs.) Requires that the AwsSecretKey and AwsAccessKey be set to valid values prior to calling this method.
Note: This method can only generate URLs that are for HTTP GET requests (i.e. URLs you can paste into a browser address bar). This method does not generate URLs for POST, PUT, DELETE, etc.
Returns 1 for success, 0 for failure.
S3_GenerateUrlV4
# bucketName is a string
# path is a string
# numSecondsValid is an integer
# awsService is a string
# outStr is a CkString (output)
set status [CkHttp_S3_GenerateUrlV4 $useHttps $bucketName $path $numSecondsValid $awsService $outStr]
set retStr [CkHttp_s3_GenerateUrlV4 $myHttp $useHttps $bucketName $path $numSecondsValid $awsService]
Note: The S3_GenPresignedUrl method is new in Chilkat v9.5.0.83 and can create S3 pre-signed URLs for GET, POST, PUT, DELETE, or any other HTTP verb.
Generates a temporary pre-signed URL for Amazon S3 using AWS Signature V4. (Call S3_GenerateUrl to generate AWS Signature V2 pre-signed URLs.) Requires that the AwsSecretKey, AwsAccessKey, and AwsRegion properties be set to valid values prior to calling this method. Also requires the AwsEndpoint property to be set if the endpoint is different than "s3.amazonaws.com".
The URL that is generated has this format:
https://<AwsEndpoint>/<bucket_name>/<path> ?X-Amz-Algorithm=AWS4-HMAC-SHA256 &X-Amz-Credential=<AwsAccessKey>/<currentDate>/<AwsRegion>/<awsService>/aws4_request &X-Amz-Date=<currentDateTime> &X-Amz-Expires=<numSecondsValid> &X-Amz-SignedHeaders=host &X-Amz-Signature=<signature-value>
The awsService is a string naming the AWS service, such as "s3". If useHttps is 1, then the URL begins with "https://", otherwise it begins with "http://".
Note: This method can only generate URLs that are for HTTP GET requests (i.e. URLs you can paste into a browser address bar). This method does not generate URLs for POST, PUT, DELETE, etc.
Returns 1 for success, 0 for failure.
S3_GenPresignedUrl
# useHttps is a boolean
# bucketName is a string
# path is a string
# numSecondsValid is an integer
# awsService is a string
# outStr is a CkString (output)
set status [CkHttp_S3_GenPresignedUrl $httpVerb $useHttps $bucketName $path $numSecondsValid $awsService $outStr]
set retStr [CkHttp_s3_GenPresignedUrl $myHttp $httpVerb $useHttps $bucketName $path $numSecondsValid $awsService]
Generates a temporary pre-signed URL for Amazon S3 using AWS Signature V4. Requires that the AwsSecretKey, AwsAccessKey, and AwsRegion properties be set to valid values prior to calling this method. Also requires the AwsEndpoint property to be set if the endpoint is different than "s3.amazonaws.com".
The URL that is generated has this format:
https://<AwsEndpoint>/<bucket_name>/<path> ?X-Amz-Algorithm=AWS4-HMAC-SHA256 &X-Amz-Credential=<AwsAccessKey>/<currentDate>/<AwsRegion>/<awsService>/aws4_request &X-Amz-Date=<currentDateTime> &X-Amz-Expires=<numSecondsValid> &X-Amz-SignedHeaders=host &X-Amz-Signature=<signature-value>
The httpVerb is the HTTP verb such as "GET", "PUT", "POST", "DELETE", etc. The awsService is a string naming the AWS service, such as "s3" or "s3-accelerate". If useHttps is 1, then the URL begins with "https://", otherwise it begins with "http://".
Returns 1 for success, 0 for failure.
S3_ListBucketObjects
# outStr is a CkString (output)
set status [CkHttp_S3_ListBucketObjects $bucketPath $outStr]
set retStr [CkHttp_s3_ListBucketObjects $myHttp $bucketPath]
Retrieves the XML listing of the objects contained within an Amazon S3 bucket. (This is like a directory listing, but in XML format.)
The bucketPath name may be qualified with URL-encoded params. For example, to list the objects in a bucket named "ChilkatABC" with max-keys = 2000 and marker = "xyz", call S3_ListBucketObject passing the following string for bucketPath: "ChilkatABC?max-keys=2000&marker=xyz"
The S3_ListBucketObjects method recognized all params listed in the AWS documentation for listing objects in a bucket: delimiter, marker, max-keys, and prefix. See Amazon's AWS online documentation for more information.
Returns 1 for success, 0 for failure.
S3_ListBucketObjectsAsync (1)
# bucketPath is a string
set ret_task [CkHttp_S3_ListBucketObjectsAsync $bucketPath]
Creates an asynchronous task to call the S3_ListBucketObjects method with the arguments provided.
Returns NULL on failure
topS3_ListBuckets
set status [CkHttp_S3_ListBuckets $outStr]
set retStr [CkHttp_s3_ListBuckets $myHttp]
Retrieves the XML listing of the buckets for an Amazon S3 account.
Returns 1 for success, 0 for failure.
S3_ListBucketsAsync (1)
set ret_task [CkHttp_S3_ListBucketsAsync]
Creates an asynchronous task to call the S3_ListBuckets method with the arguments provided.
Returns NULL on failure
topS3_UploadBd
# contentType is a string
# bucketPath is a string
# objectName is a string
set status [CkHttp_S3_UploadBd $bd $contentType $bucketPath $objectName]
The same as S3_UploadFile, except the contents of the file come from bd instead of a local file.
Note: x-amz-* headers, including metadata, can be added to any S3 request by adding each header with a call to SetRequestHeader. This applies to all S3 methods, even if not explicitly stated.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
S3_UploadBdAsync (1)
# bd is a CkBinData
# contentType is a string
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_UploadBdAsync $bd $contentType $bucketPath $objectName]
Creates an asynchronous task to call the S3_UploadBd method with the arguments provided.
Returns NULL on failure
topS3_UploadBytes
# contentType is a string
# bucketPath is a string
# objectName is a string
set status [CkHttp_S3_UploadBytes $contentBytes $contentType $bucketPath $objectName]
The same as S3_UploadFile, except the contents of the file come from contentBytes instead of a local file.
Note: x-amz-* headers, including metadata, can be added to any S3 request by adding each header with a call to SetRequestHeader. This applies to all S3 methods, even if not explicitly stated.
Returns 1 for success, 0 for failure.
S3_UploadBytesAsync (1)
# contentBytes is a CkByteData
# contentType is a string
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_UploadBytesAsync $contentBytes $contentType $bucketPath $objectName]
Creates an asynchronous task to call the S3_UploadBytes method with the arguments provided.
Returns NULL on failure
topS3_UploadFile
# contentType is a string
# bucketPath is a string
# objectName is a string
set status [CkHttp_S3_UploadFile $localFilePath $contentType $bucketPath $objectName]
Uploads a file to the Amazon S3 service.
Note: x-amz-* headers, including metadata, can be added to any S3 request by adding each header with a call to SetRequestHeader. This applies to all S3 methods, even if not explicitly stated.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
S3_UploadFileAsync (1)
# localFilePath is a string
# contentType is a string
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_UploadFileAsync $localFilePath $contentType $bucketPath $objectName]
Creates an asynchronous task to call the S3_UploadFile method with the arguments provided.
Returns NULL on failure
topS3_UploadString
# charset is a string
# contentType is a string
# bucketPath is a string
# objectName is a string
set status [CkHttp_S3_UploadString $objectContent $charset $contentType $bucketPath $objectName]
Uploads an in-memory string to the Amazon S3 service. This is the same as UploadFile, except that the file contents are from an in-memory string instead of a local file. Internal to this method, the objectContent is converted to the character encoding specified by charset prior to uploading.
Note: x-amz-* headers, including metadata, can be added to any S3 request by adding each header with a call to SetRequestHeader. This applies to all S3 methods, even if not explicitly stated.
Note: If the bucket is in a region different than us-east-1, makes sure to set the AwsEndpoint property to the correct region, such as "eu-central-1". Also, if using an S3 compatible service such as Wasabi, always set the AwsEndpoint property. For example: "s3.wasabisys.com", "s3.eu-central-1.wasabisys.com".
Returns 1 for success, 0 for failure.
S3_UploadStringAsync (1)
# objectContent is a string
# charset is a string
# contentType is a string
# bucketPath is a string
# objectName is a string
set ret_task [CkHttp_S3_UploadStringAsync $objectContent $charset $contentType $bucketPath $objectName]
Creates an asynchronous task to call the S3_UploadString method with the arguments provided.
Returns NULL on failure
topSetAuthPrivateKey
# privKey is a CkPrivateKey
set status [CkHttp_SetAuthPrivateKey $publicKeyId $privKey]
Sets the private key to be used with some forms of authentication. Starting in v9.5.0.89, this is used automatically add the Authorization header (Signature) for Amazon Pay requests.
Returns 1 for success, 0 for failure.
SetAuthTokenSb
set status [CkHttp_SetAuthTokenSb $sb]
Sets the AuthToken property. The sb contains the OAuth2 access token to be used.
Returns 1 for success, 0 for failure.
topSetCookieXml
# cookieXml is a string
set status [CkHttp_SetCookieXml $domain $cookieXml]
Restores cookies for a particular domain. It is assumed that the cookie XML was previously retrieved via the GetCookieXml method, and saved to some sort of persistent storage, such as within a database table. It is then possible for an application to restore the cookies by calling this method.
Returns 1 for success, 0 for failure.
topSetOAuthRsaKey
set status [CkHttp_SetOAuthRsaKey $privKey]
Sets the RSA key to be used with OAuth authentication when the RSA-SHA1 OAuth signature method is used (see the OAuthSigMethod property).
Returns 1 for success, 0 for failure.
topSetRequestHeader
# headerFieldValue is a string
CkHttp_SetRequestHeader $headerFieldName $headerFieldValue
Adds a custom header field to any HTTP request sent by a method that does not use the HTTP request object. These methods include Download, DownloadAppend, GetHead, PostBinary, PostXml, PutBinary, PutText, QuickDeleteStr, QuickGet, QuickGetObj, QuickGetStr, QuickPutStr, XmlRpc, and XmlRpcPut.
Cookies may be explictly added by calling this method passing "Cookie" for the headerFieldName.
The RemoveRequestHeader method can be called to remove a custom header.
Note1: Do not call this method to add Basic authentication, i.e. "Authorization: Basic ....". Instead, set the Login and Password properties, and also set the BasicAuth property = 1. Chilkat will add the "Authorization: Basic ..." header using the correct format automatically.
Note 2: Never explicitly set the Content-Length header field. Chilkat will automatically compute the correct length and add the Content-Length header to all POST, PUT, or any other request where the Content-Length needs to be specified. (GET requests always have a 0 length body, and therefore never need a Content-Length header field.)
Note 3: To add more than one header, call this method once per header field.
Note 4:: Passing an empty value string causes the header to be removed. This was the unfortunate behavior of the method from the beginning, and cannot be changed for backward compatibility reasons. A workaround exists starting in v9.5.0.82 by adding the "AllowEmptyHeaders" keyword to the UncommonOptions property.
SetSecurePassword
set status [CkHttp_SetSecurePassword $password]
Equivalent to setting the Password property, but provides for a more secure way of passing the password in a secure string object.
Returns 1 for success, 0 for failure.
topSetSslCertRequirement
# reqValue is a string
set status [CkHttp_SetSslCertRequirement $reqName $reqValue]
Enforces a requirement on the server's certificate. The reqName can be one of the following:
- SubjectDN
- SubjectCN
- IssuerDN
- IssuerCN
- SAN (added in v9.5.0.84)
The reqName specifies the part of the certificate, and the reqValue is the value that it must match exactly or with a wildcard (*). If the server's certificate does not match, the SSL / TLS connection is aborted.
Returns 1 for success, 0 for failure.
SetSslClientCert
set status [CkHttp_SetSslClientCert $cert]
Allows for a client-side certificate to be used for an SSL connection.
Returns 1 for success, 0 for failure.
SetSslClientCertPem
# pemPassword is a string
set status [CkHttp_SetSslClientCertPem $pemDataOrPath $pemPassword]
Allows for a client-side certificate + private key to be used for the SSL / TLS connection (often called 2-way SSL).
Returns 1 for success, 0 for failure.
SetSslClientCertPfx
# pfxPassword is a string
set status [CkHttp_SetSslClientCertPfx $pfxPath $pfxPassword]
Allows for a client-side certificate + private key to be used for the SSL / TLS connection (often called 2-way SSL).
Returns 1 for success, 0 for failure.
SetUrlVar
# value is a string
set status [CkHttp_SetUrlVar $name $value]
Sets the value of a variable for substitutions in URLs passed to any method. Variables can appear in URLs in the following format: {$varName}. For example: https://graph.microsoft.com/v1.0/users/{$id}
Returns 1 for success, 0 for failure.
topSharePointOnlineAuth
# username is a string
# password is a CkSecureString
# extraInfo is a CkJsonObject
set status [CkHttp_SharePointOnlineAuth $siteUrl $username $password $extraInfo]
Authenticates with SharePoint Online, resulting in a cookie being set and used for subsequent SharePoint HTTP requests. Prior to calling this method, an application should set the CookieDir property to either "memory" or a directory path to persist the SharePoint authentication cookie to be automatically used in subsequent runs.
This method has the side-effect of setting the SaveCookies and SendCookies properties to 1, because these settings are required for SharePoint Online authentication.
The siteUrl is a URL such as "https://yourdomain.sharepoint.com/". The username is an email address such as "username@yourdomain.com". The extraInfo is reserved for providing additional information as needed in the future.
Returns 1 for success, 0 for failure.
SharePointOnlineAuthAsync (1)
# siteUrl is a string
# username is a string
# password is a CkSecureString
# extraInfo is a CkJsonObject
set ret_task [CkHttp_SharePointOnlineAuthAsync $siteUrl $username $password $extraInfo]
Creates an asynchronous task to call the SharePointOnlineAuth method with the arguments provided.
Returns NULL on failure
topSleepMs
CkHttp_SleepMs $millisec
Convenience method to force the calling process to sleep for a number of milliseconds.
topSynchronousRequest
# domain is a string
# port is an integer
# ssl is a boolean
# req is a CkHttpRequest
set ret_httpResponse [CkHttp_SynchronousRequest $domain $port $ssl $req]
Sends an explicit HttpRequest to an HTTP server and returns an HttpResponse object. The HttpResponse object provides full access to the response including all headers and the response body. This method may be used to send POST requests, as well as GET, HEAD, file uploads, and XMLHTTP. To send via HTTPS (i.e. TLS), set the ssl property = 1. Otherwise set it to 0.
NOTE: The 1st argument of this method is a domain, not a URL. For example, DO NOT pass "https://www.somedomain.com/" in the 1st argument. Instead, pass "www.somedomain.com".
The Parts of a URL
http://example.com:8042/over/there?name=ferret#nose \__/ \______________/\_________/ \________/ \__/ | | | | | scheme domain+port path query fragment
Returns NULL on failure
SynchronousRequestAsync (1) (2)
# domain is a string
# port is an integer
# ssl is a boolean
# req is a CkHttpRequest
set ret_task [CkHttp_SynchronousRequestAsync $domain $port $ssl $req]
Creates an asynchronous task to call the SynchronousRequest method with the arguments provided.
Returns NULL on failure
topUrlDecode
# outStr is a CkString (output)
set status [CkHttp_UrlDecode $str $outStr]
set retStr [CkHttp_urlDecode $myHttp $str]
UrlEncode
# outStr is a CkString (output)
set status [CkHttp_UrlEncode $str $outStr]
set retStr [CkHttp_urlEncode $myHttp $str]
VerifyTimestampReply
# tsaCert is a CkCert
set retInt [CkHttp_VerifyTimestampReply $timestampReply $tsaCert]
Verifies a timestamp reply received from a timestamp authority (TSA). Returns the following possible integer values:
- -1: The timestampReply does not contain a valid timestamp reply.
- -2: The timestampReply is a valid timestamp reply, but failed verification using the public key of the tsaCert.
- 0: Granted and verified.
- 1: Granted and verified, with mods (see RFC 3161)
- 2: Rejected.
- 3: Waiting.
- 4: Revocation Warning
- 5: Revocation Notification
If the timestamp reply (timestampReply) is known to be from a trusted source, then the tsaCert may be empty. If tsaCert is empty (never loaded with a certificate), then the verification will use the certificate embedded in the timestamp reply.
XmlRpc
# xmlIn is a string
# outStr is a CkString (output)
set status [CkHttp_XmlRpc $urlEndpoint $xmlIn $outStr]
set retStr [CkHttp_xmlRpc $myHttp $urlEndpoint $xmlIn]
Makes an XML RPC call to a URL endpoint. The XML string is passed in an HTTP POST, and the XML response is returned.
Returns 1 for success, 0 for failure.
XmlRpcAsync (1)
# urlEndpoint is a string
# xmlIn is a string
set ret_task [CkHttp_XmlRpcAsync $urlEndpoint $xmlIn]
Creates an asynchronous task to call the XmlRpc method with the arguments provided.
Returns NULL on failure
topXmlRpcPut
# xmlIn is a string
# outStr is a CkString (output)
set status [CkHttp_XmlRpcPut $urlEndpoint $xmlIn $outStr]
set retStr [CkHttp_xmlRpcPut $myHttp $urlEndpoint $xmlIn]
Same as XmlRpc, but uses the HTTP PUT method instead of the POST method.
Returns 1 for success, 0 for failure.
topXmlRpcPutAsync (1)
# urlEndpoint is a string
# xmlIn is a string
set ret_task [CkHttp_XmlRpcPutAsync $urlEndpoint $xmlIn]
Creates an asynchronous task to call the XmlRpcPut method with the arguments provided.
Returns NULL on failure
top