Changes for page 2 Script
Last modified by Devin Chen on 2025/06/06 14:03
From version 63.1
edited by Theodore Xu
on 2023/08/24 17:28
on 2023/08/24 17:28
Change comment:
There is no comment for this version
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. AiXia1 +XWiki.Hunter - Content
-
... ... @@ -1,9 +1,9 @@ 1 1 = **1 General Script Demo** = 2 2 3 -== **1.1 Address Operation** == 3 +== **1.1 Address Operation:Write/Read data from address A to B** == 4 4 5 5 ((( 6 - Write/Read data from address A to B**. **For example:transfer D2 to D06 +For example:transfer D2 to D0 7 7 ))) 8 8 9 9 (% style="text-align:center" %) ... ... @@ -27,19 +27,25 @@ 27 27 28 28 == **1.4 Short message** == 29 29 30 - Thefollowingdemo showsthat whenthealarm condition is reached: temp1 > 5 & temp2 >10 & temp3 < 20(lasts more than 5 seconds) , then send an "alarm trigger" sms.30 +When the alarm condition is reached: temp1 > 5 & temp2 >10 & temp3 < 20(lasts more than 5 seconds) , then send an "alarm trigger" sms. 31 31 32 -When the alarm condition is released,then send an Script is as below:32 +When the alarm condition is released,then send an "alarm release" sms. 33 33 34 -{{code language="lua"}} 34 +(% style="text-align:center" %) 35 +[[image:1645535936750-316.png||height="385" width="400" class="img-thumbnail"]] 36 + 37 +Script is as below: 38 + 39 +(% class="box infomessage" %) 40 +((( 35 35 function sms.main() 36 -------send condition------ 42 +~-~-~-~-~-~-send condition~-~-~-~-~-~- 37 37 local temp1 = addr_getword("@Temperature1") 38 38 local temp2 = addr_getword("@Temperature2") 39 39 local temp3 = addr_getword("@Temperature3") 40 40 local timer = addr_getword("@Timer") 41 41 local tag = addr_getbit("@Tag") 42 -------lasting time------ 48 +~-~-~-~-~-~-lasting time~-~-~-~-~-~- 43 43 if temp1 > 5 and temp2 > 10 and temp3 < 20 then 44 44 timer = timer + 1 45 45 addr_setword("@Timer",timer) ... ... @@ -47,7 +47,7 @@ 47 47 timer = 0 48 48 addr_setword("@Timer",timer) 49 49 end 50 -------send sms & output Y0------ 56 +~-~-~-~-~-~-send sms & output Y0~-~-~-~-~-~- 51 51 if timer > 5 then 52 52 if tag == 0 then 53 53 send_sms_ira("19859254700","alarm trigger") ... ... @@ -58,18 +58,12 @@ 58 58 addr_setbit("@Tag",0) 59 59 end 60 60 end 61 - {{/code}}67 +))) 62 62 63 63 == **1.5 Telegram notification** == 64 64 65 65 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. 66 66 67 -As for How to get the botToken and chatID, please check the followig videos: 68 - 69 -[[https:~~/~~/www.youtube.com/watch?v=zh6yYlnjX7k>>https://www.youtube.com/watch?v=zh6yYlnjX7k]] 70 - 71 -[[https:~~/~~/www.youtube.com/watch?v=Pj8mwuMZZvg>>https://www.youtube.com/watch?v=Pj8mwuMZZvg]] 72 - 73 73 {{code language="Lua"}} 74 74 local tempBit = 0 75 75 local tempWord = 0 ... ... @@ -139,7 +139,7 @@ 139 139 140 140 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. 141 141 142 -{{code language="lua"}}142 +{{code}} 143 143 local tempBit = 0 144 144 local tempWord = 0 145 145 ... ... @@ -214,266 +214,8 @@ 214 214 end 215 215 {{/code}} 216 216 217 -= =**1.7TwilioWhatsAppMessaging** ==217 += **2 V-Box connect with third part server** = 218 218 219 -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. 220 - 221 -About how to register the Twilio API, please check the following video: 222 - 223 -[[https:~~/~~/www.youtube.com/watch?v=Id4lKichauU>>https://www.youtube.com/watch?v=Id4lKichauU]] 224 - 225 -{{code language="Lua"}} 226 -local tempBit = 0 227 -local tempWord = 0 228 - 229 -local https = require("https") 230 -local json = require("json") 231 -local ltn12 = require("ltn12") 232 - 233 -local SID = 'AC1703bd710ffa98006d2bcc0b********' 234 -local Token = 'd3c11897623c39e538b20263ec19****' 235 - 236 -local twilioPhoneNumber = '+14155238886' 237 -local receiverPhoneNumber = '+8615880018277' 238 - 239 -local b='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' 240 -function encodingBase64(data) 241 - return ((data:gsub('.', function(x) 242 - local r,b='',x:byte() 243 - for i=8,1,-1 do r=r..(b%2^i-b%2^(i-1)>0 and '1' or '0') end 244 - return r; 245 - end)..'0000'):gsub('%d%d%d?%d?%d?%d?', function(x) 246 - if (#x < 6) then return '' end 247 - local c=0 248 - for i=1,6 do c=c+(x:sub(i,i)=='1' and 2^(6-i) or 0) end 249 - return b:sub(c+1,c+1) 250 - end)..({ '', '==', '=' })[#data%3+1]) 251 -end 252 - 253 -function encodeUrl(str) 254 - str = string.gsub(str, "([^%w%.%- ])", function(c) 255 - return string.format("%%%02X", string.byte(c)) end) 256 - return string.gsub(str, " ", "+") 257 -end 258 - 259 - 260 - 261 - 262 -function requestBodySplice(message, sender, receiver) 263 - local reqBody = '' 264 - local encodeMess = encodeUrl(message) 265 - local encodeSend = encodeUrl(sender) 266 - local encodeRece = encodeUrl(receiver) 267 - --reqBody = "Body=Hello%20Wecon2&From=whatsapp%3A%2B14155238886&To=whatsapp%3A%2B8615880018277" 268 - reqBody = string.format("Body=%s&From=whatsapp:%s&To=whatsapp:%s", encodeMess, encodeSend, encodeRece) 269 - print(reqBody) 270 - return reqBody 271 -end 272 - 273 - 274 --- Send http.get request and return response result 275 -function getHttpsUrl(url,header,reqbody) 276 - local body = {} 277 - local bodyJson = json.encode(body) 278 - local result_table, code, headers, status = https.request{ 279 - method = "POST", 280 - url = url, 281 - source = ltn12.source.string(reqbody), 282 - headers = header, 283 - sink = ltn12.sink.table(body) 284 - } 285 - print("code:"..code) 286 - if code~= 200 then 287 - return 288 - else 289 - return body 290 - end 291 -end 292 - 293 -function getMessageUrl(whatsAppMessage) 294 - local auth = SID..':'..Token 295 - local url = "https://api.twilio.com/2010-04-01/Accounts/"..SID.."/Messages" 296 - --local reqMess = "message="..twilioMessage 297 - local reqMess = requestBodySplice(whatsAppMessage, twilioPhoneNumber, receiverPhoneNumber) 298 - local headers = 299 - { 300 - ["Authorization"] = "Basic "..encodingBase64(auth), 301 - ["Content-Type"] = "application/x-www-form-urlencoded", 302 - ["Content-Length"] = #reqMess 303 - } 304 - 305 - print("Get the link:"..url) 306 - getHttpsUrl(url, headers, reqMess) 307 -end 308 - 309 - 310 - 311 -function Twilio.main() 312 - --dosomething 313 - --local auth = SID..':'..Token 314 - --print(requestBodySplice("HelloWorld", twilioPhoneNumber, receiverPhoneNumber)) 315 - --print(encodingBase64(auth)) 316 - local bitValue = addr_getbit("@testBit"); 317 - local message = '' 318 - print("b=="..bitValue) 319 - if bitValue == 1 and bitValue ~= tempBit then 320 - message = 'Alarm V-Box triggered, the output is '.. bitValue 321 - getMessageUrl(message) 322 - print("Notification pushed of triggering alarm,"..bitValue) 323 - elseif bitValue == 0 and bitValue ~= tempBit then 324 - message = 'Alarm V-Box dismissed, the output is '.. bitValue 325 - getMessageUrl(message) 326 - print("Notification pushed of dismissing alarm,"..bitValue) 327 - end 328 - tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform 329 - 330 - local wordValue = addr_getword("@testWord") 331 - print("w=="..wordValue) 332 - --dosomething 333 - if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then 334 - message = 'Alarm V-Box triggered, the temperature is '.. wordValue 335 - getMessageUrl(message) 336 - print("Notification pushed of triggering alarm,"..wordValue) 337 - elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then 338 - message = 'Alarm V-Box dismissed, the temperature is '.. wordValue 339 - getMessageUrl(message) 340 - print("Notification pushed of dismissing alarm,"..wordValue) 341 - end 342 - tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform 343 -end 344 -{{/code}} 345 - 346 -== **1.8 HTTP response body** == 347 - 348 -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": 349 - 350 -(% style="text-align:center" %) 351 -[[image:InputHTTPparameter.png]] 352 - 353 -Then the response body would be like as following: 354 - 355 -{{code language="json"}} 356 -{ 357 - "location": { 358 - "name": "Madrid", 359 - "region": "Madrid", 360 - "country": "Spain", 361 - "lat": 40.4, 362 - "lon": -3.68, 363 - "tz_id": "Europe/Madrid", 364 - "localtime_epoch": 1669022636, 365 - "localtime": "2022-11-21 10:23" 366 - }, 367 - "current": { 368 - "last_updated_epoch": 1669022100, 369 - "last_updated": "2022-11-21 10:15", 370 - "temp_c": 13.0, 371 - "temp_f": 55.4, 372 - "is_day": 1, 373 - "condition": { 374 - "text": "Partly cloudy", 375 - "icon": "//cdn.weatherapi.com/weather/64x64/day/116.png", 376 - "code": 1003 377 - }, 378 - "wind_mph": 11.9, 379 - "wind_kph": 19.1, 380 - "wind_degree": 210, 381 - "wind_dir": "SSW", 382 - "pressure_mb": 1015.0, 383 - "pressure_in": 29.97, 384 - "precip_mm": 0.0, 385 - "precip_in": 0.0, 386 - "humidity": 88, 387 - "cloud": 75, 388 - "feelslike_c": 10.8, 389 - "feelslike_f": 51.4, 390 - "vis_km": 10.0, 391 - "vis_miles": 6.0, 392 - "uv": 3.0, 393 - "gust_mph": 22.1, 394 - "gust_kph": 35.6 395 - } 396 -} 397 -{{/code}} 398 - 399 -(% class="wikigeneratedid" %) 400 -So we decode json into lua object to assign the value into addresses HDW6060(temperature), HDW7070(humidity), the code example like follows: 401 - 402 -{{code language="lua"}} 403 -local APIkey = '70faaecf926b4341b1974006221711' 404 - 405 - 406 -local http = require("socket.http") 407 -local json = require("json") 408 - 409 --- Send http.get request and return response result 410 -function getHttpsUrl(url) 411 - local result_table, code, headers, status = http.request(url) 412 - print("code:"..code) 413 - if code~= 200 then 414 - return 415 - else 416 - return result_table 417 - end 418 -end 419 - 420 -function sendAPI(key, city) 421 - local url = "http://api.weatherapi.com/v1/current.json?key="..key.."&q="..city.."&aqi=no" 422 - --local url = 'http://v-box.net' 423 - --local url = 'https://www.google.com/' 424 - --http://api.weatherapi.com/v1/current.json?key=70faaecf926b4341b1974006221711&q=Barcelona&aqi=no 425 - print("Get the link:"..url) 426 - local body = getHttpsUrl(url) 427 - --print(body) 428 - local jsonBody = json.decode(body) 429 - --print(jsonBody["current"]["temp_c"]) 430 - --print(type(jsonBody["current"]["temp_c"])) 431 - --print(type(jsonBody["current"]["humidity"])) 432 - addr_setfloat("@HDW6060", jsonBody["current"]["temp_c"]) 433 - addr_setword("@HDW7070", jsonBody["current"]["humidity"]) 434 -end 435 - 436 - 437 -function Weather.main() 438 - local cityName = addr_getstring("@HDW5050",6) 439 - print("cityName: "..cityName) 440 - sendAPI(APIkey, cityName) 441 -end 442 -{{/code}} 443 - 444 -== **1.9 High-Low Byte Switch** == 445 - 446 -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"]]. 447 - 448 -{{code language="lua"}} 449 -function highLowByteSwitch(floatNumber) 450 - addr_setfloat("@W_0#HDW23036",floatNumber,0,2) 451 - local newFloat = addr_getfloat("@W_0#HDW23036") 452 - local formattedFloat = string.format("%.2f",newFloat) 453 - print("The formatted float value is the : "..formattedFloat) 454 - return formattedFloat 455 -end 456 -{{/code}} 457 - 458 -== **1.10 Read 64bits Unsigned Value** == 459 - 460 -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. 461 - 462 -{{code language="lua"}} 463 -function addr_getquatra(address) 464 - local highAddress = addr_newnoaddr(address,2) 465 - local low32 = addr_getdword(address) 466 - local high32 = addr_getdword(highAddress) 467 - --print("the low number is "..low32) 468 - --print("the high number is "..high32) 469 - local formatVal = string.format("%64.0f",2^32*high32+low32) 470 - print("the format value is ".. formatVal) 471 - return formatVal 472 -end 473 -{{/code}} 474 - 475 -= **2 Third part server** = 476 - 477 477 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. 478 478 479 479 (% class="mark" %)1.Europe server:eu.v-box.net ... ... @@ -490,38 +490,17 @@ 490 490 491 491 (% class="mark" %)2.If your server requires SSL certificate to log in,please use OpenCloud.Because only OpenCloud platform can support to upload certificate 492 492 493 - {{info}}235 +(% class="wikigeneratedid" %) 494 494 **✎Note: **Before program the script of MQTT, please make sure the server(MQTT broker) can be connected through MQTT Client tool. 495 -{{/info}} 496 496 497 497 (% class="wikigeneratedid" %) 498 498 Tool link: **[[MQTT.fx>>http://mqttfx.jensd.de/index.php/download]]** 499 499 500 -== **2.1 Test server(General Example)** ==241 +== **2.1 V-Box connect with test server(General Example)** == 501 501 502 -The following example is trying to publish to the topic "testtopic/test/no1/7890", and subscribe the topic "testtopic/test/no1/123456". 503 - 504 -And the JSON message is like follows: 505 - 506 -{{code language="JSON"}} 507 -{ 508 - "timestamp": 1631152760, 509 - "messageId": 1, 510 - "event": "test_data", 511 - "mfrs": "HMI/box", 512 - "data": 513 - { 514 - "id" : 1436217747670454274, 515 - "waterlevel" : 48, 516 - "temperture" : 23 517 - } 518 -} 519 -{{/code}} 520 - 521 521 {{code language="lua"}} 522 522 --MQTT configuration table 523 523 local MQTT_CFG={} 524 ---if there is no need the username and password, please put them as "" 525 525 MQTT_CFG.username = "weconsupport" 526 526 MQTT_CFG.password = "123456" 527 527 MQTT_CFG.netway = 0 ... ... @@ -560,13 +560,9 @@ 560 560 --initialize mqtt 561 561 function mqtt_init() 562 562 print(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENT_ID)) 563 - if g_mq then 564 - mqtt.close(g_mq) --Close mqtt object 565 - end 566 566 g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENT_ID) -- create mqtt object,and declare it as a global variable 567 567 if g_mq then 568 568 g_mq:on("message", mqtt_msg_callback) -- Register a callback for receiving messages 569 - g_mq:on("offline", mqtt_msg_offline) -- Register a callback for offline 570 570 print("mqtt init success") 571 571 else 572 572 print("mqtt init failed:", err) ... ... @@ -586,11 +586,6 @@ 586 586 g_mq:subscribe(SUBSCRIBE_TOPIC, 0) 587 587 end 588 588 589 ---Offline callback function 590 -function mqtt_msg_offline(cause) 591 - print("mqtt offline, cause:", cause) 592 -end 593 - 594 594 -- Received message callback function 595 595 function mqtt_msg_callback(topic, msg) 596 596 print("topic:", topic) ... ... @@ -629,11 +629,9 @@ 629 629 if g_mq:isconnected() then 630 630 send_data() 631 631 else 632 - --if exceed 5sec not connect, reconnect once633 - if os.time() - LAST_TIME > 5then344 + --if exceed 20 sec not connect, reconnect once 345 + if os.time() - LAST_TIME > 20 then 634 634 LAST_TIME = os.time() 635 - --reinitial the mqtt object 636 - mqtt_init() 637 637 --connect to mqtt or reconnect 638 638 mqtt_connect() 639 639 end ... ... @@ -646,7 +646,7 @@ 646 646 end 647 647 {{/code}} 648 648 649 -== **2.2 Customer server:grouprobotinfo.com** ==359 +== **2.2 V-Box connect with customer server:grouprobotinfo.com** == 650 650 651 651 This demo does not use SSL certification. Script is as below 652 652 ... ... @@ -656,138 +656,146 @@ 656 656 -- Meta class 657 657 --main 658 658 function mq.main() 659 - 660 - 369 + if not mq.m then 370 + local err = "" 661 661 662 - mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 663 - if mq.m then 664 - mq.config = { 665 - username = "",-- ID 666 - password = "",-- password 667 - netway = 1, -- Ethernet connection, WIFI=1 668 - -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 669 - -- cleansession = 0, -- Optional, keep session 670 - } 671 - mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 672 - local str = string.format("%s:%s", topic, msg) 673 - -- print("mqtt msg:", str) -- Print out the received topics and content 674 - end) 675 - mq.m:on("offline", function (cause) -- Register for lost connection callbacks 676 - -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 677 - end) 678 - mq.m:on("arrived", function() -- Registration for sending messages to callbacks 679 - print("msg arrived") 680 - end) 681 - else 682 - print("mqtt create failed:", err) -- Create object failed 683 - end 684 - else 685 - if mq.m:isconnected() then -- If online, post a message 686 - local phaseStatus ="unknow" 687 - if addr_getbit("@Standby")== 1 then 688 - phaseStatus = "Standby" 689 - elseif addr_getbit("@Pre-Freeze")==1 then 690 - phaseStatus= "Pre-Freeze" 691 - elseif addr_getbit("@Prepare")==1 then 692 - phaseStatus ="Prepare" 693 - elseif addr_getbit("@Primary Dry")==1 then 694 - phaseStatus = "Primary dry" 695 - elseif addr_getbit("@Secondary Dry")==1 then 696 - phaseStatus = "Secondary Dry" 697 - end 698 - --print(addr_getbit("@Primary Dry")) 372 + mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 373 + if mq.m then 374 + mq.config = { 375 + username = "",-- ID 376 + password = "",-- password 377 + netway = 1, -- Ethernet connection, WIFI=1 378 + -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 379 + -- cleansession = 0, -- Optional, keep session 380 + } 381 + mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 382 + local str = string.format("%s:%s", topic, msg) 383 + -- print("mqtt msg:", str) -- Print out the received topics and content 384 + end 385 + ) 386 + mq.m:on("offline", function (cause) -- Register for lost connection callbacks 387 + -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 388 + end) 389 + mq.m:on("arrived", function() -- Registration for sending messages to callbacks 390 + print("msg arrived") 391 + end) 392 + else 393 + print("mqtt create failed:", err) -- Create object failed 394 + end 395 + else 396 + if mq.m:isconnected() then -- If online, post a message 397 + local phaseStatus ="unknow" 398 + if addr_getbit("@Standby")== 1 then 399 + phaseStatus = "Standby" 400 + elseif addr_getbit("@Pre-Freeze")==1 then 401 + phaseStatus= "Pre-Freeze" 402 + elseif addr_getbit("@Prepare")==1 then 403 + phaseStatus ="Prepare" 404 + elseif addr_getbit("@Primary Dry")==1 then 405 + phaseStatus = "Primary dry" 406 + elseif addr_getbit("@Secondary Dry")==1 then 407 + phaseStatus = "Secondary Dry" 408 + end 409 +-- print(addr_getbit("@Primary Dry")) 699 699 ------------------------------------------------------------------------------------------------------------------------- 700 - local activating ="unknow" 701 - if addr_getbit("@Compressor")==1 then 702 - activating = ",".."Compressor" 703 - end 704 - if addr_getbit("@Silicone Pump")==1 then 705 - activating = activating..",".."Silicone Pump" 706 - end 707 - if addr_getbit("@Vacuum Pump")==1 then 708 - activating = activating..",".."Vacuum Pump" 709 - end 710 - if addr_getbit("@Root Pump")==1 then 711 - activating = activating..",".."Root Pump" 712 - end 713 - if addr_getbit("@Heater")==1 then 714 - activating = activating..",".."Heater" 715 - end 716 - if addr_getbit("@Valve Silicone")==1 then 717 - activating = activating..",".."Valve Silicone" 718 - end 719 - if addr_getbit("@Valve Ice Condenser")==1 then 720 - activating = activating..",".."Valve Ice Condenser" 721 - end 722 - if addr_getbit("@Valve Vacuum Pump")==1 then 723 - activating = activating..",".."Valve Vacuum Pump" 724 - end 725 - local pr_activating =string.sub(activating,2) 726 - -- print(pr_activating) 727 - local status_text ="unknow" 728 - if addr_getbit("@Status Run")==1 then 729 - status_text = "RUNNING" 730 - else 731 - status_text = "STOP" 732 - end 733 -------------------------------------------------------------------------------------------------------------------------- 734 - local js = {type="status", 735 - mc_name ="FD300", 736 - status=status_text, 737 - elapsed_time={ 738 - hour=addr_getword("@Elapsed Time (Hour)"), 739 - min=addr_getword("@Elapsed Time (Minute)"), 740 - sec=addr_getword("@Elapsed Time (Second)") 741 - }, 742 - phase = phaseStatus, 743 - step = addr_getword("@Step"), 744 - activating_output = pr_activating, 745 - sv=addr_getshort("@SV Silicone")/10, 746 - pv=addr_getshort("@PV Silicone")/10, 747 - product1=addr_getshort("@Product 1")/10, 411 + local activating ="unknow" 412 + if addr_getbit("@Compressor")==1 then 413 + activating = ",".."Compressor" 414 + end 415 + if addr_getbit("@Silicone Pump")==1 then 416 + activating = activating..",".."Silicone Pump" 417 + end 418 + if addr_getbit("@Vacuum Pump")==1 then 419 + activating = activating..",".."Vacuum Pump" 420 + end 421 + if addr_getbit("@Root Pump")==1 then 422 + activating = activating..",".."Root Pump" 423 + end 424 + if addr_getbit("@Heater")==1 then 425 + activating = activating..",".."Heater" 426 + end 427 + if addr_getbit("@Valve Silicone")==1 then 428 + activating = activating..",".."Valve Silicone" 429 + end 430 + if addr_getbit("@Valve Ice Condenser")==1 then 431 + activating = activating..",".."Valve Ice Condenser" 432 + end 433 + if addr_getbit("@Valve Vacuum Pump")==1 then 434 + activating = activating..",".."Valve Vacuum Pump" 435 + end 436 + local pr_activating =string.sub(activating,2) 437 + -- print(pr_activating) 748 748 749 - product2=addr_getshort("@Product 2")/10, 750 - product3=addr_getshort("@Product 3")/10, 751 - product4=addr_getshort("@Product 4")/10, 752 - ice1=addr_getshort("@Ice condenser 1")/10, 753 - ice2=addr_getshort("@Ice condenser 2")/10, 754 - vacuum=addr_getfloat("@Vacuum") 755 - } 756 - local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 757 - ODPC = addr_getbit("@B_25395#W0.01"), 758 - MTPC=addr_getbit("@B_25395#W0.02"), 759 - HTT = addr_getbit("@B_25395#W1.03"), 760 - CPC = addr_getbit("@B_25395#W0.08"), 761 - CPSP =addr_getbit("@B_25395#W1.00"), 762 - CPVP =addr_getbit("@B_25395#W0.10"), 763 - CPRP =addr_getbit("@B_25395#W0.11"), 764 - HP =addr_getbit("@B_25395#W1.01"), 765 - PP= addr_getbit("@B_25395#W1.02"), 766 - PO=addr_getbit("@B_25395#W0.07"), 767 - FSE=addr_getbit("@B_25395#W2.04"), 768 - AVVSVV=addr_getbit("@B_25395#W1.12"), 769 - ICHT=addr_getbit("@B_25395#W3.06") 770 - } 771 - -- ("@B_25395#CIO1.02") 772 - mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 773 - mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 774 - else 775 - local stat, err = mq.m:connect(mq.config) -- connection 776 - if stat == nil then --Determine whether to connect 777 - print("mqtt connect failed:", err) 778 - return -- Connection failed, return directly 779 - end 780 - mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 781 781 782 - end 783 - -- mq.m:unsubscribe("stc/test") 784 - -- mq.m:disconnect() -- close matt 785 - -- mq.m:close() -- close clase 786 - end 440 + 441 + local status_text ="unknow" 442 + if addr_getbit("@Status Run")==1 then 443 + status_text = "RUNNING" 444 + else 445 + status_text = "STOP" 446 + end 447 +------------------------------------------------------------------------------------------------------------------------- 448 + 449 + local js = {type="status", 450 + mc_name ="FD300", 451 + status=status_text, 452 + elapsed_time={ 453 + hour=addr_getword("@Elapsed Time (Hour)"), 454 + min=addr_getword("@Elapsed Time (Minute)"), 455 + sec=addr_getword("@Elapsed Time (Second)") 456 + }, 457 + phase = phaseStatus, 458 + step = addr_getword("@Step"), 459 + activating_output = pr_activating, 460 + sv=addr_getshort("@SV Silicone")/10, 461 + pv=addr_getshort("@PV Silicone")/10, 462 + product1=addr_getshort("@Product 1")/10, 463 + 464 + product2=addr_getshort("@Product 2")/10, 465 + product3=addr_getshort("@Product 3")/10, 466 + product4=addr_getshort("@Product 4")/10, 467 + ice1=addr_getshort("@Ice condenser 1")/10, 468 + ice2=addr_getshort("@Ice condenser 2")/10, 469 + vacuum=addr_getfloat("@Vacuum") 470 + 471 + } 472 + local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 473 + ODPC = addr_getbit("@B_25395#W0.01"), 474 + MTPC=addr_getbit("@B_25395#W0.02"), 475 + HTT = addr_getbit("@B_25395#W1.03"), 476 + CPC = addr_getbit("@B_25395#W0.08"), 477 + CPSP =addr_getbit("@B_25395#W1.00"), 478 + CPVP =addr_getbit("@B_25395#W0.10"), 479 + CPRP =addr_getbit("@B_25395#W0.11"), 480 + HP =addr_getbit("@B_25395#W1.01"), 481 + PP= addr_getbit("@B_25395#W1.02"), 482 + PO=addr_getbit("@B_25395#W0.07"), 483 + FSE=addr_getbit("@B_25395#W2.04"), 484 + AVVSVV=addr_getbit("@B_25395#W1.12"), 485 + ICHT=addr_getbit("@B_25395#W3.06") 486 + 487 + } 488 + 489 + -- ("@B_25395#CIO1.02") 490 + mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 491 + mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 492 + else 493 + local stat, err = mq.m:connect(mq.config) -- connection 494 + if stat == nil then --Determine whether to connect 495 + print("mqtt connect failed:", err) 496 + return -- Connection failed, return directly 497 + end 498 + mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 499 + 500 + end 501 + -- mq.m:unsubscribe("stc/test") 502 + -- mq.m:disconnect() -- close matt 503 + -- mq.m:close() -- close clase 504 + end 787 787 end 788 788 {{/code}} 789 789 790 -== **2.3 Azure platform** == 508 +== **2.3 V-Box connect with Azure platform** == 791 791 792 792 In this demo,V-Box connects with Azure by SSL certification. 793 793 ... ... @@ -918,12 +918,8 @@ 918 918 end 919 919 ))) 920 920 921 -== **2.4 Huawei platform** == 639 +== **2.4 How to configure the Huawei platform?(✎Note: Huawei IOT DA function is only in China area.If you want this function,you need to use chinese mobile to register)** == 922 922 923 -{{info}} 924 -**✎Note**:**Huawei IOT DA function is only in China area.If you want this function,you need to use chinese mobile to register** 925 -{{/info}} 926 - 927 927 1.Register a account: [[https:~~/~~/www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ>>https://www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ]] 928 928 929 929 2.log in the Huawei IOTDA ... ... @@ -1071,8 +1071,10 @@ 1071 1071 (% style="text-align:center" %) 1072 1072 [[image:1624441186851-536.png||height="434" width="700" class="img-thumbnail"]] 1073 1073 1074 -== =HuaweibySSLcertification.===788 +== **2.5 V-Box connect with Huawei platform** == 1075 1075 790 +In this demo,V-Box connects with Huawei by SSL certification. 791 + 1076 1076 1.Create a project access for Huawei IOT 1077 1077 1078 1078 2.configure MQTT configuration ... ... @@ -1190,7 +1190,7 @@ 1190 1190 (% style="text-align:center" %) 1191 1191 [[image:1624506666650-161.png||height="547" width="1000" class="img-thumbnail"]] 1192 1192 1193 -== **2.6 AWS platform** == 909 +== **2.6 V-Box connect with AWS platform** == 1194 1194 1195 1195 === **Log in AWS** === 1196 1196 ... ... @@ -1215,20 +1215,35 @@ 1215 1215 1216 1216 {{code language="java"}} 1217 1217 { 934 + 1218 1218 "Version": "2012-10-17", 936 + 1219 1219 "Statement": [ 938 + 1220 1220 { 940 + 1221 1221 "Effect": "Allow", 942 + 1222 1222 "Action": [ 944 + 1223 1223 "iot:Connect", 946 + 1224 1224 "iot:Publish", 948 + 1225 1225 "iot:Subscribe", 950 + 1226 1226 "iot:Receive", 952 + 1227 1227 "greengrass:Discover" 954 + 1228 1228 ], 956 + 1229 1229 "Resource": "*" 958 + 1230 1230 } 960 + 1231 1231 ] 962 + 1232 1232 } 1233 1233 {{/code}} 1234 1234 ... ... @@ -1255,7 +1255,7 @@ 1255 1255 [[image:image-20220709165402-11.png]] 1256 1256 1257 1257 1258 -=== **MQTT.fx tool** === 989 +=== **Test with MQTT.fx tool** === 1259 1259 1260 1260 Click “View Setting” to get the “Broker Adress” 1261 1261 ... ... @@ -1283,7 +1283,7 @@ 1283 1283 1284 1284 [[image:image-20220709165402-18.png]] 1285 1285 1286 -=== **CloudTool** === 1017 +=== **Configurate in CloudTool** === 1287 1287 1288 1288 Copy the same setting in MQTT.fx to MQTT configuration 1289 1289 ... ... @@ -1293,193 +1293,186 @@ 1293 1293 1294 1294 [[image:image-20220709165402-20.png]] 1295 1295 1296 -{{info}} 1297 -**✎Note:** Before using the following demo script, please make sure the V-Box firmware is newer than 22110701 1298 -{{/info}} 1299 - 1300 -{{code language="lua"}} 1301 1301 sprint = print 1302 1302 1303 ---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) 1029 +~-~-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) 1304 1304 1305 1305 local MQTT_URL, MQTT_CLIENTID, MQTT_CFG, MQTT_LWT, MQTT_CART = mqtt.setup_cfg() 1306 1306 1307 ---publish to topics 1033 +~-~-publish to topics 1308 1308 1309 1309 local pub_RE_TOPIC = string.format('TEST') 1310 1310 1311 ---Subscribe topics 1037 +~-~-Subscribe topics 1312 1312 1313 1313 local Subscribe_RE_TOPIC1 = string.format('TEST') 1314 1314 1315 ---variable 1041 +~-~-variable 1316 1316 1317 1317 local last_time = 0 1318 1318 1319 ---Timing main function 1045 +~-~-Timing main function 1320 1320 1321 1321 function aws.main() 1322 1322 1323 - 1049 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start") 1324 1324 1325 - 1051 + if g_mq then 1326 1326 1327 - 1053 + if g_mq:isconnected() then 1328 1328 1329 - 1055 + send_Data() 1330 1330 1331 - 1057 + else 1332 1332 1333 - 1059 + if os.time() - last_time > 5 then 1334 1334 1335 - 1061 + last_time = os.time() 1336 1336 1337 - 1063 + mymqtt_connect() 1338 1338 1339 - end 1340 - 1341 1341 end 1342 1342 1343 - lse1067 + end 1344 1344 1345 - mymqtt_init()1069 + else 1346 1346 1347 - end1071 + mymqtt_init() 1348 1348 1349 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.mainend")1073 + end 1350 1350 1075 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end") 1076 + 1351 1351 end 1352 1352 1353 1353 1080 +~-~- Initialize MQTT 1354 1354 1355 --- Initialize MQTT 1356 - 1357 1357 function mymqtt_init() 1358 1358 1359 - 1084 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID)) 1360 1360 1361 - , 1) -- Create the object and declare it as a global variable, 1 means using the domain to connect1086 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable 1362 1362 1363 - 1088 + if g_mq then 1364 1364 1365 - 1090 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks 1366 1366 1367 - 1092 + sprint("mqtt init success") 1368 1368 1369 - 1094 + else 1370 1370 1371 - 1096 + sprint("mqtt init failed:", err) 1372 1372 1373 - 1098 + end 1374 1374 1375 1375 end 1376 1376 1377 --- Connect to MQTT server 1102 +~-~- Connect to MQTT server 1378 1378 1379 1379 function mymqtt_connect() 1380 1380 1381 - 1106 + sprint("mqtt connecting...") 1382 1382 1383 - 1108 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 1384 1384 1385 - 1110 + if stat == nil then 1386 1386 1387 - 1112 + sprint("mqtt connect failed:", err) 1388 1388 1389 - 1114 + return 1390 1390 1391 - 1116 + else 1392 1392 1393 - 1118 + sprint("mqtt connected") 1394 1394 1395 - 1120 + end 1396 1396 1397 - Subscribe_RE_TOPIC1, 0)1122 + g_mq:subscribe(TEST, 0) 1398 1398 1399 1399 end 1400 1400 1401 --- Receive MQTT message callback function 1126 +~-~- Receive MQTT message callback function 1402 1402 1403 1403 function mymqtt_msg_callback(topic, msg) 1404 1404 1405 - 1130 + print("topic:",topic) 1406 1406 1407 - 1132 + print("revdata:",msg) 1408 1408 1409 - 1134 + local revData = json.decode(msg) 1410 1410 1411 - 1136 + print (revData) 1412 1412 1413 - 1138 + if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud 1414 1414 1415 - 1140 +if string.match(topic,Subscribe_RE_TOPIC1) then 1416 1416 1417 - 1142 + ~-~-if revData ~~= nil then 1418 1418 1419 - 1144 + for k,v in pairs (revData) do 1420 1420 1421 - 1146 + print("printing revdata after kv here") 1422 1422 1423 - 1148 + print (k,v) 1424 1424 1425 - 1150 + end 1426 1426 1427 - 1152 + print ("current state is",fanstate) 1428 1428 1429 - 1154 + ~-~-end 1430 1430 1431 - 1156 +end 1432 1432 1433 - 1158 +end 1434 1434 1435 1435 end 1436 1436 1437 1437 1163 +~-~-Get real-time data 1438 1438 1439 ---Get real-time data 1440 - 1441 1441 function getData() 1442 1442 1443 - 1167 + local jdata = {} 1444 1444 1445 - 1169 + local addr = bns_get_alldata() 1446 1446 1447 - 1171 + print(json.encode(addr)) 1448 1448 1449 - 1173 + for i,v in pairs(addr) do 1450 1450 1451 - 1175 + if v[2] == 1 then 1452 1452 1453 - 1177 + jdata[v[3]] = v[4] 1454 1454 1455 - 1179 + end 1456 1456 1457 - 1181 + end 1458 1458 1459 - 1183 + return jdata 1460 1460 1461 1461 end 1462 1462 1463 ---send data 1187 +~-~-send data 1464 1464 1465 1465 function send_Data() 1466 1466 1467 - local pub_data = 1468 - { 1469 - 123 1470 - } 1191 + local pub_data = 1471 1471 1193 + { 1194 + 1195 +123 1196 + 1197 +} 1198 + 1472 1472 sprint(json.encode(pub_data)) 1473 1473 1474 1474 print("..........",pub_RE_TOPIC) 1475 1475 1476 - 1203 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0) 1477 1477 1478 1478 end 1479 -{{/code}} 1480 1480 1481 1481 Get message in AWS 1482 1482 1483 1483 [[image:image-20220709165402-21.png]] 1484 - 1485 -= **2.7 Mysql** =
- InputHTTPparameter.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Hunter - Size
-
... ... @@ -1,1 +1,0 @@ 1 -17.9 KB - Content