class_httpclient.rst 55 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145
  1. :github_url: hide
  2. .. DO NOT EDIT THIS FILE!!!
  3. .. Generated automatically from Godot engine sources.
  4. .. Generator: https://github.com/godotengine/godot/tree/master/doc/tools/make_rst.py.
  5. .. XML source: https://github.com/godotengine/godot/tree/master/doc/classes/HTTPClient.xml.
  6. .. _class_HTTPClient:
  7. HTTPClient
  8. ==========
  9. **Inherits:** :ref:`RefCounted<class_RefCounted>` **<** :ref:`Object<class_Object>`
  10. Low-level hyper-text transfer protocol client.
  11. .. rst-class:: classref-introduction-group
  12. Description
  13. -----------
  14. Hyper-text transfer protocol client (sometimes called "User Agent"). Used to make HTTP requests to download web content, upload files and other data or to communicate with various services, among other use cases.
  15. See the :ref:`HTTPRequest<class_HTTPRequest>` node for a higher-level alternative.
  16. \ **Note:** This client only needs to connect to a host once (see :ref:`connect_to_host<class_HTTPClient_method_connect_to_host>`) to send multiple requests. Because of this, methods that take URLs usually take just the part after the host instead of the full URL, as the client is already connected to a host. See :ref:`request<class_HTTPClient_method_request>` for a full example and to get started.
  17. A **HTTPClient** should be reused between multiple requests or to connect to different hosts instead of creating one client per request. Supports Transport Layer Security (TLS), including server certificate verification. HTTP status codes in the 2xx range indicate success, 3xx redirection (i.e. "try again, but over here"), 4xx something was wrong with the request, and 5xx something went wrong on the server's side.
  18. For more information on HTTP, see `MDN's documentation on HTTP <https://developer.mozilla.org/en-US/docs/Web/HTTP>`__ (or read `RFC 2616 <https://tools.ietf.org/html/rfc2616>`__ to get it straight from the source).
  19. \ **Note:** When exporting to Android, make sure to enable the ``INTERNET`` permission in the Android export preset before exporting the project or using one-click deploy. Otherwise, network communication of any kind will be blocked by Android.
  20. \ **Note:** It's recommended to use transport encryption (TLS) and to avoid sending sensitive information (such as login credentials) in HTTP GET URL parameters. Consider using HTTP POST requests or HTTP headers for such information instead.
  21. \ **Note:** When performing HTTP requests from a project exported to Web, keep in mind the remote server may not allow requests from foreign origins due to `CORS <https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS>`__. If you host the server in question, you should modify its backend to allow requests from foreign origins by adding the ``Access-Control-Allow-Origin: *`` HTTP header.
  22. \ **Note:** TLS support is currently limited to TLS 1.0, TLS 1.1, and TLS 1.2. Attempting to connect to a TLS 1.3-only server will return an error.
  23. \ **Warning:** TLS certificate revocation and certificate pinning are currently not supported. Revoked certificates are accepted as long as they are otherwise valid. If this is a concern, you may want to use automatically managed certificates with a short validity period.
  24. .. rst-class:: classref-introduction-group
  25. Tutorials
  26. ---------
  27. - :doc:`HTTP client class <../tutorials/networking/http_client_class>`
  28. - :doc:`TLS certificates <../tutorials/networking/ssl_certificates>`
  29. .. rst-class:: classref-reftable-group
  30. Properties
  31. ----------
  32. .. table::
  33. :widths: auto
  34. +-------------------------------------+-------------------------------------------------------------------------------+-----------+
  35. | :ref:`bool<class_bool>` | :ref:`blocking_mode_enabled<class_HTTPClient_property_blocking_mode_enabled>` | ``false`` |
  36. +-------------------------------------+-------------------------------------------------------------------------------+-----------+
  37. | :ref:`StreamPeer<class_StreamPeer>` | :ref:`connection<class_HTTPClient_property_connection>` | |
  38. +-------------------------------------+-------------------------------------------------------------------------------+-----------+
  39. | :ref:`int<class_int>` | :ref:`read_chunk_size<class_HTTPClient_property_read_chunk_size>` | ``65536`` |
  40. +-------------------------------------+-------------------------------------------------------------------------------+-----------+
  41. .. rst-class:: classref-reftable-group
  42. Methods
  43. -------
  44. .. table::
  45. :widths: auto
  46. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  47. | void | :ref:`close<class_HTTPClient_method_close>` **(** **)** |
  48. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  49. | :ref:`Error<enum_@GlobalScope_Error>` | :ref:`connect_to_host<class_HTTPClient_method_connect_to_host>` **(** :ref:`String<class_String>` host, :ref:`int<class_int>` port=-1, :ref:`TLSOptions<class_TLSOptions>` tls_options=null **)** |
  50. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  51. | :ref:`int<class_int>` | :ref:`get_response_body_length<class_HTTPClient_method_get_response_body_length>` **(** **)** |const| |
  52. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  53. | :ref:`int<class_int>` | :ref:`get_response_code<class_HTTPClient_method_get_response_code>` **(** **)** |const| |
  54. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  55. | :ref:`PackedStringArray<class_PackedStringArray>` | :ref:`get_response_headers<class_HTTPClient_method_get_response_headers>` **(** **)** |
  56. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  57. | :ref:`Dictionary<class_Dictionary>` | :ref:`get_response_headers_as_dictionary<class_HTTPClient_method_get_response_headers_as_dictionary>` **(** **)** |
  58. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  59. | :ref:`Status<enum_HTTPClient_Status>` | :ref:`get_status<class_HTTPClient_method_get_status>` **(** **)** |const| |
  60. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  61. | :ref:`bool<class_bool>` | :ref:`has_response<class_HTTPClient_method_has_response>` **(** **)** |const| |
  62. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  63. | :ref:`bool<class_bool>` | :ref:`is_response_chunked<class_HTTPClient_method_is_response_chunked>` **(** **)** |const| |
  64. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  65. | :ref:`Error<enum_@GlobalScope_Error>` | :ref:`poll<class_HTTPClient_method_poll>` **(** **)** |
  66. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  67. | :ref:`String<class_String>` | :ref:`query_string_from_dict<class_HTTPClient_method_query_string_from_dict>` **(** :ref:`Dictionary<class_Dictionary>` fields **)** |
  68. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  69. | :ref:`PackedByteArray<class_PackedByteArray>` | :ref:`read_response_body_chunk<class_HTTPClient_method_read_response_body_chunk>` **(** **)** |
  70. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  71. | :ref:`Error<enum_@GlobalScope_Error>` | :ref:`request<class_HTTPClient_method_request>` **(** :ref:`Method<enum_HTTPClient_Method>` method, :ref:`String<class_String>` url, :ref:`PackedStringArray<class_PackedStringArray>` headers, :ref:`String<class_String>` body="" **)** |
  72. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  73. | :ref:`Error<enum_@GlobalScope_Error>` | :ref:`request_raw<class_HTTPClient_method_request_raw>` **(** :ref:`Method<enum_HTTPClient_Method>` method, :ref:`String<class_String>` url, :ref:`PackedStringArray<class_PackedStringArray>` headers, :ref:`PackedByteArray<class_PackedByteArray>` body **)** |
  74. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  75. | void | :ref:`set_http_proxy<class_HTTPClient_method_set_http_proxy>` **(** :ref:`String<class_String>` host, :ref:`int<class_int>` port **)** |
  76. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  77. | void | :ref:`set_https_proxy<class_HTTPClient_method_set_https_proxy>` **(** :ref:`String<class_String>` host, :ref:`int<class_int>` port **)** |
  78. +---------------------------------------------------+------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------+
  79. .. rst-class:: classref-section-separator
  80. ----
  81. .. rst-class:: classref-descriptions-group
  82. Enumerations
  83. ------------
  84. .. _enum_HTTPClient_Method:
  85. .. rst-class:: classref-enumeration
  86. enum **Method**:
  87. .. _class_HTTPClient_constant_METHOD_GET:
  88. .. rst-class:: classref-enumeration-constant
  89. :ref:`Method<enum_HTTPClient_Method>` **METHOD_GET** = ``0``
  90. HTTP GET method. The GET method requests a representation of the specified resource. Requests using GET should only retrieve data.
  91. .. _class_HTTPClient_constant_METHOD_HEAD:
  92. .. rst-class:: classref-enumeration-constant
  93. :ref:`Method<enum_HTTPClient_Method>` **METHOD_HEAD** = ``1``
  94. HTTP HEAD method. The HEAD method asks for a response identical to that of a GET request, but without the response body. This is useful to request metadata like HTTP headers or to check if a resource exists.
  95. .. _class_HTTPClient_constant_METHOD_POST:
  96. .. rst-class:: classref-enumeration-constant
  97. :ref:`Method<enum_HTTPClient_Method>` **METHOD_POST** = ``2``
  98. HTTP POST method. The POST method is used to submit an entity to the specified resource, often causing a change in state or side effects on the server. This is often used for forms and submitting data or uploading files.
  99. .. _class_HTTPClient_constant_METHOD_PUT:
  100. .. rst-class:: classref-enumeration-constant
  101. :ref:`Method<enum_HTTPClient_Method>` **METHOD_PUT** = ``3``
  102. HTTP PUT method. The PUT method asks to replace all current representations of the target resource with the request payload. (You can think of POST as "create or update" and PUT as "update", although many services tend to not make a clear distinction or change their meaning).
  103. .. _class_HTTPClient_constant_METHOD_DELETE:
  104. .. rst-class:: classref-enumeration-constant
  105. :ref:`Method<enum_HTTPClient_Method>` **METHOD_DELETE** = ``4``
  106. HTTP DELETE method. The DELETE method requests to delete the specified resource.
  107. .. _class_HTTPClient_constant_METHOD_OPTIONS:
  108. .. rst-class:: classref-enumeration-constant
  109. :ref:`Method<enum_HTTPClient_Method>` **METHOD_OPTIONS** = ``5``
  110. HTTP OPTIONS method. The OPTIONS method asks for a description of the communication options for the target resource. Rarely used.
  111. .. _class_HTTPClient_constant_METHOD_TRACE:
  112. .. rst-class:: classref-enumeration-constant
  113. :ref:`Method<enum_HTTPClient_Method>` **METHOD_TRACE** = ``6``
  114. HTTP TRACE method. The TRACE method performs a message loop-back test along the path to the target resource. Returns the entire HTTP request received in the response body. Rarely used.
  115. .. _class_HTTPClient_constant_METHOD_CONNECT:
  116. .. rst-class:: classref-enumeration-constant
  117. :ref:`Method<enum_HTTPClient_Method>` **METHOD_CONNECT** = ``7``
  118. HTTP CONNECT method. The CONNECT method establishes a tunnel to the server identified by the target resource. Rarely used.
  119. .. _class_HTTPClient_constant_METHOD_PATCH:
  120. .. rst-class:: classref-enumeration-constant
  121. :ref:`Method<enum_HTTPClient_Method>` **METHOD_PATCH** = ``8``
  122. HTTP PATCH method. The PATCH method is used to apply partial modifications to a resource.
  123. .. _class_HTTPClient_constant_METHOD_MAX:
  124. .. rst-class:: classref-enumeration-constant
  125. :ref:`Method<enum_HTTPClient_Method>` **METHOD_MAX** = ``9``
  126. Represents the size of the :ref:`Method<enum_HTTPClient_Method>` enum.
  127. .. rst-class:: classref-item-separator
  128. ----
  129. .. _enum_HTTPClient_Status:
  130. .. rst-class:: classref-enumeration
  131. enum **Status**:
  132. .. _class_HTTPClient_constant_STATUS_DISCONNECTED:
  133. .. rst-class:: classref-enumeration-constant
  134. :ref:`Status<enum_HTTPClient_Status>` **STATUS_DISCONNECTED** = ``0``
  135. Status: Disconnected from the server.
  136. .. _class_HTTPClient_constant_STATUS_RESOLVING:
  137. .. rst-class:: classref-enumeration-constant
  138. :ref:`Status<enum_HTTPClient_Status>` **STATUS_RESOLVING** = ``1``
  139. Status: Currently resolving the hostname for the given URL into an IP.
  140. .. _class_HTTPClient_constant_STATUS_CANT_RESOLVE:
  141. .. rst-class:: classref-enumeration-constant
  142. :ref:`Status<enum_HTTPClient_Status>` **STATUS_CANT_RESOLVE** = ``2``
  143. Status: DNS failure: Can't resolve the hostname for the given URL.
  144. .. _class_HTTPClient_constant_STATUS_CONNECTING:
  145. .. rst-class:: classref-enumeration-constant
  146. :ref:`Status<enum_HTTPClient_Status>` **STATUS_CONNECTING** = ``3``
  147. Status: Currently connecting to server.
  148. .. _class_HTTPClient_constant_STATUS_CANT_CONNECT:
  149. .. rst-class:: classref-enumeration-constant
  150. :ref:`Status<enum_HTTPClient_Status>` **STATUS_CANT_CONNECT** = ``4``
  151. Status: Can't connect to the server.
  152. .. _class_HTTPClient_constant_STATUS_CONNECTED:
  153. .. rst-class:: classref-enumeration-constant
  154. :ref:`Status<enum_HTTPClient_Status>` **STATUS_CONNECTED** = ``5``
  155. Status: Connection established.
  156. .. _class_HTTPClient_constant_STATUS_REQUESTING:
  157. .. rst-class:: classref-enumeration-constant
  158. :ref:`Status<enum_HTTPClient_Status>` **STATUS_REQUESTING** = ``6``
  159. Status: Currently sending request.
  160. .. _class_HTTPClient_constant_STATUS_BODY:
  161. .. rst-class:: classref-enumeration-constant
  162. :ref:`Status<enum_HTTPClient_Status>` **STATUS_BODY** = ``7``
  163. Status: HTTP body received.
  164. .. _class_HTTPClient_constant_STATUS_CONNECTION_ERROR:
  165. .. rst-class:: classref-enumeration-constant
  166. :ref:`Status<enum_HTTPClient_Status>` **STATUS_CONNECTION_ERROR** = ``8``
  167. Status: Error in HTTP connection.
  168. .. _class_HTTPClient_constant_STATUS_TLS_HANDSHAKE_ERROR:
  169. .. rst-class:: classref-enumeration-constant
  170. :ref:`Status<enum_HTTPClient_Status>` **STATUS_TLS_HANDSHAKE_ERROR** = ``9``
  171. Status: Error in TLS handshake.
  172. .. rst-class:: classref-item-separator
  173. ----
  174. .. _enum_HTTPClient_ResponseCode:
  175. .. rst-class:: classref-enumeration
  176. enum **ResponseCode**:
  177. .. _class_HTTPClient_constant_RESPONSE_CONTINUE:
  178. .. rst-class:: classref-enumeration-constant
  179. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_CONTINUE** = ``100``
  180. HTTP status code ``100 Continue``. Interim response that indicates everything so far is OK and that the client should continue with the request (or ignore this status if already finished).
  181. .. _class_HTTPClient_constant_RESPONSE_SWITCHING_PROTOCOLS:
  182. .. rst-class:: classref-enumeration-constant
  183. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_SWITCHING_PROTOCOLS** = ``101``
  184. HTTP status code ``101 Switching Protocol``. Sent in response to an ``Upgrade`` request header by the client. Indicates the protocol the server is switching to.
  185. .. _class_HTTPClient_constant_RESPONSE_PROCESSING:
  186. .. rst-class:: classref-enumeration-constant
  187. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PROCESSING** = ``102``
  188. HTTP status code ``102 Processing`` (WebDAV). Indicates that the server has received and is processing the request, but no response is available yet.
  189. .. _class_HTTPClient_constant_RESPONSE_OK:
  190. .. rst-class:: classref-enumeration-constant
  191. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_OK** = ``200``
  192. HTTP status code ``200 OK``. The request has succeeded. Default response for successful requests. Meaning varies depending on the request. GET: The resource has been fetched and is transmitted in the message body. HEAD: The entity headers are in the message body. POST: The resource describing the result of the action is transmitted in the message body. TRACE: The message body contains the request message as received by the server.
  193. .. _class_HTTPClient_constant_RESPONSE_CREATED:
  194. .. rst-class:: classref-enumeration-constant
  195. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_CREATED** = ``201``
  196. HTTP status code ``201 Created``. The request has succeeded and a new resource has been created as a result of it. This is typically the response sent after a PUT request.
  197. .. _class_HTTPClient_constant_RESPONSE_ACCEPTED:
  198. .. rst-class:: classref-enumeration-constant
  199. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_ACCEPTED** = ``202``
  200. HTTP status code ``202 Accepted``. The request has been received but not yet acted upon. It is non-committal, meaning that there is no way in HTTP to later send an asynchronous response indicating the outcome of processing the request. It is intended for cases where another process or server handles the request, or for batch processing.
  201. .. _class_HTTPClient_constant_RESPONSE_NON_AUTHORITATIVE_INFORMATION:
  202. .. rst-class:: classref-enumeration-constant
  203. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NON_AUTHORITATIVE_INFORMATION** = ``203``
  204. HTTP status code ``203 Non-Authoritative Information``. This response code means returned meta-information set is not exact set as available from the origin server, but collected from a local or a third party copy. Except this condition, 200 OK response should be preferred instead of this response.
  205. .. _class_HTTPClient_constant_RESPONSE_NO_CONTENT:
  206. .. rst-class:: classref-enumeration-constant
  207. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NO_CONTENT** = ``204``
  208. HTTP status code ``204 No Content``. There is no content to send for this request, but the headers may be useful. The user-agent may update its cached headers for this resource with the new ones.
  209. .. _class_HTTPClient_constant_RESPONSE_RESET_CONTENT:
  210. .. rst-class:: classref-enumeration-constant
  211. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_RESET_CONTENT** = ``205``
  212. HTTP status code ``205 Reset Content``. The server has fulfilled the request and desires that the client resets the "document view" that caused the request to be sent to its original state as received from the origin server.
  213. .. _class_HTTPClient_constant_RESPONSE_PARTIAL_CONTENT:
  214. .. rst-class:: classref-enumeration-constant
  215. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PARTIAL_CONTENT** = ``206``
  216. HTTP status code ``206 Partial Content``. This response code is used because of a range header sent by the client to separate download into multiple streams.
  217. .. _class_HTTPClient_constant_RESPONSE_MULTI_STATUS:
  218. .. rst-class:: classref-enumeration-constant
  219. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_MULTI_STATUS** = ``207``
  220. HTTP status code ``207 Multi-Status`` (WebDAV). A Multi-Status response conveys information about multiple resources in situations where multiple status codes might be appropriate.
  221. .. _class_HTTPClient_constant_RESPONSE_ALREADY_REPORTED:
  222. .. rst-class:: classref-enumeration-constant
  223. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_ALREADY_REPORTED** = ``208``
  224. HTTP status code ``208 Already Reported`` (WebDAV). Used inside a DAV: propstat response element to avoid enumerating the internal members of multiple bindings to the same collection repeatedly.
  225. .. _class_HTTPClient_constant_RESPONSE_IM_USED:
  226. .. rst-class:: classref-enumeration-constant
  227. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_IM_USED** = ``226``
  228. HTTP status code ``226 IM Used`` (WebDAV). The server has fulfilled a GET request for the resource, and the response is a representation of the result of one or more instance-manipulations applied to the current instance.
  229. .. _class_HTTPClient_constant_RESPONSE_MULTIPLE_CHOICES:
  230. .. rst-class:: classref-enumeration-constant
  231. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_MULTIPLE_CHOICES** = ``300``
  232. HTTP status code ``300 Multiple Choice``. The request has more than one possible responses and there is no standardized way to choose one of the responses. User-agent or user should choose one of them.
  233. .. _class_HTTPClient_constant_RESPONSE_MOVED_PERMANENTLY:
  234. .. rst-class:: classref-enumeration-constant
  235. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_MOVED_PERMANENTLY** = ``301``
  236. HTTP status code ``301 Moved Permanently``. Redirection. This response code means the URI of requested resource has been changed. The new URI is usually included in the response.
  237. .. _class_HTTPClient_constant_RESPONSE_FOUND:
  238. .. rst-class:: classref-enumeration-constant
  239. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_FOUND** = ``302``
  240. HTTP status code ``302 Found``. Temporary redirection. This response code means the URI of requested resource has been changed temporarily. New changes in the URI might be made in the future. Therefore, this same URI should be used by the client in future requests.
  241. .. _class_HTTPClient_constant_RESPONSE_SEE_OTHER:
  242. .. rst-class:: classref-enumeration-constant
  243. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_SEE_OTHER** = ``303``
  244. HTTP status code ``303 See Other``. The server is redirecting the user agent to a different resource, as indicated by a URI in the Location header field, which is intended to provide an indirect response to the original request.
  245. .. _class_HTTPClient_constant_RESPONSE_NOT_MODIFIED:
  246. .. rst-class:: classref-enumeration-constant
  247. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NOT_MODIFIED** = ``304``
  248. HTTP status code ``304 Not Modified``. A conditional GET or HEAD request has been received and would have resulted in a 200 OK response if it were not for the fact that the condition evaluated to ``false``.
  249. .. _class_HTTPClient_constant_RESPONSE_USE_PROXY:
  250. .. rst-class:: classref-enumeration-constant
  251. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_USE_PROXY** = ``305``
  252. *Deprecated.* HTTP status code ``305 Use Proxy``.
  253. .. _class_HTTPClient_constant_RESPONSE_SWITCH_PROXY:
  254. .. rst-class:: classref-enumeration-constant
  255. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_SWITCH_PROXY** = ``306``
  256. *Deprecated.* HTTP status code ``306 Switch Proxy``.
  257. .. _class_HTTPClient_constant_RESPONSE_TEMPORARY_REDIRECT:
  258. .. rst-class:: classref-enumeration-constant
  259. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_TEMPORARY_REDIRECT** = ``307``
  260. HTTP status code ``307 Temporary Redirect``. The target resource resides temporarily under a different URI and the user agent MUST NOT change the request method if it performs an automatic redirection to that URI.
  261. .. _class_HTTPClient_constant_RESPONSE_PERMANENT_REDIRECT:
  262. .. rst-class:: classref-enumeration-constant
  263. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PERMANENT_REDIRECT** = ``308``
  264. HTTP status code ``308 Permanent Redirect``. The target resource has been assigned a new permanent URI and any future references to this resource ought to use one of the enclosed URIs.
  265. .. _class_HTTPClient_constant_RESPONSE_BAD_REQUEST:
  266. .. rst-class:: classref-enumeration-constant
  267. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_BAD_REQUEST** = ``400``
  268. HTTP status code ``400 Bad Request``. The request was invalid. The server cannot or will not process the request due to something that is perceived to be a client error (e.g., malformed request syntax, invalid request message framing, invalid request contents, or deceptive request routing).
  269. .. _class_HTTPClient_constant_RESPONSE_UNAUTHORIZED:
  270. .. rst-class:: classref-enumeration-constant
  271. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_UNAUTHORIZED** = ``401``
  272. HTTP status code ``401 Unauthorized``. Credentials required. The request has not been applied because it lacks valid authentication credentials for the target resource.
  273. .. _class_HTTPClient_constant_RESPONSE_PAYMENT_REQUIRED:
  274. .. rst-class:: classref-enumeration-constant
  275. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PAYMENT_REQUIRED** = ``402``
  276. HTTP status code ``402 Payment Required``. This response code is reserved for future use. Initial aim for creating this code was using it for digital payment systems, however this is not currently used.
  277. .. _class_HTTPClient_constant_RESPONSE_FORBIDDEN:
  278. .. rst-class:: classref-enumeration-constant
  279. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_FORBIDDEN** = ``403``
  280. HTTP status code ``403 Forbidden``. The client does not have access rights to the content, i.e. they are unauthorized, so server is rejecting to give proper response. Unlike ``401``, the client's identity is known to the server.
  281. .. _class_HTTPClient_constant_RESPONSE_NOT_FOUND:
  282. .. rst-class:: classref-enumeration-constant
  283. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NOT_FOUND** = ``404``
  284. HTTP status code ``404 Not Found``. The server can not find requested resource. Either the URL is not recognized or the endpoint is valid but the resource itself does not exist. May also be sent instead of 403 to hide existence of a resource if the client is not authorized.
  285. .. _class_HTTPClient_constant_RESPONSE_METHOD_NOT_ALLOWED:
  286. .. rst-class:: classref-enumeration-constant
  287. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_METHOD_NOT_ALLOWED** = ``405``
  288. HTTP status code ``405 Method Not Allowed``. The request's HTTP method is known by the server but has been disabled and cannot be used. For example, an API may forbid DELETE-ing a resource. The two mandatory methods, GET and HEAD, must never be disabled and should not return this error code.
  289. .. _class_HTTPClient_constant_RESPONSE_NOT_ACCEPTABLE:
  290. .. rst-class:: classref-enumeration-constant
  291. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NOT_ACCEPTABLE** = ``406``
  292. HTTP status code ``406 Not Acceptable``. The target resource does not have a current representation that would be acceptable to the user agent, according to the proactive negotiation header fields received in the request. Used when negotiation content.
  293. .. _class_HTTPClient_constant_RESPONSE_PROXY_AUTHENTICATION_REQUIRED:
  294. .. rst-class:: classref-enumeration-constant
  295. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PROXY_AUTHENTICATION_REQUIRED** = ``407``
  296. HTTP status code ``407 Proxy Authentication Required``. Similar to 401 Unauthorized, but it indicates that the client needs to authenticate itself in order to use a proxy.
  297. .. _class_HTTPClient_constant_RESPONSE_REQUEST_TIMEOUT:
  298. .. rst-class:: classref-enumeration-constant
  299. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_REQUEST_TIMEOUT** = ``408``
  300. HTTP status code ``408 Request Timeout``. The server did not receive a complete request message within the time that it was prepared to wait.
  301. .. _class_HTTPClient_constant_RESPONSE_CONFLICT:
  302. .. rst-class:: classref-enumeration-constant
  303. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_CONFLICT** = ``409``
  304. HTTP status code ``409 Conflict``. The request could not be completed due to a conflict with the current state of the target resource. This code is used in situations where the user might be able to resolve the conflict and resubmit the request.
  305. .. _class_HTTPClient_constant_RESPONSE_GONE:
  306. .. rst-class:: classref-enumeration-constant
  307. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_GONE** = ``410``
  308. HTTP status code ``410 Gone``. The target resource is no longer available at the origin server and this condition is likely permanent.
  309. .. _class_HTTPClient_constant_RESPONSE_LENGTH_REQUIRED:
  310. .. rst-class:: classref-enumeration-constant
  311. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_LENGTH_REQUIRED** = ``411``
  312. HTTP status code ``411 Length Required``. The server refuses to accept the request without a defined Content-Length header.
  313. .. _class_HTTPClient_constant_RESPONSE_PRECONDITION_FAILED:
  314. .. rst-class:: classref-enumeration-constant
  315. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PRECONDITION_FAILED** = ``412``
  316. HTTP status code ``412 Precondition Failed``. One or more conditions given in the request header fields evaluated to ``false`` when tested on the server.
  317. .. _class_HTTPClient_constant_RESPONSE_REQUEST_ENTITY_TOO_LARGE:
  318. .. rst-class:: classref-enumeration-constant
  319. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_REQUEST_ENTITY_TOO_LARGE** = ``413``
  320. HTTP status code ``413 Entity Too Large``. The server is refusing to process a request because the request payload is larger than the server is willing or able to process.
  321. .. _class_HTTPClient_constant_RESPONSE_REQUEST_URI_TOO_LONG:
  322. .. rst-class:: classref-enumeration-constant
  323. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_REQUEST_URI_TOO_LONG** = ``414``
  324. HTTP status code ``414 Request-URI Too Long``. The server is refusing to service the request because the request-target is longer than the server is willing to interpret.
  325. .. _class_HTTPClient_constant_RESPONSE_UNSUPPORTED_MEDIA_TYPE:
  326. .. rst-class:: classref-enumeration-constant
  327. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_UNSUPPORTED_MEDIA_TYPE** = ``415``
  328. HTTP status code ``415 Unsupported Media Type``. The origin server is refusing to service the request because the payload is in a format not supported by this method on the target resource.
  329. .. _class_HTTPClient_constant_RESPONSE_REQUESTED_RANGE_NOT_SATISFIABLE:
  330. .. rst-class:: classref-enumeration-constant
  331. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_REQUESTED_RANGE_NOT_SATISFIABLE** = ``416``
  332. HTTP status code ``416 Requested Range Not Satisfiable``. None of the ranges in the request's Range header field overlap the current extent of the selected resource or the set of ranges requested has been rejected due to invalid ranges or an excessive request of small or overlapping ranges.
  333. .. _class_HTTPClient_constant_RESPONSE_EXPECTATION_FAILED:
  334. .. rst-class:: classref-enumeration-constant
  335. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_EXPECTATION_FAILED** = ``417``
  336. HTTP status code ``417 Expectation Failed``. The expectation given in the request's Expect header field could not be met by at least one of the inbound servers.
  337. .. _class_HTTPClient_constant_RESPONSE_IM_A_TEAPOT:
  338. .. rst-class:: classref-enumeration-constant
  339. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_IM_A_TEAPOT** = ``418``
  340. HTTP status code ``418 I'm A Teapot``. Any attempt to brew coffee with a teapot should result in the error code "418 I'm a teapot". The resulting entity body MAY be short and stout.
  341. .. _class_HTTPClient_constant_RESPONSE_MISDIRECTED_REQUEST:
  342. .. rst-class:: classref-enumeration-constant
  343. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_MISDIRECTED_REQUEST** = ``421``
  344. HTTP status code ``421 Misdirected Request``. The request was directed at a server that is not able to produce a response. This can be sent by a server that is not configured to produce responses for the combination of scheme and authority that are included in the request URI.
  345. .. _class_HTTPClient_constant_RESPONSE_UNPROCESSABLE_ENTITY:
  346. .. rst-class:: classref-enumeration-constant
  347. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_UNPROCESSABLE_ENTITY** = ``422``
  348. HTTP status code ``422 Unprocessable Entity`` (WebDAV). The server understands the content type of the request entity (hence a 415 Unsupported Media Type status code is inappropriate), and the syntax of the request entity is correct (thus a 400 Bad Request status code is inappropriate) but was unable to process the contained instructions.
  349. .. _class_HTTPClient_constant_RESPONSE_LOCKED:
  350. .. rst-class:: classref-enumeration-constant
  351. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_LOCKED** = ``423``
  352. HTTP status code ``423 Locked`` (WebDAV). The source or destination resource of a method is locked.
  353. .. _class_HTTPClient_constant_RESPONSE_FAILED_DEPENDENCY:
  354. .. rst-class:: classref-enumeration-constant
  355. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_FAILED_DEPENDENCY** = ``424``
  356. HTTP status code ``424 Failed Dependency`` (WebDAV). The method could not be performed on the resource because the requested action depended on another action and that action failed.
  357. .. _class_HTTPClient_constant_RESPONSE_UPGRADE_REQUIRED:
  358. .. rst-class:: classref-enumeration-constant
  359. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_UPGRADE_REQUIRED** = ``426``
  360. HTTP status code ``426 Upgrade Required``. The server refuses to perform the request using the current protocol but might be willing to do so after the client upgrades to a different protocol.
  361. .. _class_HTTPClient_constant_RESPONSE_PRECONDITION_REQUIRED:
  362. .. rst-class:: classref-enumeration-constant
  363. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_PRECONDITION_REQUIRED** = ``428``
  364. HTTP status code ``428 Precondition Required``. The origin server requires the request to be conditional.
  365. .. _class_HTTPClient_constant_RESPONSE_TOO_MANY_REQUESTS:
  366. .. rst-class:: classref-enumeration-constant
  367. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_TOO_MANY_REQUESTS** = ``429``
  368. HTTP status code ``429 Too Many Requests``. The user has sent too many requests in a given amount of time (see "rate limiting"). Back off and increase time between requests or try again later.
  369. .. _class_HTTPClient_constant_RESPONSE_REQUEST_HEADER_FIELDS_TOO_LARGE:
  370. .. rst-class:: classref-enumeration-constant
  371. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_REQUEST_HEADER_FIELDS_TOO_LARGE** = ``431``
  372. HTTP status code ``431 Request Header Fields Too Large``. The server is unwilling to process the request because its header fields are too large. The request MAY be resubmitted after reducing the size of the request header fields.
  373. .. _class_HTTPClient_constant_RESPONSE_UNAVAILABLE_FOR_LEGAL_REASONS:
  374. .. rst-class:: classref-enumeration-constant
  375. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_UNAVAILABLE_FOR_LEGAL_REASONS** = ``451``
  376. HTTP status code ``451 Response Unavailable For Legal Reasons``. The server is denying access to the resource as a consequence of a legal demand.
  377. .. _class_HTTPClient_constant_RESPONSE_INTERNAL_SERVER_ERROR:
  378. .. rst-class:: classref-enumeration-constant
  379. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_INTERNAL_SERVER_ERROR** = ``500``
  380. HTTP status code ``500 Internal Server Error``. The server encountered an unexpected condition that prevented it from fulfilling the request.
  381. .. _class_HTTPClient_constant_RESPONSE_NOT_IMPLEMENTED:
  382. .. rst-class:: classref-enumeration-constant
  383. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NOT_IMPLEMENTED** = ``501``
  384. HTTP status code ``501 Not Implemented``. The server does not support the functionality required to fulfill the request.
  385. .. _class_HTTPClient_constant_RESPONSE_BAD_GATEWAY:
  386. .. rst-class:: classref-enumeration-constant
  387. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_BAD_GATEWAY** = ``502``
  388. HTTP status code ``502 Bad Gateway``. The server, while acting as a gateway or proxy, received an invalid response from an inbound server it accessed while attempting to fulfill the request. Usually returned by load balancers or proxies.
  389. .. _class_HTTPClient_constant_RESPONSE_SERVICE_UNAVAILABLE:
  390. .. rst-class:: classref-enumeration-constant
  391. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_SERVICE_UNAVAILABLE** = ``503``
  392. HTTP status code ``503 Service Unavailable``. The server is currently unable to handle the request due to a temporary overload or scheduled maintenance, which will likely be alleviated after some delay. Try again later.
  393. .. _class_HTTPClient_constant_RESPONSE_GATEWAY_TIMEOUT:
  394. .. rst-class:: classref-enumeration-constant
  395. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_GATEWAY_TIMEOUT** = ``504``
  396. HTTP status code ``504 Gateway Timeout``. The server, while acting as a gateway or proxy, did not receive a timely response from an upstream server it needed to access in order to complete the request. Usually returned by load balancers or proxies.
  397. .. _class_HTTPClient_constant_RESPONSE_HTTP_VERSION_NOT_SUPPORTED:
  398. .. rst-class:: classref-enumeration-constant
  399. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_HTTP_VERSION_NOT_SUPPORTED** = ``505``
  400. HTTP status code ``505 HTTP Version Not Supported``. The server does not support, or refuses to support, the major version of HTTP that was used in the request message.
  401. .. _class_HTTPClient_constant_RESPONSE_VARIANT_ALSO_NEGOTIATES:
  402. .. rst-class:: classref-enumeration-constant
  403. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_VARIANT_ALSO_NEGOTIATES** = ``506``
  404. HTTP status code ``506 Variant Also Negotiates``. The server has an internal configuration error: the chosen variant resource is configured to engage in transparent content negotiation itself, and is therefore not a proper end point in the negotiation process.
  405. .. _class_HTTPClient_constant_RESPONSE_INSUFFICIENT_STORAGE:
  406. .. rst-class:: classref-enumeration-constant
  407. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_INSUFFICIENT_STORAGE** = ``507``
  408. HTTP status code ``507 Insufficient Storage``. The method could not be performed on the resource because the server is unable to store the representation needed to successfully complete the request.
  409. .. _class_HTTPClient_constant_RESPONSE_LOOP_DETECTED:
  410. .. rst-class:: classref-enumeration-constant
  411. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_LOOP_DETECTED** = ``508``
  412. HTTP status code ``508 Loop Detected``. The server terminated an operation because it encountered an infinite loop while processing a request with "Depth: infinity". This status indicates that the entire operation failed.
  413. .. _class_HTTPClient_constant_RESPONSE_NOT_EXTENDED:
  414. .. rst-class:: classref-enumeration-constant
  415. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NOT_EXTENDED** = ``510``
  416. HTTP status code ``510 Not Extended``. The policy for accessing the resource has not been met in the request. The server should send back all the information necessary for the client to issue an extended request.
  417. .. _class_HTTPClient_constant_RESPONSE_NETWORK_AUTH_REQUIRED:
  418. .. rst-class:: classref-enumeration-constant
  419. :ref:`ResponseCode<enum_HTTPClient_ResponseCode>` **RESPONSE_NETWORK_AUTH_REQUIRED** = ``511``
  420. HTTP status code ``511 Network Authentication Required``. The client needs to authenticate to gain network access.
  421. .. rst-class:: classref-section-separator
  422. ----
  423. .. rst-class:: classref-descriptions-group
  424. Property Descriptions
  425. ---------------------
  426. .. _class_HTTPClient_property_blocking_mode_enabled:
  427. .. rst-class:: classref-property
  428. :ref:`bool<class_bool>` **blocking_mode_enabled** = ``false``
  429. .. rst-class:: classref-property-setget
  430. - void **set_blocking_mode** **(** :ref:`bool<class_bool>` value **)**
  431. - :ref:`bool<class_bool>` **is_blocking_mode_enabled** **(** **)**
  432. If ``true``, execution will block until all data is read from the response.
  433. .. rst-class:: classref-item-separator
  434. ----
  435. .. _class_HTTPClient_property_connection:
  436. .. rst-class:: classref-property
  437. :ref:`StreamPeer<class_StreamPeer>` **connection**
  438. .. rst-class:: classref-property-setget
  439. - void **set_connection** **(** :ref:`StreamPeer<class_StreamPeer>` value **)**
  440. - :ref:`StreamPeer<class_StreamPeer>` **get_connection** **(** **)**
  441. The connection to use for this client.
  442. .. rst-class:: classref-item-separator
  443. ----
  444. .. _class_HTTPClient_property_read_chunk_size:
  445. .. rst-class:: classref-property
  446. :ref:`int<class_int>` **read_chunk_size** = ``65536``
  447. .. rst-class:: classref-property-setget
  448. - void **set_read_chunk_size** **(** :ref:`int<class_int>` value **)**
  449. - :ref:`int<class_int>` **get_read_chunk_size** **(** **)**
  450. The size of the buffer used and maximum bytes to read per iteration. See :ref:`read_response_body_chunk<class_HTTPClient_method_read_response_body_chunk>`.
  451. .. rst-class:: classref-section-separator
  452. ----
  453. .. rst-class:: classref-descriptions-group
  454. Method Descriptions
  455. -------------------
  456. .. _class_HTTPClient_method_close:
  457. .. rst-class:: classref-method
  458. void **close** **(** **)**
  459. Closes the current connection, allowing reuse of this **HTTPClient**.
  460. .. rst-class:: classref-item-separator
  461. ----
  462. .. _class_HTTPClient_method_connect_to_host:
  463. .. rst-class:: classref-method
  464. :ref:`Error<enum_@GlobalScope_Error>` **connect_to_host** **(** :ref:`String<class_String>` host, :ref:`int<class_int>` port=-1, :ref:`TLSOptions<class_TLSOptions>` tls_options=null **)**
  465. Connects to a host. This needs to be done before any requests are sent.
  466. If no ``port`` is specified (or ``-1`` is used), it is automatically set to 80 for HTTP and 443 for HTTPS. You can pass the optional ``tls_options`` parameter to customize the trusted certification authorities, or the common name verification when using HTTPS. See :ref:`TLSOptions.client<class_TLSOptions_method_client>` and :ref:`TLSOptions.client_unsafe<class_TLSOptions_method_client_unsafe>`.
  467. .. rst-class:: classref-item-separator
  468. ----
  469. .. _class_HTTPClient_method_get_response_body_length:
  470. .. rst-class:: classref-method
  471. :ref:`int<class_int>` **get_response_body_length** **(** **)** |const|
  472. Returns the response's body length.
  473. \ **Note:** Some Web servers may not send a body length. In this case, the value returned will be ``-1``. If using chunked transfer encoding, the body length will also be ``-1``.
  474. \ **Note:** This function always returns ``-1`` on the Web platform due to browsers limitations.
  475. .. rst-class:: classref-item-separator
  476. ----
  477. .. _class_HTTPClient_method_get_response_code:
  478. .. rst-class:: classref-method
  479. :ref:`int<class_int>` **get_response_code** **(** **)** |const|
  480. Returns the response's HTTP status code.
  481. .. rst-class:: classref-item-separator
  482. ----
  483. .. _class_HTTPClient_method_get_response_headers:
  484. .. rst-class:: classref-method
  485. :ref:`PackedStringArray<class_PackedStringArray>` **get_response_headers** **(** **)**
  486. Returns the response headers.
  487. .. rst-class:: classref-item-separator
  488. ----
  489. .. _class_HTTPClient_method_get_response_headers_as_dictionary:
  490. .. rst-class:: classref-method
  491. :ref:`Dictionary<class_Dictionary>` **get_response_headers_as_dictionary** **(** **)**
  492. Returns all response headers as a Dictionary of structure ``{ "key": "value1; value2" }`` where the case-sensitivity of the keys and values is kept like the server delivers it. A value is a simple String, this string can have more than one value where "; " is used as separator.
  493. \ **Example:**\
  494. ::
  495. {
  496. "content-length": 12,
  497. "Content-Type": "application/json; charset=UTF-8",
  498. }
  499. .. rst-class:: classref-item-separator
  500. ----
  501. .. _class_HTTPClient_method_get_status:
  502. .. rst-class:: classref-method
  503. :ref:`Status<enum_HTTPClient_Status>` **get_status** **(** **)** |const|
  504. Returns a :ref:`Status<enum_HTTPClient_Status>` constant. Need to call :ref:`poll<class_HTTPClient_method_poll>` in order to get status updates.
  505. .. rst-class:: classref-item-separator
  506. ----
  507. .. _class_HTTPClient_method_has_response:
  508. .. rst-class:: classref-method
  509. :ref:`bool<class_bool>` **has_response** **(** **)** |const|
  510. If ``true``, this **HTTPClient** has a response available.
  511. .. rst-class:: classref-item-separator
  512. ----
  513. .. _class_HTTPClient_method_is_response_chunked:
  514. .. rst-class:: classref-method
  515. :ref:`bool<class_bool>` **is_response_chunked** **(** **)** |const|
  516. If ``true``, this **HTTPClient** has a response that is chunked.
  517. .. rst-class:: classref-item-separator
  518. ----
  519. .. _class_HTTPClient_method_poll:
  520. .. rst-class:: classref-method
  521. :ref:`Error<enum_@GlobalScope_Error>` **poll** **(** **)**
  522. This needs to be called in order to have any request processed. Check results with :ref:`get_status<class_HTTPClient_method_get_status>`.
  523. .. rst-class:: classref-item-separator
  524. ----
  525. .. _class_HTTPClient_method_query_string_from_dict:
  526. .. rst-class:: classref-method
  527. :ref:`String<class_String>` **query_string_from_dict** **(** :ref:`Dictionary<class_Dictionary>` fields **)**
  528. Generates a GET/POST application/x-www-form-urlencoded style query string from a provided dictionary, e.g.:
  529. .. tabs::
  530. .. code-tab:: gdscript
  531. var fields = {"username": "user", "password": "pass"}
  532. var query_string = http_client.query_string_from_dict(fields)
  533. # Returns "username=user&password=pass"
  534. .. code-tab:: csharp
  535. var fields = new Godot.Collections.Dictionary { { "username", "user" }, { "password", "pass" } };
  536. string queryString = httpClient.QueryStringFromDict(fields);
  537. // Returns "username=user&password=pass"
  538. Furthermore, if a key has a ``null`` value, only the key itself is added, without equal sign and value. If the value is an array, for each value in it a pair with the same key is added.
  539. .. tabs::
  540. .. code-tab:: gdscript
  541. var fields = {"single": 123, "not_valued": null, "multiple": [22, 33, 44]}
  542. var query_string = http_client.query_string_from_dict(fields)
  543. # Returns "single=123&not_valued&multiple=22&multiple=33&multiple=44"
  544. .. code-tab:: csharp
  545. var fields = new Godot.Collections.Dictionary
  546. {
  547. { "single", 123 },
  548. { "notValued", default },
  549. { "multiple", new Godot.Collections.Array { 22, 33, 44 } },
  550. };
  551. string queryString = httpClient.QueryStringFromDict(fields);
  552. // Returns "single=123&not_valued&multiple=22&multiple=33&multiple=44"
  553. .. rst-class:: classref-item-separator
  554. ----
  555. .. _class_HTTPClient_method_read_response_body_chunk:
  556. .. rst-class:: classref-method
  557. :ref:`PackedByteArray<class_PackedByteArray>` **read_response_body_chunk** **(** **)**
  558. Reads one chunk from the response.
  559. .. rst-class:: classref-item-separator
  560. ----
  561. .. _class_HTTPClient_method_request:
  562. .. rst-class:: classref-method
  563. :ref:`Error<enum_@GlobalScope_Error>` **request** **(** :ref:`Method<enum_HTTPClient_Method>` method, :ref:`String<class_String>` url, :ref:`PackedStringArray<class_PackedStringArray>` headers, :ref:`String<class_String>` body="" **)**
  564. Sends a request to the connected host.
  565. The URL parameter is usually just the part after the host, so for ``https://somehost.com/index.php``, it is ``/index.php``. When sending requests to an HTTP proxy server, it should be an absolute URL. For :ref:`METHOD_OPTIONS<class_HTTPClient_constant_METHOD_OPTIONS>` requests, ``*`` is also allowed. For :ref:`METHOD_CONNECT<class_HTTPClient_constant_METHOD_CONNECT>` requests, it should be the authority component (``host:port``).
  566. Headers are HTTP request headers. For available HTTP methods, see :ref:`Method<enum_HTTPClient_Method>`.
  567. To create a POST request with query strings to push to the server, do:
  568. .. tabs::
  569. .. code-tab:: gdscript
  570. var fields = {"username" : "user", "password" : "pass"}
  571. var query_string = http_client.query_string_from_dict(fields)
  572. var headers = ["Content-Type: application/x-www-form-urlencoded", "Content-Length: " + str(query_string.length())]
  573. var result = http_client.request(http_client.METHOD_POST, "/index.php", headers, query_string)
  574. .. code-tab:: csharp
  575. var fields = new Godot.Collections.Dictionary { { "username", "user" }, { "password", "pass" } };
  576. string queryString = new HTTPClient().QueryStringFromDict(fields);
  577. string[] headers = { "Content-Type: application/x-www-form-urlencoded", $"Content-Length: {queryString.Length}" };
  578. var result = new HTTPClient().Request(HTTPClient.Method.Post, "index.php", headers, queryString);
  579. \ **Note:** The ``body`` parameter is ignored if ``method`` is :ref:`METHOD_GET<class_HTTPClient_constant_METHOD_GET>`. This is because GET methods can't contain request data. As a workaround, you can pass request data as a query string in the URL. See :ref:`String.uri_encode<class_String_method_uri_encode>` for an example.
  580. .. rst-class:: classref-item-separator
  581. ----
  582. .. _class_HTTPClient_method_request_raw:
  583. .. rst-class:: classref-method
  584. :ref:`Error<enum_@GlobalScope_Error>` **request_raw** **(** :ref:`Method<enum_HTTPClient_Method>` method, :ref:`String<class_String>` url, :ref:`PackedStringArray<class_PackedStringArray>` headers, :ref:`PackedByteArray<class_PackedByteArray>` body **)**
  585. Sends a raw request to the connected host.
  586. The URL parameter is usually just the part after the host, so for ``https://somehost.com/index.php``, it is ``/index.php``. When sending requests to an HTTP proxy server, it should be an absolute URL. For :ref:`METHOD_OPTIONS<class_HTTPClient_constant_METHOD_OPTIONS>` requests, ``*`` is also allowed. For :ref:`METHOD_CONNECT<class_HTTPClient_constant_METHOD_CONNECT>` requests, it should be the authority component (``host:port``).
  587. Headers are HTTP request headers. For available HTTP methods, see :ref:`Method<enum_HTTPClient_Method>`.
  588. Sends the body data raw, as a byte array and does not encode it in any way.
  589. .. rst-class:: classref-item-separator
  590. ----
  591. .. _class_HTTPClient_method_set_http_proxy:
  592. .. rst-class:: classref-method
  593. void **set_http_proxy** **(** :ref:`String<class_String>` host, :ref:`int<class_int>` port **)**
  594. Sets the proxy server for HTTP requests.
  595. The proxy server is unset if ``host`` is empty or ``port`` is -1.
  596. .. rst-class:: classref-item-separator
  597. ----
  598. .. _class_HTTPClient_method_set_https_proxy:
  599. .. rst-class:: classref-method
  600. void **set_https_proxy** **(** :ref:`String<class_String>` host, :ref:`int<class_int>` port **)**
  601. Sets the proxy server for HTTPS requests.
  602. The proxy server is unset if ``host`` is empty or ``port`` is -1.
  603. .. |virtual| replace:: :abbr:`virtual (This method should typically be overridden by the user to have any effect.)`
  604. .. |const| replace:: :abbr:`const (This method has no side effects. It doesn't modify any of the instance's member variables.)`
  605. .. |vararg| replace:: :abbr:`vararg (This method accepts any number of arguments after the ones described here.)`
  606. .. |constructor| replace:: :abbr:`constructor (This method is used to construct a type.)`
  607. .. |static| replace:: :abbr:`static (This method doesn't need an instance to be called, so it can be called directly using the class name.)`
  608. .. |operator| replace:: :abbr:`operator (This method describes a valid operator to use with this type as left-hand operand.)`
  609. .. |bitfield| replace:: :abbr:`BitField (This value is an integer composed as a bitmask of the following flags.)`