Difference between revisions of "HTTP (API)"

From ComputerCraft Wiki
Jump to: navigation, search
m (fixed formatting)
 
(2 intermediate revisions by 2 users not shown)
Line 5: Line 5:
 
The HTTP API allows interfacing with websites and downloading from them.
 
The HTTP API allows interfacing with websites and downloading from them.
  
<table style="width: 100%; border: solid 1px black; margin: 2px; border-spacing: 0px;">
+
{{API table|HTTP|image=Grid disk.png|2=
<tr><td colspan="3" style="font-weight: bold; font-size: large; padding-bottom: .3em; border-bottom: solid #C9C9C9 1px; background: #D3FFC2; line-height:28px;">
+
[[File:Grid_disk.png|24px]]&nbsp;&nbsp;
+
HTTP (API)
+
</td></tr>
+
  
<tr><td style="width: 100px; background: #E0E0E0; padding: .4em; font-weight:bold;">Return</td><td style="width: 350px; background: #E0E0E0; padding: .4em; font-weight:bold;">Method Name</td><td style="background: #E0E0E0; padding: .4em; font-weight:bold;">Description</td></tr>
+
{{API table/row
 +
|[[http.request]]({{type|string}} url [, {{type|string}} postData [, {{type|table}} headers]])
 +
|{{type|nil}}
 +
|Sends a HTTP request to a website, asynchronously.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[nil]]</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[http.request]]({{type|string}} url [, {{type|string}} postData [, {{type|table}} headers]])</td>
+
|[[http.get]]({{type|string}} url [, {{type|table}} headers])
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Sends a HTTP request to a website, asynchronously.</td></tr>
+
|{{type|table}} handle
 +
|Sends a HTTP GET request to a website, synchronously.
 +
|}}
  
<tr style="background-color: #E8E8E8;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{type|table}} handle</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[http.get]]({{type|string}} url [, {{type|table}} headers])</td>
+
|[[http.post]]({{type|string}} url, {{type|string}} postData [, {{type|table}} headers])
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Sends a HTTP GET request to a website, synchronously.</td></tr>
+
|{{type|table}} handle
 +
|Sends a HTTP POST request to a website, synchronously.
 +
|odd}}
  
<tr style="background-color: #FFFFFF;"><td style="border-top: solid #C9C9C9 1px; padding: .4em;">{{type|table}} handle</td>
+
{{API table/row
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">[[http.post]]({{type|string}} url, {{type|string}} postData [, {{type|table}} headers])</td>
+
|[[http.checkURL]]({{type|string}} url)
<td style="border-top: solid #C9C9C9 1px; padding: .4em;">Sends a HTTP POST request to a website, synchronously.</td></tr>
+
|{{type|boolean}} success [<nowiki />, {{type|string}} error]
</table>
+
|Checks if a URL is valid and is included in the HTTP whitelist.
 +
|}}
 +
 
 +
}}
  
 
[[http.request]] is used to send a HTTP request that completes asynchronously and generates an event (one of [[Http success (event)|http_success]] or [[Http failure (event)|http_failure]]). [[http.get]] and [[http.post]] execute [[http.request]] and block until the operation completes.
 
[[http.request]] is used to send a HTTP request that completes asynchronously and generates an event (one of [[Http success (event)|http_success]] or [[Http failure (event)|http_failure]]). [[http.get]] and [[http.post]] execute [[http.request]] and block until the operation completes.
Line 42: Line 49:
 
{{Example
 
{{Example
 
|desc=Sends a request to http://example.com/ with the custom headers.
 
|desc=Sends a request to http://example.com/ with the custom headers.
|code=<nowiki>local headers = {
+
|code=local headers = {
  ["User-Agent"] = "A custom user-agent!", -- Overrides the default User-Agent.
+
  [ "User-Agent" ] = "A custom user-agent!", ''-- Overrides the default User-Agent.''
  ["Hi"] = "Hello" -- A non-standard custom header field.
+
  [ "Hi" ] = "Hello" ''-- A non-standard custom header field.''
}
+
}
http.get("http://example.com/", headers)</nowiki>
+
 +
[[http.get]]( "http:<nowiki/>//example.com/", headers )
 
}}
 
}}
=== Caution ===
 
You '''must''' either pass a ''string'' or ''nil'' as the second argument of http.request(). It will silently fail if you try to pass a header table as the second argument.
 
<pre>
 
http.request("http://example.com/", headers) -- This will produce a normal GET request.
 
http.request("http://example.com/", nil, headers) -- This will produce a GET request with your custom headers.
 
</pre>
 
  
 
[[Category:APIs]]
 
[[Category:APIs]]

Latest revision as of 20:35, 1 August 2015

The HTTP API must be enabled in ComputerCraft.cfg before being used. To enable it see this tutorial.

The HTTP API allows interfacing with websites and downloading from them.

Grid disk.png  HTTP (API)
Function Return values Description
http.request(string url [, string postData [, table headers]]) nil Sends a HTTP request to a website, asynchronously.
http.get(string url [, table headers]) table handle Sends a HTTP GET request to a website, synchronously.
http.post(string url, string postData [, table headers]) table handle Sends a HTTP POST request to a website, synchronously.
http.checkURL(string url) boolean success [, string error] Checks if a URL is valid and is included in the HTTP whitelist.

http.request is used to send a HTTP request that completes asynchronously and generates an event (one of http_success or http_failure). http.get and http.post execute http.request and block until the operation completes.

Handles

All three operations make use of handles, tables that contain functions to read data returned from the HTTP server. These handles act the same as the I/O handles returned by fs.open in read-only text mode, implementing the close, readLine, and readAll methods. These handles also implement the following function:


Grid Redstone.png  Function h.getResponseCode
Returns the numerical HTTP response code sent by the server
Syntax h.getResponseCode()
Returns number HTTP response code
Part of ComputerCraft
API HTTP


Headers

As of ComputerCraft 1.63, you can optionally set custom headers. This also means that you can override default headers such as the User-Agent.

Grid paper.png  Example
Sends a request to http://example.com/ with the custom headers.
Code
local headers = {
  [ "User-Agent" ] = "A custom user-agent!", -- Overrides the default User-Agent.
  [ "Hi" ] = "Hello" -- A non-standard custom header field.
}

http.get( "http://example.com/", headers )