Skip to content

http.get

Matthew Versluys edited this page May 17, 2016 · 17 revisions

Gets an HTTP resource from the specified URL as a string.

http.get(url, { options })

Parameters

url is the URL to be downloaded.

options is a table of options used for this http retrieval

  • progress is a Lua callback function that receives two numeric arguments representing total and current download progress in bytes.
  • headers is a Lua table with HTTP headers to be used on the request.
  • userpwd is a username and optional password in the format of username:password which will be used to authenticate the request
  • username is the username which will be used to authenticate the request
  • password is the password which will be used to authenticate the request

Backward compatible function signature

The previous signature of this function was

http.get(url, progress, headers)

and continues to be supported. This is equivalent to

http.get(url, { progress = progress, headers = headers })

Return Value

Resource as a string if successful, otherwise nil and an error message.

Examples

local result = http.get("http://example.com/api.json")
function progress(total, current)
  local ratio = current / total;
  ratio = math.min(math.max(ratio, 0), 1);
  local percent = math.floor(ratio * 100);
  print("Download progress (" .. percent .. "%/100%)")
end

local result = http.get("http://example.com/api.json", {
    progress = progress,
    headers = { "From: Premake", "Referer: Premake" }, 
    userpwd = "username:password"
})

Availability

Premake 5.0 or later.

See Also

Clone this wiki locally