Changes for page 2 Script
Last modified by Devin Chen on 2025/06/06 14:03
From version 62.1
edited by Theodore Xu
on 2023/08/24 17:27
on 2023/08/24 17:27
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,7 +58,7 @@ 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 ... ... @@ -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"}}148 +{{code}} 143 143 local tempBit = 0 144 144 local tempWord = 0 145 145 ... ... @@ -218,10 +218,6 @@ 218 218 219 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 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 225 {{code language="Lua"}} 226 226 local tempBit = 0 227 227 local tempWord = 0 ... ... @@ -343,137 +343,8 @@ 343 343 end 344 344 {{/code}} 345 345 346 -= =**1.8HTTPresponsebody** ==348 += **2 V-Box connect with third part server** = 347 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}}366 +(% 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)** ==372 +== **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 > 5then475 + --if exceed 20 sec not connect, reconnect once 476 + 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** ==490 +== **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 - 500 + if not mq.m then 501 + 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")) 503 + mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 504 + if mq.m then 505 + mq.config = { 506 + username = "",-- ID 507 + password = "",-- password 508 + netway = 1, -- Ethernet connection, WIFI=1 509 + -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 510 + -- cleansession = 0, -- Optional, keep session 511 + } 512 + mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 513 + local str = string.format("%s:%s", topic, msg) 514 + -- print("mqtt msg:", str) -- Print out the received topics and content 515 + end 516 + ) 517 + mq.m:on("offline", function (cause) -- Register for lost connection callbacks 518 + -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 519 + end) 520 + mq.m:on("arrived", function() -- Registration for sending messages to callbacks 521 + print("msg arrived") 522 + end) 523 + else 524 + print("mqtt create failed:", err) -- Create object failed 525 + end 526 + else 527 + if mq.m:isconnected() then -- If online, post a message 528 + local phaseStatus ="unknow" 529 + if addr_getbit("@Standby")== 1 then 530 + phaseStatus = "Standby" 531 + elseif addr_getbit("@Pre-Freeze")==1 then 532 + phaseStatus= "Pre-Freeze" 533 + elseif addr_getbit("@Prepare")==1 then 534 + phaseStatus ="Prepare" 535 + elseif addr_getbit("@Primary Dry")==1 then 536 + phaseStatus = "Primary dry" 537 + elseif addr_getbit("@Secondary Dry")==1 then 538 + phaseStatus = "Secondary Dry" 539 + end 540 +-- 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, 542 + local activating ="unknow" 543 + if addr_getbit("@Compressor")==1 then 544 + activating = ",".."Compressor" 545 + end 546 + if addr_getbit("@Silicone Pump")==1 then 547 + activating = activating..",".."Silicone Pump" 548 + end 549 + if addr_getbit("@Vacuum Pump")==1 then 550 + activating = activating..",".."Vacuum Pump" 551 + end 552 + if addr_getbit("@Root Pump")==1 then 553 + activating = activating..",".."Root Pump" 554 + end 555 + if addr_getbit("@Heater")==1 then 556 + activating = activating..",".."Heater" 557 + end 558 + if addr_getbit("@Valve Silicone")==1 then 559 + activating = activating..",".."Valve Silicone" 560 + end 561 + if addr_getbit("@Valve Ice Condenser")==1 then 562 + activating = activating..",".."Valve Ice Condenser" 563 + end 564 + if addr_getbit("@Valve Vacuum Pump")==1 then 565 + activating = activating..",".."Valve Vacuum Pump" 566 + end 567 + local pr_activating =string.sub(activating,2) 568 + -- 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 571 + 572 + local status_text ="unknow" 573 + if addr_getbit("@Status Run")==1 then 574 + status_text = "RUNNING" 575 + else 576 + status_text = "STOP" 577 + end 578 +------------------------------------------------------------------------------------------------------------------------- 579 + 580 + local js = {type="status", 581 + mc_name ="FD300", 582 + status=status_text, 583 + elapsed_time={ 584 + hour=addr_getword("@Elapsed Time (Hour)"), 585 + min=addr_getword("@Elapsed Time (Minute)"), 586 + sec=addr_getword("@Elapsed Time (Second)") 587 + }, 588 + phase = phaseStatus, 589 + step = addr_getword("@Step"), 590 + activating_output = pr_activating, 591 + sv=addr_getshort("@SV Silicone")/10, 592 + pv=addr_getshort("@PV Silicone")/10, 593 + product1=addr_getshort("@Product 1")/10, 594 + 595 + product2=addr_getshort("@Product 2")/10, 596 + product3=addr_getshort("@Product 3")/10, 597 + product4=addr_getshort("@Product 4")/10, 598 + ice1=addr_getshort("@Ice condenser 1")/10, 599 + ice2=addr_getshort("@Ice condenser 2")/10, 600 + vacuum=addr_getfloat("@Vacuum") 601 + 602 + } 603 + local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 604 + ODPC = addr_getbit("@B_25395#W0.01"), 605 + MTPC=addr_getbit("@B_25395#W0.02"), 606 + HTT = addr_getbit("@B_25395#W1.03"), 607 + CPC = addr_getbit("@B_25395#W0.08"), 608 + CPSP =addr_getbit("@B_25395#W1.00"), 609 + CPVP =addr_getbit("@B_25395#W0.10"), 610 + CPRP =addr_getbit("@B_25395#W0.11"), 611 + HP =addr_getbit("@B_25395#W1.01"), 612 + PP= addr_getbit("@B_25395#W1.02"), 613 + PO=addr_getbit("@B_25395#W0.07"), 614 + FSE=addr_getbit("@B_25395#W2.04"), 615 + AVVSVV=addr_getbit("@B_25395#W1.12"), 616 + ICHT=addr_getbit("@B_25395#W3.06") 617 + 618 + } 619 + 620 + -- ("@B_25395#CIO1.02") 621 + mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 622 + mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 623 + else 624 + local stat, err = mq.m:connect(mq.config) -- connection 625 + if stat == nil then --Determine whether to connect 626 + print("mqtt connect failed:", err) 627 + return -- Connection failed, return directly 628 + end 629 + mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 630 + 631 + end 632 + -- mq.m:unsubscribe("stc/test") 633 + -- mq.m:disconnect() -- close matt 634 + -- mq.m:close() -- close clase 635 + end 787 787 end 788 788 {{/code}} 789 789 790 -== **2.3 Azure platform** == 639 +== **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** == 770 +== **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.===919 +== **2.5 V-Box connect with Huawei platform** == 1075 1075 921 +In this demo,V-Box connects with Huawei by SSL certification. 922 + 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** == 1040 +== **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 { 1065 + 1218 1218 "Version": "2012-10-17", 1067 + 1219 1219 "Statement": [ 1069 + 1220 1220 { 1071 + 1221 1221 "Effect": "Allow", 1073 + 1222 1222 "Action": [ 1075 + 1223 1223 "iot:Connect", 1077 + 1224 1224 "iot:Publish", 1079 + 1225 1225 "iot:Subscribe", 1081 + 1226 1226 "iot:Receive", 1083 + 1227 1227 "greengrass:Discover" 1085 + 1228 1228 ], 1087 + 1229 1229 "Resource": "*" 1089 + 1230 1230 } 1091 + 1231 1231 ] 1093 + 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** === 1120 +=== **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** === 1148 +=== **Configurate in CloudTool** === 1287 1287 1288 1288 Copy the same setting in MQTT.fx to MQTT configuration 1289 1289 ... ... @@ -1293,255 +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) 1160 +~-~-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 1164 +~-~-publish to topics 1308 1308 1309 1309 local pub_RE_TOPIC = string.format('TEST') 1310 1310 1311 ---Subscribe topics 1168 +~-~-Subscribe topics 1312 1312 1313 1313 local Subscribe_RE_TOPIC1 = string.format('TEST') 1314 1314 1315 ---variable 1172 +~-~-variable 1316 1316 1317 1317 local last_time = 0 1318 1318 1319 ---Timing main function 1176 +~-~-Timing main function 1320 1320 1321 1321 function aws.main() 1322 1322 1323 - 1180 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start") 1324 1324 1325 - 1182 + if g_mq then 1326 1326 1327 - 1184 + if g_mq:isconnected() then 1328 1328 1329 - 1186 + send_Data() 1330 1330 1331 - 1188 + else 1332 1332 1333 - 1190 + if os.time() - last_time > 5 then 1334 1334 1335 - 1192 + last_time = os.time() 1336 1336 1337 - 1194 + mymqtt_connect() 1338 1338 1339 - end 1340 - 1341 1341 end 1342 1342 1343 - lse1198 + end 1344 1344 1345 - mymqtt_init()1200 + else 1346 1346 1347 - end1202 + mymqtt_init() 1348 1348 1349 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.mainend")1204 + end 1350 1350 1206 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end") 1207 + 1351 1351 end 1352 1352 1353 1353 1211 +~-~- Initialize MQTT 1354 1354 1355 --- Initialize MQTT 1356 - 1357 1357 function mymqtt_init() 1358 1358 1359 - 1215 + 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 connect1217 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable 1362 1362 1363 - 1219 + if g_mq then 1364 1364 1365 - 1221 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks 1366 1366 1367 - 1223 + sprint("mqtt init success") 1368 1368 1369 - 1225 + else 1370 1370 1371 - 1227 + sprint("mqtt init failed:", err) 1372 1372 1373 - 1229 + end 1374 1374 1375 1375 end 1376 1376 1377 --- Connect to MQTT server 1233 +~-~- Connect to MQTT server 1378 1378 1379 1379 function mymqtt_connect() 1380 1380 1381 - 1237 + sprint("mqtt connecting...") 1382 1382 1383 - 1239 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 1384 1384 1385 - 1241 + if stat == nil then 1386 1386 1387 - 1243 + sprint("mqtt connect failed:", err) 1388 1388 1389 - 1245 + return 1390 1390 1391 - 1247 + else 1392 1392 1393 - 1249 + sprint("mqtt connected") 1394 1394 1395 - 1251 + end 1396 1396 1397 - Subscribe_RE_TOPIC1, 0)1253 + g_mq:subscribe(TEST, 0) 1398 1398 1399 1399 end 1400 1400 1401 --- Receive MQTT message callback function 1257 +~-~- Receive MQTT message callback function 1402 1402 1403 1403 function mymqtt_msg_callback(topic, msg) 1404 1404 1405 - 1261 + print("topic:",topic) 1406 1406 1407 - 1263 + print("revdata:",msg) 1408 1408 1409 - 1265 + local revData = json.decode(msg) 1410 1410 1411 - 1267 + print (revData) 1412 1412 1413 - 1269 + if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud 1414 1414 1415 - 1271 +if string.match(topic,Subscribe_RE_TOPIC1) then 1416 1416 1417 - 1273 + ~-~-if revData ~~= nil then 1418 1418 1419 - 1275 + for k,v in pairs (revData) do 1420 1420 1421 - 1277 + print("printing revdata after kv here") 1422 1422 1423 - 1279 + print (k,v) 1424 1424 1425 - 1281 + end 1426 1426 1427 - 1283 + print ("current state is",fanstate) 1428 1428 1429 - 1285 + ~-~-end 1430 1430 1431 - 1287 +end 1432 1432 1433 - 1289 +end 1434 1434 1435 1435 end 1436 1436 1437 1437 1294 +~-~-Get real-time data 1438 1438 1439 ---Get real-time data 1440 - 1441 1441 function getData() 1442 1442 1443 - 1298 + local jdata = {} 1444 1444 1445 - 1300 + local addr = bns_get_alldata() 1446 1446 1447 - 1302 + print(json.encode(addr)) 1448 1448 1449 - 1304 + for i,v in pairs(addr) do 1450 1450 1451 - 1306 + if v[2] == 1 then 1452 1452 1453 - 1308 + jdata[v[3]] = v[4] 1454 1454 1455 - 1310 + end 1456 1456 1457 - 1312 + end 1458 1458 1459 - 1314 + return jdata 1460 1460 1461 1461 end 1462 1462 1463 ---send data 1318 +~-~-send data 1464 1464 1465 1465 function send_Data() 1466 1466 1467 - local pub_data = 1468 - { 1469 - 123 1470 - } 1322 + local pub_data = 1471 1471 1324 + { 1325 + 1326 +123 1327 + 1328 +} 1329 + 1472 1472 sprint(json.encode(pub_data)) 1473 1473 1474 1474 print("..........",pub_RE_TOPIC) 1475 1475 1476 - 1334 + 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** = 1486 - 1487 - 1488 - 1489 -=== 1.Install Mysql software === 1490 - 1491 -Download the latest version of Mysql. 1492 - 1493 -(% style="text-align:center" %) 1494 -[[image:Mysql的软件版本.png||height="673" width="894"]] 1495 - 1496 -=== 2.Navicat connect Mysql === 1497 - 1498 -Connecting to Mysql with navicat. 1499 - 1500 -(% style="text-align:center" %) 1501 -[[image:连接到mysql.png]] 1502 - 1503 -=== 3.Create a database === 1504 - 1505 -Character set should be choose utf8mb3/utf8mb4 and Collation choose utf8mb3_danish_ci/utf8mb4_danish_ci. 1506 - 1507 -(% style="text-align:center" %) 1508 -[[image:创建数据库.png||height="585" width="818"]] 1509 - 1510 -=== 4.Create a data table === 1511 - 1512 -Create a table, enter the fields you need. 1513 - 1514 -(% style="text-align:center" %) 1515 -[[image:创建表1.png||height="484" width="737"]] 1516 - 1517 -Save, enter table name. 1518 - 1519 -(% style="text-align:center" %) 1520 -[[image:创建表2.png]] 1521 - 1522 -=== 5.Input Table Data === 1523 - 1524 -(% style="text-align:center" %) 1525 -[[image:输入或者导入数据.png]] 1526 - 1527 -=== 6.Modifying scripts and debug:**[[Mysql script>>https://docs.we-con.com.cn/bin/view/V-BOX/V-Net/Manual/04%20Lua%20Script/01%20Lua%20Functions/\#H11MySQLdatabaseoperation]]** === 1528 - 1529 -(% style="text-align:center" %) 1530 -[[image:调试结果.png]] 1531 - 1532 -=== 7.Problem === 1533 - 1534 -During our debugging process it may there are some problems about Mysql, such as 1535 - 1536 -* MySQL: Host 192.168.XXX.XXX is not allowed to connect. 1537 -* MySQL: Host 192.168.XXX.XXX is blocked because of many connection errors. 1538 -* MySQL: SSL connection error: unknown error number. 1539 -* ((( 1540 -1449-The user specified as a definer(‘mysql.infoschema‘@localhost‘) does not exist. 1541 -))) 1542 - 1543 -This type of problem has nothing to do with scripts or devices, it is a Mysql configuration issue. If you have any of these problems, please look for a solution online. 1544 - 1545 -{{info}} 1546 -✎Note: If you want to use CMD to access Mysql, you need to add the bin file to the environment variable, please check online for details of the operation. 1547 -{{/info}}
- InputHTTPparameter.png
-
- Author
-
... ... @@ -1,1 +1,0 @@ 1 -XWiki.Hunter - Size
-
... ... @@ -1,1 +1,0 @@ 1 -17.9 KB - Content