Changes for page 2 Script
Last modified by Devin Chen on 2025/06/06 14:03
Summary
-
Page properties (2 modified, 0 added, 0 removed)
-
Attachments (0 modified, 0 added, 1 removed)
Details
- Page properties
-
- Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. Hunter1 +XWiki.Stone - Content
-
... ... @@ -70,12 +70,6 @@ 70 70 71 71 This example shows how to use the Bot API to send message into Telegram group or channel. When monitoring bit "@HDX" changes, it will trigger and send the message. Please replace with your own Token and chat id. 72 72 73 -As for How to get the botToken and chatID, please check the followig videos: 74 - 75 -[[https:~~/~~/www.youtube.com/watch?v=zh6yYlnjX7k>>https://www.youtube.com/watch?v=zh6yYlnjX7k]] 76 - 77 -[[https:~~/~~/www.youtube.com/watch?v=Pj8mwuMZZvg>>https://www.youtube.com/watch?v=Pj8mwuMZZvg]] 78 - 79 79 {{code language="Lua"}} 80 80 local tempBit = 0 81 81 local tempWord = 0 ... ... @@ -141,343 +141,7 @@ 141 141 end 142 142 {{/code}} 143 143 144 -== **1.6 LINE Notify** == 145 145 146 -This example shows how to use the LINE Notify to send message into LINE group. When monitoring bit "@test" changes, it will trigger and send the message. Please replace with your own Token. 147 - 148 -{{code}} 149 -local tempBit = 0 150 -local tempWord = 0 151 - 152 -local LineToken = "08XCpubkOdwGdGgRTXF0x8umiyrALtoM0v6lBFUV6PC" 153 - 154 -local https = require("https") 155 -local json = require("json") 156 -local ltn12 = require("ltn12") 157 - 158 --- Send http.get request and return response result 159 -function getHttpsUrl(url,header,reqbody) 160 - local body = {} 161 - local bodyJson = json.encode(body) 162 - local result_table, code, headers, status = https.request{ 163 - method = "POST", 164 - url = url, 165 - source = ltn12.source.string(reqbody), 166 - headers = header, 167 - sink = ltn12.sink.table(body) 168 - } 169 - print("code:"..code) 170 - if code~= 200 then 171 - return 172 - else 173 - return body 174 - end 175 -end 176 - 177 -function getMessageUrl(lineMessage) 178 - local url = "https://notify-api.line.me/api/notify" 179 - local reqMess = "message="..lineMessage 180 - local headers = 181 - { 182 - ["Authorization"] = "Bearer "..LineToken, 183 - ["Content-Type"] = "application/x-www-form-urlencoded", 184 - ["Content-Length"] = #reqMess 185 - } 186 - 187 - print("Get the link:"..url) 188 - getHttpsUrl(url, headers, reqMess) 189 -end 190 - 191 - 192 -function linenotify.main() 193 - local bitValue = addr_getbit("@test"); 194 - local message = '' 195 - print("b=="..bitValue) 196 - if bitValue == 1 and bitValue ~= tempBit then 197 - message = 'Alarm V-Box triggered, the output is '.. bitValue 198 - getMessageUrl(message) 199 - print("Notification pushed of triggering alarm,"..bitValue) 200 - elseif bitValue == 0 and bitValue ~= tempBit then 201 - message = 'Alarm V-Box dismissed, the output is '.. bitValue 202 - getMessageUrl(message) 203 - print("Notification pushed of dismissing alarm,"..bitValue) 204 - end 205 - tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform 206 - 207 - local wordValue = addr_getword("@t2") 208 - print("w=="..wordValue) 209 - --dosomething 210 - if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then 211 - message = 'Alarm V-Box triggered, the temperature is '.. wordValue 212 - getMessageUrl(message) 213 - print("Notification pushed of triggering alarm,"..wordValue) 214 - elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then 215 - message = 'Alarm V-Box dismissed, the temperature is '.. wordValue 216 - getMessageUrl(message) 217 - print("Notification pushed of dismissing alarm,"..wordValue) 218 - end 219 - tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform 220 -end 221 -{{/code}} 222 - 223 -== **1.7 Twilio WhatsApp Messaging** == 224 - 225 -This example shows how to use the Twilio API to send WhatsApp message to private number. When monitoring bit "@testBit" changes, it will trigger and send the message. Please replace with your own SID, Token, twilioPhoneNumber and receiverPhoneNumber. 226 - 227 -About how to register the Twilio API, please check the following video: 228 - 229 -[[https:~~/~~/www.youtube.com/watch?v=Id4lKichauU>>https://www.youtube.com/watch?v=Id4lKichauU]] 230 - 231 -{{code language="Lua"}} 232 -local tempBit = 0 233 -local tempWord = 0 234 - 235 -local https = require("https") 236 -local json = require("json") 237 -local ltn12 = require("ltn12") 238 - 239 -local SID = 'AC1703bd710ffa98006d2bcc0b********' 240 -local Token = 'd3c11897623c39e538b20263ec19****' 241 - 242 -local twilioPhoneNumber = '+14155238886' 243 -local receiverPhoneNumber = '+8615880018277' 244 - 245 -local b='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' 246 -function encodingBase64(data) 247 - return ((data:gsub('.', function(x) 248 - local r,b='',x:byte() 249 - for i=8,1,-1 do r=r..(b%2^i-b%2^(i-1)>0 and '1' or '0') end 250 - return r; 251 - end)..'0000'):gsub('%d%d%d?%d?%d?%d?', function(x) 252 - if (#x < 6) then return '' end 253 - local c=0 254 - for i=1,6 do c=c+(x:sub(i,i)=='1' and 2^(6-i) or 0) end 255 - return b:sub(c+1,c+1) 256 - end)..({ '', '==', '=' })[#data%3+1]) 257 -end 258 - 259 -function encodeUrl(str) 260 - str = string.gsub(str, "([^%w%.%- ])", function(c) 261 - return string.format("%%%02X", string.byte(c)) end) 262 - return string.gsub(str, " ", "+") 263 -end 264 - 265 - 266 - 267 - 268 -function requestBodySplice(message, sender, receiver) 269 - local reqBody = '' 270 - local encodeMess = encodeUrl(message) 271 - local encodeSend = encodeUrl(sender) 272 - local encodeRece = encodeUrl(receiver) 273 - --reqBody = "Body=Hello%20Wecon2&From=whatsapp%3A%2B14155238886&To=whatsapp%3A%2B8615880018277" 274 - reqBody = string.format("Body=%s&From=whatsapp:%s&To=whatsapp:%s", encodeMess, encodeSend, encodeRece) 275 - print(reqBody) 276 - return reqBody 277 -end 278 - 279 - 280 --- Send http.get request and return response result 281 -function getHttpsUrl(url,header,reqbody) 282 - local body = {} 283 - local bodyJson = json.encode(body) 284 - local result_table, code, headers, status = https.request{ 285 - method = "POST", 286 - url = url, 287 - source = ltn12.source.string(reqbody), 288 - headers = header, 289 - sink = ltn12.sink.table(body) 290 - } 291 - print("code:"..code) 292 - if code~= 200 then 293 - return 294 - else 295 - return body 296 - end 297 -end 298 - 299 -function getMessageUrl(whatsAppMessage) 300 - local auth = SID..':'..Token 301 - local url = "https://api.twilio.com/2010-04-01/Accounts/"..SID.."/Messages" 302 - --local reqMess = "message="..twilioMessage 303 - local reqMess = requestBodySplice(whatsAppMessage, twilioPhoneNumber, receiverPhoneNumber) 304 - local headers = 305 - { 306 - ["Authorization"] = "Basic "..encodingBase64(auth), 307 - ["Content-Type"] = "application/x-www-form-urlencoded", 308 - ["Content-Length"] = #reqMess 309 - } 310 - 311 - print("Get the link:"..url) 312 - getHttpsUrl(url, headers, reqMess) 313 -end 314 - 315 - 316 - 317 -function Twilio.main() 318 - --dosomething 319 - --local auth = SID..':'..Token 320 - --print(requestBodySplice("HelloWorld", twilioPhoneNumber, receiverPhoneNumber)) 321 - --print(encodingBase64(auth)) 322 - local bitValue = addr_getbit("@testBit"); 323 - local message = '' 324 - print("b=="..bitValue) 325 - if bitValue == 1 and bitValue ~= tempBit then 326 - message = 'Alarm V-Box triggered, the output is '.. bitValue 327 - getMessageUrl(message) 328 - print("Notification pushed of triggering alarm,"..bitValue) 329 - elseif bitValue == 0 and bitValue ~= tempBit then 330 - message = 'Alarm V-Box dismissed, the output is '.. bitValue 331 - getMessageUrl(message) 332 - print("Notification pushed of dismissing alarm,"..bitValue) 333 - end 334 - tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform 335 - 336 - local wordValue = addr_getword("@testWord") 337 - print("w=="..wordValue) 338 - --dosomething 339 - if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then 340 - message = 'Alarm V-Box triggered, the temperature is '.. wordValue 341 - getMessageUrl(message) 342 - print("Notification pushed of triggering alarm,"..wordValue) 343 - elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then 344 - message = 'Alarm V-Box dismissed, the temperature is '.. wordValue 345 - getMessageUrl(message) 346 - print("Notification pushed of dismissing alarm,"..wordValue) 347 - end 348 - tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform 349 -end 350 -{{/code}} 351 - 352 -== **1.8 How to parse value from HTTP response body** == 353 - 354 -This example use [[https:~~/~~/www.weatherapi.com/>>https://www.weatherapi.com/]] as example, to show how to parse value from HTTP response body. When we input the city name into address "@HDW5050": 355 - 356 -(% style="text-align:center" %) 357 -[[image:InputHTTPparameter.png]] 358 - 359 -Then the response body would be like as following: 360 - 361 -{{code language="json"}} 362 -{ 363 - "location": { 364 - "name": "Madrid", 365 - "region": "Madrid", 366 - "country": "Spain", 367 - "lat": 40.4, 368 - "lon": -3.68, 369 - "tz_id": "Europe/Madrid", 370 - "localtime_epoch": 1669022636, 371 - "localtime": "2022-11-21 10:23" 372 - }, 373 - "current": { 374 - "last_updated_epoch": 1669022100, 375 - "last_updated": "2022-11-21 10:15", 376 - "temp_c": 13.0, 377 - "temp_f": 55.4, 378 - "is_day": 1, 379 - "condition": { 380 - "text": "Partly cloudy", 381 - "icon": "//cdn.weatherapi.com/weather/64x64/day/116.png", 382 - "code": 1003 383 - }, 384 - "wind_mph": 11.9, 385 - "wind_kph": 19.1, 386 - "wind_degree": 210, 387 - "wind_dir": "SSW", 388 - "pressure_mb": 1015.0, 389 - "pressure_in": 29.97, 390 - "precip_mm": 0.0, 391 - "precip_in": 0.0, 392 - "humidity": 88, 393 - "cloud": 75, 394 - "feelslike_c": 10.8, 395 - "feelslike_f": 51.4, 396 - "vis_km": 10.0, 397 - "vis_miles": 6.0, 398 - "uv": 3.0, 399 - "gust_mph": 22.1, 400 - "gust_kph": 35.6 401 - } 402 -} 403 -{{/code}} 404 - 405 -(% class="wikigeneratedid" %) 406 -So we decode json into lua object to assign the value into addresses HDW6060(temperature), HDW7070(humidity), the code example like follows: 407 - 408 -{{code language="lua"}} 409 -local APIkey = '70faaecf926b4341b1974006221711' 410 - 411 - 412 -local http = require("socket.http") 413 -local json = require("json") 414 - 415 --- Send http.get request and return response result 416 -function getHttpsUrl(url) 417 - local result_table, code, headers, status = http.request(url) 418 - print("code:"..code) 419 - if code~= 200 then 420 - return 421 - else 422 - return result_table 423 - end 424 -end 425 - 426 -function sendAPI(key, city) 427 - local url = "http://api.weatherapi.com/v1/current.json?key="..key.."&q="..city.."&aqi=no" 428 - --local url = 'http://v-box.net' 429 - --local url = 'https://www.google.com/' 430 - --http://api.weatherapi.com/v1/current.json?key=70faaecf926b4341b1974006221711&q=Barcelona&aqi=no 431 - print("Get the link:"..url) 432 - local body = getHttpsUrl(url) 433 - --print(body) 434 - local jsonBody = json.decode(body) 435 - --print(jsonBody["current"]["temp_c"]) 436 - --print(type(jsonBody["current"]["temp_c"])) 437 - --print(type(jsonBody["current"]["humidity"])) 438 - addr_setfloat("@HDW6060", jsonBody["current"]["temp_c"]) 439 - addr_setword("@HDW7070", jsonBody["current"]["humidity"]) 440 -end 441 - 442 - 443 -function Weather.main() 444 - local cityName = addr_getstring("@HDW5050",6) 445 - print("cityName: "..cityName) 446 - sendAPI(APIkey, cityName) 447 -end 448 -{{/code}} 449 - 450 -== **1.9 High-Low Byte Switch** == 451 - 452 -The following example is converting the floating number from order 1234 to order 3412, and formating output the number with 2 decimal point. About which high-low word order corresponding to which value, please refer to the [[Address Operation Table>>doc:V-BOX.V-Net.Manual.04 Lua Script.01 Lua Functions.WebHome||anchor="H2Addressoperation"]]. 453 - 454 -{{code language="lua"}} 455 -function highLowByteSwitch(floatNumber) 456 - addr_setfloat("@W_0#HDW23036",floatNumber,0,2) 457 - local newFloat = addr_getfloat("@W_0#HDW23036") 458 - local formattedFloat = string.format("%.2f",newFloat) 459 - print("The formatted float value is the : "..formattedFloat) 460 - return formattedFloat 461 -end 462 -{{/code}} 463 - 464 -== **1.10 Read 64bits Unsigned Value** == 465 - 466 -In our built-in function library doesn't have the function for reading 64-bit unsigned format value, so the following function is for solve this. But if the number is greater 2^53, the precision will be lost. So the final result will be a little bit different from the original value. 467 - 468 -{{code language="lua"}} 469 -function addr_getquatra(address) 470 - local highAddress = addr_newnoaddr(address,2) 471 - local low32 = addr_getdword(address) 472 - local high32 = addr_getdword(highAddress) 473 - --print("the low number is "..low32) 474 - --print("the high number is "..high32) 475 - local formatVal = string.format("%64.0f",2^32*high32+low32) 476 - print("the format value is ".. formatVal) 477 - return formatVal 478 -end 479 -{{/code}} 480 - 481 481 = **2 V-Box connect with third part server** = 482 482 483 483 V-Box have two mode.One is for V-Net,User need to use WECON server to store data.We call this V-NET platform. ... ... @@ -496,9 +496,8 @@ 496 496 497 497 (% class="mark" %)2.If your server requires SSL certificate to log in,please use OpenCloud.Because only OpenCloud platform can support to upload certificate 498 498 499 - {{info}}157 +(% class="wikigeneratedid" %) 500 500 **✎Note: **Before program the script of MQTT, please make sure the server(MQTT broker) can be connected through MQTT Client tool. 501 -{{/info}} 502 502 503 503 (% class="wikigeneratedid" %) 504 504 Tool link: **[[MQTT.fx>>http://mqttfx.jensd.de/index.php/download]]** ... ... @@ -505,25 +505,6 @@ 505 505 506 506 == **2.1 V-Box connect with test server(General Example)** == 507 507 508 -The following example is trying to publish to the topic "testtopic/test/no1/7890", and subscribe the topic "testtopic/test/no1/123456". 509 - 510 -And the JSON message is like follows: 511 - 512 -{{code language="JSON"}} 513 -{ 514 - "timestamp": 1631152760, 515 - "messageId": 1, 516 - "event": "test_data", 517 - "mfrs": "HMI/box", 518 - "data": 519 - { 520 - "id" : 1436217747670454274, 521 - "waterlevel" : 48, 522 - "temperture" : 23 523 - } 524 -} 525 -{{/code}} 526 - 527 527 {{code language="lua"}} 528 528 --MQTT configuration table 529 529 local MQTT_CFG={} ... ... @@ -565,13 +565,9 @@ 565 565 --initialize mqtt 566 566 function mqtt_init() 567 567 print(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENT_ID)) 568 - if g_mq then 569 - mqtt.close() --Close mqtt object 570 - end 571 571 g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENT_ID) -- create mqtt object,and declare it as a global variable 572 572 if g_mq then 573 573 g_mq:on("message", mqtt_msg_callback) -- Register a callback for receiving messages 574 - g_mq:on("offline", mqtt_msg_offline) -- Register a callback for offline 575 575 print("mqtt init success") 576 576 else 577 577 print("mqtt init failed:", err) ... ... @@ -591,11 +591,6 @@ 591 591 g_mq:subscribe(SUBSCRIBE_TOPIC, 0) 592 592 end 593 593 594 ---Offline callback function 595 -function mqtt_msg_offline(cause) 596 - print("mqtt offline, cause:", cause) 597 -end 598 - 599 599 -- Received message callback function 600 600 function mqtt_msg_callback(topic, msg) 601 601 print("topic:", topic) ... ... @@ -634,11 +634,9 @@ 634 634 if g_mq:isconnected() then 635 635 send_data() 636 636 else 637 - --if exceed 5sec not connect, reconnect once638 - if os.time() - LAST_TIME > 5then266 + --if exceed 20 sec not connect, reconnect once 267 + if os.time() - LAST_TIME > 20 then 639 639 LAST_TIME = os.time() 640 - --reinitial the mqtt object 641 - mqtt_init() 642 642 --connect to mqtt or reconnect 643 643 mqtt_connect() 644 644 end ... ... @@ -661,134 +661,142 @@ 661 661 -- Meta class 662 662 --main 663 663 function mq.main() 664 - 665 - 291 + if not mq.m then 292 + local err = "" 666 666 667 - mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 668 - if mq.m then 669 - mq.config = { 670 - username = "",-- ID 671 - password = "",-- password 672 - netway = 1, -- Ethernet connection, WIFI=1 673 - -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 674 - -- cleansession = 0, -- Optional, keep session 675 - } 676 - mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 677 - local str = string.format("%s:%s", topic, msg) 678 - -- print("mqtt msg:", str) -- Print out the received topics and content 679 - end) 680 - mq.m:on("offline", function (cause) -- Register for lost connection callbacks 681 - -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 682 - end) 683 - mq.m:on("arrived", function() -- Registration for sending messages to callbacks 684 - print("msg arrived") 685 - end) 686 - else 687 - print("mqtt create failed:", err) -- Create object failed 688 - end 689 - else 690 - if mq.m:isconnected() then -- If online, post a message 691 - local phaseStatus ="unknow" 692 - if addr_getbit("@Standby")== 1 then 693 - phaseStatus = "Standby" 694 - elseif addr_getbit("@Pre-Freeze")==1 then 695 - phaseStatus= "Pre-Freeze" 696 - elseif addr_getbit("@Prepare")==1 then 697 - phaseStatus ="Prepare" 698 - elseif addr_getbit("@Primary Dry")==1 then 699 - phaseStatus = "Primary dry" 700 - elseif addr_getbit("@Secondary Dry")==1 then 701 - phaseStatus = "Secondary Dry" 702 - end 703 - --print(addr_getbit("@Primary Dry")) 294 + mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 295 + if mq.m then 296 + mq.config = { 297 + username = "",-- ID 298 + password = "",-- password 299 + netway = 1, -- Ethernet connection, WIFI=1 300 + -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 301 + -- cleansession = 0, -- Optional, keep session 302 + } 303 + mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 304 + local str = string.format("%s:%s", topic, msg) 305 + -- print("mqtt msg:", str) -- Print out the received topics and content 306 + end 307 + ) 308 + mq.m:on("offline", function (cause) -- Register for lost connection callbacks 309 + -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 310 + end) 311 + mq.m:on("arrived", function() -- Registration for sending messages to callbacks 312 + print("msg arrived") 313 + end) 314 + else 315 + print("mqtt create failed:", err) -- Create object failed 316 + end 317 + else 318 + if mq.m:isconnected() then -- If online, post a message 319 + local phaseStatus ="unknow" 320 + if addr_getbit("@Standby")== 1 then 321 + phaseStatus = "Standby" 322 + elseif addr_getbit("@Pre-Freeze")==1 then 323 + phaseStatus= "Pre-Freeze" 324 + elseif addr_getbit("@Prepare")==1 then 325 + phaseStatus ="Prepare" 326 + elseif addr_getbit("@Primary Dry")==1 then 327 + phaseStatus = "Primary dry" 328 + elseif addr_getbit("@Secondary Dry")==1 then 329 + phaseStatus = "Secondary Dry" 330 + end 331 +-- print(addr_getbit("@Primary Dry")) 704 704 ------------------------------------------------------------------------------------------------------------------------- 705 - local activating ="unknow" 706 - if addr_getbit("@Compressor")==1 then 707 - activating = ",".."Compressor" 708 - end 709 - if addr_getbit("@Silicone Pump")==1 then 710 - activating = activating..",".."Silicone Pump" 711 - end 712 - if addr_getbit("@Vacuum Pump")==1 then 713 - activating = activating..",".."Vacuum Pump" 714 - end 715 - if addr_getbit("@Root Pump")==1 then 716 - activating = activating..",".."Root Pump" 717 - end 718 - if addr_getbit("@Heater")==1 then 719 - activating = activating..",".."Heater" 720 - end 721 - if addr_getbit("@Valve Silicone")==1 then 722 - activating = activating..",".."Valve Silicone" 723 - end 724 - if addr_getbit("@Valve Ice Condenser")==1 then 725 - activating = activating..",".."Valve Ice Condenser" 726 - end 727 - if addr_getbit("@Valve Vacuum Pump")==1 then 728 - activating = activating..",".."Valve Vacuum Pump" 729 - end 730 - local pr_activating =string.sub(activating,2) 731 - -- print(pr_activating) 732 - local status_text ="unknow" 733 - if addr_getbit("@Status Run")==1 then 734 - status_text = "RUNNING" 735 - else 736 - status_text = "STOP" 737 - end 738 -------------------------------------------------------------------------------------------------------------------------- 739 - local js = {type="status", 740 - mc_name ="FD300", 741 - status=status_text, 742 - elapsed_time={ 743 - hour=addr_getword("@Elapsed Time (Hour)"), 744 - min=addr_getword("@Elapsed Time (Minute)"), 745 - sec=addr_getword("@Elapsed Time (Second)") 746 - }, 747 - phase = phaseStatus, 748 - step = addr_getword("@Step"), 749 - activating_output = pr_activating, 750 - sv=addr_getshort("@SV Silicone")/10, 751 - pv=addr_getshort("@PV Silicone")/10, 752 - product1=addr_getshort("@Product 1")/10, 333 + local activating ="unknow" 334 + if addr_getbit("@Compressor")==1 then 335 + activating = ",".."Compressor" 336 + end 337 + if addr_getbit("@Silicone Pump")==1 then 338 + activating = activating..",".."Silicone Pump" 339 + end 340 + if addr_getbit("@Vacuum Pump")==1 then 341 + activating = activating..",".."Vacuum Pump" 342 + end 343 + if addr_getbit("@Root Pump")==1 then 344 + activating = activating..",".."Root Pump" 345 + end 346 + if addr_getbit("@Heater")==1 then 347 + activating = activating..",".."Heater" 348 + end 349 + if addr_getbit("@Valve Silicone")==1 then 350 + activating = activating..",".."Valve Silicone" 351 + end 352 + if addr_getbit("@Valve Ice Condenser")==1 then 353 + activating = activating..",".."Valve Ice Condenser" 354 + end 355 + if addr_getbit("@Valve Vacuum Pump")==1 then 356 + activating = activating..",".."Valve Vacuum Pump" 357 + end 358 + local pr_activating =string.sub(activating,2) 359 + -- print(pr_activating) 753 753 754 - product2=addr_getshort("@Product 2")/10, 755 - product3=addr_getshort("@Product 3")/10, 756 - product4=addr_getshort("@Product 4")/10, 757 - ice1=addr_getshort("@Ice condenser 1")/10, 758 - ice2=addr_getshort("@Ice condenser 2")/10, 759 - vacuum=addr_getfloat("@Vacuum") 760 - } 761 - local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 762 - ODPC = addr_getbit("@B_25395#W0.01"), 763 - MTPC=addr_getbit("@B_25395#W0.02"), 764 - HTT = addr_getbit("@B_25395#W1.03"), 765 - CPC = addr_getbit("@B_25395#W0.08"), 766 - CPSP =addr_getbit("@B_25395#W1.00"), 767 - CPVP =addr_getbit("@B_25395#W0.10"), 768 - CPRP =addr_getbit("@B_25395#W0.11"), 769 - HP =addr_getbit("@B_25395#W1.01"), 770 - PP= addr_getbit("@B_25395#W1.02"), 771 - PO=addr_getbit("@B_25395#W0.07"), 772 - FSE=addr_getbit("@B_25395#W2.04"), 773 - AVVSVV=addr_getbit("@B_25395#W1.12"), 774 - ICHT=addr_getbit("@B_25395#W3.06") 775 - } 776 - -- ("@B_25395#CIO1.02") 777 - mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 778 - mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 779 - else 780 - local stat, err = mq.m:connect(mq.config) -- connection 781 - if stat == nil then --Determine whether to connect 782 - print("mqtt connect failed:", err) 783 - return -- Connection failed, return directly 784 - end 785 - mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 786 786 787 - end 788 - -- mq.m:unsubscribe("stc/test") 789 - -- mq.m:disconnect() -- close matt 790 - -- mq.m:close() -- close clase 791 - end 362 + 363 + local status_text ="unknow" 364 + if addr_getbit("@Status Run")==1 then 365 + status_text = "RUNNING" 366 + else 367 + status_text = "STOP" 368 + end 369 +------------------------------------------------------------------------------------------------------------------------- 370 + 371 + local js = {type="status", 372 + mc_name ="FD300", 373 + status=status_text, 374 + elapsed_time={ 375 + hour=addr_getword("@Elapsed Time (Hour)"), 376 + min=addr_getword("@Elapsed Time (Minute)"), 377 + sec=addr_getword("@Elapsed Time (Second)") 378 + }, 379 + phase = phaseStatus, 380 + step = addr_getword("@Step"), 381 + activating_output = pr_activating, 382 + sv=addr_getshort("@SV Silicone")/10, 383 + pv=addr_getshort("@PV Silicone")/10, 384 + product1=addr_getshort("@Product 1")/10, 385 + 386 + product2=addr_getshort("@Product 2")/10, 387 + product3=addr_getshort("@Product 3")/10, 388 + product4=addr_getshort("@Product 4")/10, 389 + ice1=addr_getshort("@Ice condenser 1")/10, 390 + ice2=addr_getshort("@Ice condenser 2")/10, 391 + vacuum=addr_getfloat("@Vacuum") 392 + 393 + } 394 + local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 395 + ODPC = addr_getbit("@B_25395#W0.01"), 396 + MTPC=addr_getbit("@B_25395#W0.02"), 397 + HTT = addr_getbit("@B_25395#W1.03"), 398 + CPC = addr_getbit("@B_25395#W0.08"), 399 + CPSP =addr_getbit("@B_25395#W1.00"), 400 + CPVP =addr_getbit("@B_25395#W0.10"), 401 + CPRP =addr_getbit("@B_25395#W0.11"), 402 + HP =addr_getbit("@B_25395#W1.01"), 403 + PP= addr_getbit("@B_25395#W1.02"), 404 + PO=addr_getbit("@B_25395#W0.07"), 405 + FSE=addr_getbit("@B_25395#W2.04"), 406 + AVVSVV=addr_getbit("@B_25395#W1.12"), 407 + ICHT=addr_getbit("@B_25395#W3.06") 408 + 409 + } 410 + 411 + -- ("@B_25395#CIO1.02") 412 + mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 413 + mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 414 + else 415 + local stat, err = mq.m:connect(mq.config) -- connection 416 + if stat == nil then --Determine whether to connect 417 + print("mqtt connect failed:", err) 418 + return -- Connection failed, return directly 419 + end 420 + mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 421 + 422 + end 423 + -- mq.m:unsubscribe("stc/test") 424 + -- mq.m:disconnect() -- close matt 425 + -- mq.m:close() -- close clase 426 + end 792 792 end 793 793 {{/code}} 794 794 ... ... @@ -1218,20 +1218,35 @@ 1218 1218 1219 1219 {{code language="java"}} 1220 1220 { 856 + 1221 1221 "Version": "2012-10-17", 858 + 1222 1222 "Statement": [ 860 + 1223 1223 { 862 + 1224 1224 "Effect": "Allow", 864 + 1225 1225 "Action": [ 866 + 1226 1226 "iot:Connect", 868 + 1227 1227 "iot:Publish", 870 + 1228 1228 "iot:Subscribe", 872 + 1229 1229 "iot:Receive", 874 + 1230 1230 "greengrass:Discover" 876 + 1231 1231 ], 878 + 1232 1232 "Resource": "*" 880 + 1233 1233 } 882 + 1234 1234 ] 884 + 1235 1235 } 1236 1236 {{/code}} 1237 1237 ... ... @@ -1296,190 +1296,185 @@ 1296 1296 1297 1297 [[image:image-20220709165402-20.png]] 1298 1298 1299 -{{info}} 1300 -**✎Note:** Before using the following demo script, please make sure the V-Box firmware is newer than 22110701 1301 -{{/info}} 1302 - 1303 -{{code language="lua"}} 1304 1304 sprint = print 1305 1305 1306 ---Cloud mode interface to obtain the MQTT information configured by the cloud platform: (5 returns, namely the server address, client ID, connection table, last word table, certificate table) 951 +~-~-Cloud mode interface to obtain the MQTT information configured by the cloud platform: (5 returns, namely the server address, client ID, connection table, last word table, certificate table) 1307 1307 1308 1308 local MQTT_URL, MQTT_CLIENTID, MQTT_CFG, MQTT_LWT, MQTT_CART = mqtt.setup_cfg() 1309 1309 1310 ---publish to topics 955 +~-~-publish to topics 1311 1311 1312 1312 local pub_RE_TOPIC = string.format('TEST') 1313 1313 1314 ---Subscribe topics 959 +~-~-Subscribe topics 1315 1315 1316 1316 local Subscribe_RE_TOPIC1 = string.format('TEST') 1317 1317 1318 ---variable 963 +~-~-variable 1319 1319 1320 1320 local last_time = 0 1321 1321 1322 ---Timing main function 967 +~-~-Timing main function 1323 1323 1324 1324 function aws.main() 1325 1325 1326 - 971 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start") 1327 1327 1328 - 973 + if g_mq then 1329 1329 1330 - 975 + if g_mq:isconnected() then 1331 1331 1332 - 977 + send_Data() 1333 1333 1334 - 979 + else 1335 1335 1336 - 981 + if os.time() - last_time > 5 then 1337 1337 1338 - 983 + last_time = os.time() 1339 1339 1340 - 985 + mymqtt_connect() 1341 1341 1342 - end 1343 - 1344 1344 end 1345 1345 1346 - lse989 + end 1347 1347 1348 - mymqtt_init()991 + else 1349 1349 1350 - end993 + mymqtt_init() 1351 1351 1352 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.mainend")995 + end 1353 1353 997 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end") 998 + 1354 1354 end 1355 1355 1356 1356 1002 +~-~- Initialize MQTT 1357 1357 1358 --- Initialize MQTT 1359 - 1360 1360 function mymqtt_init() 1361 1361 1362 - 1006 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID)) 1363 1363 1364 - , 1) -- Create the object and declare it as a global variable, 1 means using the domain to connect1008 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable 1365 1365 1366 - 1010 + if g_mq then 1367 1367 1368 - 1012 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks 1369 1369 1370 - 1014 + sprint("mqtt init success") 1371 1371 1372 - 1016 + else 1373 1373 1374 - 1018 + sprint("mqtt init failed:", err) 1375 1375 1376 - 1020 + end 1377 1377 1378 1378 end 1379 1379 1380 --- Connect to MQTT server 1024 +~-~- Connect to MQTT server 1381 1381 1382 1382 function mymqtt_connect() 1383 1383 1384 - 1028 + sprint("mqtt connecting...") 1385 1385 1386 - 1030 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 1387 1387 1388 - 1032 + if stat == nil then 1389 1389 1390 - 1034 + sprint("mqtt connect failed:", err) 1391 1391 1392 - 1036 + return 1393 1393 1394 - 1038 + else 1395 1395 1396 - 1040 + sprint("mqtt connected") 1397 1397 1398 - 1042 + end 1399 1399 1400 - Subscribe_RE_TOPIC1, 0)1044 + g_mq:subscribe(TEST, 0) 1401 1401 1402 1402 end 1403 1403 1404 --- Receive MQTT message callback function 1048 +~-~- Receive MQTT message callback function 1405 1405 1406 1406 function mymqtt_msg_callback(topic, msg) 1407 1407 1408 - 1052 + print("topic:",topic) 1409 1409 1410 - 1054 + print("revdata:",msg) 1411 1411 1412 - 1056 + local revData = json.decode(msg) 1413 1413 1414 - 1058 + print (revData) 1415 1415 1416 - 1060 + if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud 1417 1417 1418 - 1062 +if string.match(topic,Subscribe_RE_TOPIC1) then 1419 1419 1420 - 1064 + ~-~-if revData ~~= nil then 1421 1421 1422 - 1066 + for k,v in pairs (revData) do 1423 1423 1424 - 1068 + print("printing revdata after kv here") 1425 1425 1426 - 1070 + print (k,v) 1427 1427 1428 - 1072 + end 1429 1429 1430 - 1074 + print ("current state is",fanstate) 1431 1431 1432 - 1076 + ~-~-end 1433 1433 1434 - 1078 +end 1435 1435 1436 - 1080 +end 1437 1437 1438 1438 end 1439 1439 1440 1440 1085 +~-~-Get real-time data 1441 1441 1442 ---Get real-time data 1443 - 1444 1444 function getData() 1445 1445 1446 - 1089 + local jdata = {} 1447 1447 1448 - 1091 + local addr = bns_get_alldata() 1449 1449 1450 - 1093 + print(json.encode(addr)) 1451 1451 1452 - 1095 + for i,v in pairs(addr) do 1453 1453 1454 - 1097 + if v[2] == 1 then 1455 1455 1456 - 1099 + jdata[v[3]] = v[4] 1457 1457 1458 - 1101 + end 1459 1459 1460 - 1103 + end 1461 1461 1462 - 1105 + return jdata 1463 1463 1464 1464 end 1465 1465 1466 ---send data 1109 +~-~-send data 1467 1467 1468 1468 function send_Data() 1469 1469 1470 - local pub_data = 1471 - { 1472 - 123 1473 - } 1113 + local pub_data = 1474 1474 1115 + { 1116 + 1117 +123 1118 + 1119 +} 1120 + 1475 1475 sprint(json.encode(pub_data)) 1476 1476 1477 1477 print("..........",pub_RE_TOPIC) 1478 1478 1479 - 1125 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0) 1480 1480 1481 1481 end 1482 -{{/code}} 1483 1483 1484 1484 Get message in AWS 1485 1485
- InputHTTPparameter.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Hunter - Size
-
... ... @@ -1,1 +1,0 @@ 1 -17.9 KB - Content