Skip to main content

HTTP

HTTP Requests Interface.

🗿Static Class
This is a Static Class. Access it's methods directly with .. It's not possible to spawn new instances.
💂Authority
This static class can be accessed only on 🟦 Server side.

Examples​

Server/Index.lua
-- Makes an asynchronous HTTP Request
HTTP.RequestAsync("127.0.0.1:7777", "/", "GET", "", "application/json", false, {}, function(status, data)
Console.Log(status) -- 200
Console.Log(data) -- "{"players_count":0,"server_name":"HELIX server"}"

-- TIP: You can parse it if it's a json return as well
local json_ret = JSON.parse(data)
end)
Server/Index.lua
-- Makes a synchronous HTTP Request
local ret = HTTP.Request("127.0.0.1:7777", "/", "GET", "", "application/json", false, {})

Console.Log(ret.Status) -- 200
Console.Log(ret.Data) -- "{"players_count":0,"server_name":"HELIX server"}"
tip

All requests are thread safe! 🥳 This means that callbacks are returned on the main thread!

Static Functions​

ReturnsNameDescription
RequestAsyncMakes an asynchronous HTTP Request
tableRequestMakes a synchronous HTTP Request.

The request will be made synchronously and will freeze the server until it's done.
SetConnectionTimeoutSets the global Connection Timeout in seconds
SetReadWriteTimeoutSets the global Read and Write Timeout in seconds

RequestAsync​

Makes an asynchronous HTTP Request.

The request will be made asynchronously and returned safetly in the same thread in the callback provided when it's done.

Note: If a request is still running when unloading packages, the server will freeze until it's finished, then the package will unload.

HTTP.RequestAsync(uri, endpoint?, method?, data?, content_type?, compress?, headers?, callback?)
TypeParameterDefaultDescription
stringuriThe main URI
stringendpoint?/The endpoint
stringmethod?GETThe HTTP Method to be used
stringdata?Payload
stringcontent_type?application/jsonThe Content Type to be used
booleancompress?falseWhether or not to compress the content with gzip
tableheaders?{}The Headers to be used
functioncallback?nilThe result will be called in the format `function(status, data)`

Request​

Makes a synchronous HTTP Request.

The request will be made synchronously and will freeze the server until it's done.

— Returns table (with this format).

local ret = HTTP.Request(uri, endpoint?, method?, data?, content_type?, compress?, headers?)
TypeParameterDefaultDescription
stringuriThe main URI
stringendpoint?/The endpoint
stringmethod?GETThe HTTP Method to be used
stringdata?Payload
stringcontent_type?application/jsonThe Content Type to be used
booleancompress?falseWhether or not to compress the content with gzip
tableheaders?{}The Headers to be used

SetConnectionTimeout​

Sets the global Connection Timeout in seconds

HTTP.SetConnectionTimeout(connection_timeout)
TypeParameterDefaultDescription
integerconnection_timeoutThe timeout in seconds

SetReadWriteTimeout​

Sets the global Read and Write Timeout in seconds

HTTP.SetReadWriteTimeout(read_write_timeout)
TypeParameterDefaultDescription
integerread_write_timeoutThe timeout in seconds

Events​

This entity doesn't have own events.