Table of Contents
Integration into other systems
WebHMI allows you to interact with other systems by running HTTP requests. For this, WebHMI has a library Lua-cURLv3. Using it you can easily send data to third-party systems and also request the necessary data from these systems.
This function is available since version 2.6.4520.
POST example
An example of a program executing an HTTPS request to send data as a file at URL https://example.com/upload:
function main (userId) INFO("Doing CURL"); c = cURL.easy_init() c:setopt_url("https://example.com/upload") c:setopt_timeout(5) postdata = { name = { file="dummy.html", data="<html><bold>bold</bold></html>", type="text/html" } } c:post(postdata) c:perform() c:close() INFO("CURL done"); end
Note that for SSL certificates correctly function, you need to have an exact local time. If there is a significant deviation of the local clock, https requests may not work. We recommend using time synchronization via NTP server.
GET example
Example of requesting a number in the GET request at URL http://demo.example.com/read-data?param=32 and writing it to the register with id=4356:
function main (userId) c = cURL.easy_init() c:setopt_timeout(5) c:setopt_url("http://demo.example.com/read-data?param=32") local res = ""; c:perform({ writefunction = function(str) res = res .. str; end}) c:close() WriteReg(4356, res); end
Implementing other requests like PUT
To implement other requests, you can use special field in the cURL for the custom methods.
Here is the example of PUT request to WebHMI itself from its Lua.
function main (userId) local new_value = "new string" write_reg_with_API(1, new_value) end function write_reg_with_API(reg_id, val_) c = cURL.easy_init() c:setopt_url("http://127.0.1.1/api/register-values/" .. reg_id) -- local host addr indicated c:setopt_timeout(2) c:setopt{[cURL.OPT_CUSTOMREQUEST] = "PUT"} c:setopt{[cURL.OPT_POSTFIELDS] = '{"value":"' .. val_ .. '"}'} -- insert value here c:setopt_httpheader({ 'Content-type: application/json', 'Accept: application/json', 'X-WH-APIKEY: 976FA578CF3B11ADA06564464B1F01823AF81C3D' -- check APIKEY }) c:perform({writefunction = function(res) str = res end }) -- you can print str for debug purposes c:close() end
Example - connecting to a remote module via its web server
Most currently produced remote i/o modules have configuration and status web-page for diagnostic and setup. When you have a module which is not supported by the WebHMI and the usage of the custom protocol feature is complicated, there is another option of accessing the module through its embedded web-server with HTTP requests right from WebHMI.
For a example we have the UC20-FBC-xxx (any bus Modubs, Ethernet/IP, DeviceNet etc) remote I/O module from Weidmuller. The module has web server for diagnostinc and setup:
On this page you press F12 to get necesssary information for the POST request:
Then, use this information for POST request in Lua script on the WebHMI:
The function returns json object which you can then analize and check necessary fileds to read:
Notes on cURL usage
In the fw of 4.0 version, the following issue was reported: When there are multiple cURL requests from the WebHMI to the unavailable resource, a system crash may happen. The timeout settings won't affect the sysem behaviour. Use this feature with care when you need cyclical calls of multiple cURLs in your scripts:
- use one script which detect availablity of the resource and locks following execution for a while
- use external watchdog circuit to reset WebHMI if you use it to control mission - critical system.
If the curl stability is the issue in your project, you can implement HTTP requests using custom protocol. See the example
HTTP / HTTPS requests
Please note that HTTPS requests are only possible in WebHMI Pro version and virtualization images.
Troubleshooting CURL requests from WebHMI
When troubleshooting your requests, you can turn on verbose information in your script. Please refer to the example below:
function main (userId) local res = "" local c = cURL.easy_init() c : setopt{ url = 'http://danepubliczne.imgw.pl/api/data/hydro/id/153160210', timeout = 30, httpheader = {'Accept: application/json', 'Content-Type: gzip, deflate, br', -- 'Host: <calculated when request is sent>', } } -- sw on verbose info c : setopt{[cURL.OPT_VERBOSE] = 1} c : setopt{[cURL.OPT_DEBUGFUNCTION] = function(...) for i, v in pairs(arg) do DEBUG(i .. ' ' .. v) end return 0 end } c : perform{writefunction = function(str) res = res .. str end} c : close() INFO(res) if (res == '') or (res == '%[%]')then ERROR('No data in response!') else INFO('\n' .. res) end end