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, 1 added, 0 removed)
Details
- Page properties
-
- Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. admin1 +XWiki.Hunter - Content
-
... ... @@ -13,7 +13,7 @@ 13 13 for example. addr_setshort(addr,num) Function: Write 16-bit signed decimal address 14 14 addr_getshort(addr) Function:Read 16-bit signed decimal address 15 15 addr_getword(string addr)Function: Read 16-bit unsigned decimal address 16 -More script function are in the second section of [[“V-BOX Script Interface Manual”>>doc:V-BOX.V-Net. 1\.UserManual.04 Lua Script.01 Lua Functions.WebHome]]16 +More script function are in the second section of [[“V-BOX Script Interface Manual”>>doc:V-BOX.V-Net.Manual.04 Lua Script.01 Lua Functions.WebHome]] 17 17 18 18 == **1.2 Arithmetic** == 19 19 ... ... @@ -36,39 +36,46 @@ 36 36 37 37 Script is as below: 38 38 39 -{{code language="Lua"}} 39 +(% class="box infomessage" %) 40 +((( 40 40 function sms.main() 41 -------send condition------ 42 +~-~-~-~-~-~-send condition~-~-~-~-~-~- 42 42 local temp1 = addr_getword("@Temperature1") 43 43 local temp2 = addr_getword("@Temperature2") 44 44 local temp3 = addr_getword("@Temperature3") 45 45 local timer = addr_getword("@Timer") 46 46 local tag = addr_getbit("@Tag") 47 -------lasting time------ 48 +~-~-~-~-~-~-lasting time~-~-~-~-~-~- 48 48 if temp1 > 5 and temp2 > 10 and temp3 < 20 then 49 - timer = timer + 1 50 - addr_setword("@Timer",timer) 50 + timer = timer + 1 51 + addr_setword("@Timer",timer) 51 51 else 52 - timer = 0 53 - addr_setword("@Timer",timer) 53 + timer = 0 54 + addr_setword("@Timer",timer) 54 54 end 55 -------send sms & output Y0------ 56 +~-~-~-~-~-~-send sms & output Y0~-~-~-~-~-~- 56 56 if timer > 5 then 57 - if tag == 0 then 58 - send_sms_ira("19859254700","alarm trigger") 59 - addr_setbit("@Tag",1) 60 - end 58 + if tag == 0 then 59 + send_sms_ira("19859254700","alarm trigger") 60 + addr_setbit("@Tag",1) 61 + end 61 61 elseif tag == 1 then 62 62 send_sms_ira("19859254700","alarm release") 63 63 addr_setbit("@Tag",0) 64 64 end 65 65 end 66 - {{/code}}67 +))) 67 67 68 68 == **1.5 Telegram notification** == 69 69 70 70 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. 71 71 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 + 72 72 {{code language="Lua"}} 73 73 local tempBit = 0 74 74 local tempWord = 0 ... ... @@ -134,7 +134,210 @@ 134 134 end 135 135 {{/code}} 136 136 144 +== **1.6 LINE Notify** == 137 137 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 +{{code language="Lua"}} 228 +local tempBit = 0 229 +local tempWord = 0 230 + 231 +local https = require("https") 232 +local json = require("json") 233 +local ltn12 = require("ltn12") 234 + 235 +local SID = 'AC1703bd710ffa98006d2bcc0b********' 236 +local Token = 'd3c11897623c39e538b20263ec19****' 237 + 238 +local twilioPhoneNumber = '+14155238886' 239 +local receiverPhoneNumber = '+8615880018277' 240 + 241 +local b='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' 242 +function encodingBase64(data) 243 + return ((data:gsub('.', function(x) 244 + local r,b='',x:byte() 245 + for i=8,1,-1 do r=r..(b%2^i-b%2^(i-1)>0 and '1' or '0') end 246 + return r; 247 + end)..'0000'):gsub('%d%d%d?%d?%d?%d?', function(x) 248 + if (#x < 6) then return '' end 249 + local c=0 250 + for i=1,6 do c=c+(x:sub(i,i)=='1' and 2^(6-i) or 0) end 251 + return b:sub(c+1,c+1) 252 + end)..({ '', '==', '=' })[#data%3+1]) 253 +end 254 + 255 +function encodeUrl(str) 256 + str = string.gsub(str, "([^%w%.%- ])", function(c) 257 + return string.format("%%%02X", string.byte(c)) end) 258 + return string.gsub(str, " ", "+") 259 +end 260 + 261 + 262 + 263 + 264 +function requestBodySplice(message, sender, receiver) 265 + local reqBody = '' 266 + local encodeMess = encodeUrl(message) 267 + local encodeSend = encodeUrl(sender) 268 + local encodeRece = encodeUrl(receiver) 269 + --reqBody = "Body=Hello%20Wecon2&From=whatsapp%3A%2B14155238886&To=whatsapp%3A%2B8615880018277" 270 + reqBody = string.format("Body=%s&From=whatsapp:%s&To=whatsapp:%s", encodeMess, encodeSend, encodeRece) 271 + print(reqBody) 272 + return reqBody 273 +end 274 + 275 + 276 +-- Send http.get request and return response result 277 +function getHttpsUrl(url,header,reqbody) 278 + local body = {} 279 + local bodyJson = json.encode(body) 280 + local result_table, code, headers, status = https.request{ 281 + method = "POST", 282 + url = url, 283 + source = ltn12.source.string(reqbody), 284 + headers = header, 285 + sink = ltn12.sink.table(body) 286 + } 287 + print("code:"..code) 288 + if code~= 200 then 289 + return 290 + else 291 + return body 292 + end 293 +end 294 + 295 +function getMessageUrl(whatsAppMessage) 296 + local auth = SID..':'..Token 297 + local url = "https://api.twilio.com/2010-04-01/Accounts/"..SID.."/Messages" 298 + --local reqMess = "message="..twilioMessage 299 + local reqMess = requestBodySplice(whatsAppMessage, twilioPhoneNumber, receiverPhoneNumber) 300 + local headers = 301 + { 302 + ["Authorization"] = "Basic "..encodingBase64(auth), 303 + ["Content-Type"] = "application/x-www-form-urlencoded", 304 + ["Content-Length"] = #reqMess 305 + } 306 + 307 + print("Get the link:"..url) 308 + getHttpsUrl(url, headers, reqMess) 309 +end 310 + 311 + 312 + 313 +function Twilio.main() 314 + --dosomething 315 + --local auth = SID..':'..Token 316 + --print(requestBodySplice("HelloWorld", twilioPhoneNumber, receiverPhoneNumber)) 317 + --print(encodingBase64(auth)) 318 + local bitValue = addr_getbit("@testBit"); 319 + local message = '' 320 + print("b=="..bitValue) 321 + if bitValue == 1 and bitValue ~= tempBit then 322 + message = 'Alarm V-Box triggered, the output is '.. bitValue 323 + getMessageUrl(message) 324 + print("Notification pushed of triggering alarm,"..bitValue) 325 + elseif bitValue == 0 and bitValue ~= tempBit then 326 + message = 'Alarm V-Box dismissed, the output is '.. bitValue 327 + getMessageUrl(message) 328 + print("Notification pushed of dismissing alarm,"..bitValue) 329 + end 330 + tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform 331 + 332 + local wordValue = addr_getword("@testWord") 333 + print("w=="..wordValue) 334 + --dosomething 335 + if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then 336 + message = 'Alarm V-Box triggered, the temperature is '.. wordValue 337 + getMessageUrl(message) 338 + print("Notification pushed of triggering alarm,"..wordValue) 339 + elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then 340 + message = 'Alarm V-Box dismissed, the temperature is '.. wordValue 341 + getMessageUrl(message) 342 + print("Notification pushed of dismissing alarm,"..wordValue) 343 + end 344 + tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform 345 +end 346 +{{/code}} 347 + 138 138 = **2 V-Box connect with third part server** = 139 139 140 140 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. ... ... @@ -153,13 +153,137 @@ 153 153 154 154 (% class="mark" %)2.If your server requires SSL certificate to log in,please use OpenCloud.Because only OpenCloud platform can support to upload certificate 155 155 156 -== **2.1 V-Box connect with customer server:grouprobotinfo.com** == 366 +(% class="wikigeneratedid" %) 367 +**✎Note: **Before program the script of MQTT, please make sure the server(MQTT broker) can be connected through MQTT Client tool. 157 157 369 +(% class="wikigeneratedid" %) 370 +Tool link: **[[MQTT.fx>>http://mqttfx.jensd.de/index.php/download]]** 371 + 372 +== **2.1 V-Box connect with test server(General Example)** == 373 + 374 +{{code language="lua"}} 375 +--MQTT configuration table 376 +local MQTT_CFG={} 377 +MQTT_CFG.username = "weconsupport" 378 +MQTT_CFG.password = "123456" 379 +MQTT_CFG.netway = 0 380 +MQTT_CFG.keepalive = 60 381 +MQTT_CFG.cleansession = 1 382 +--TCP URL 383 +MQTT_URL = "tcp://mq.tongxinmao.com:1883" 384 +--Client ID 385 +MQTT_CLIENT_ID = "V-BOXH-AG" 386 + 387 +--Generate UUID 388 +function uuid() 389 + local seed = {'e','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} 390 + local tb = {} 391 + for i=1, 32 do 392 + table.insert(tb, seed[math.random(1,16)]) 393 + end 394 + local sid=table.concat(tb) 395 + return string.format('%s', 396 + string.sub(sid,1,32) 397 + ) 398 +end 399 + 400 + 401 +--Topic name to subscribed 402 +local SUBSCRIBE_TOPIC = 'testtopic/test/no1/123456' 403 + 404 +--Topic name to be published 405 +local PUBLISH_TOPIC = 'testtopic/test/no1/7890' 406 + 407 + 408 +--real time 409 +local LAST_TIME = 0 410 + 411 + 412 +--initialize mqtt 413 +function mqtt_init() 414 + print(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENT_ID)) 415 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENT_ID) -- create mqtt object,and declare it as a global variable 416 + if g_mq then 417 + g_mq:on("message", mqtt_msg_callback) -- Register a callback for receiving messages 418 + print("mqtt init success") 419 + else 420 + print("mqtt init failed:", err) 421 + end 422 +end 423 + 424 +-- connect to mqtt 425 +function mqtt_connect() 426 + print("mqtt connecting...") 427 + local stat, err = g_mq:connect(MQTT_CFG) 428 + if stat == nil then 429 + print("mqtt connect failed:", err) 430 + return 431 + else 432 + print("mqtt connected") 433 + end 434 + g_mq:subscribe(SUBSCRIBE_TOPIC, 0) 435 +end 436 + 437 +-- Received message callback function 438 +function mqtt_msg_callback(topic, msg) 439 + print("topic:", topic) 440 + print("msg:", msg) 441 + local objMsg = json.decode(msg) 442 + local water = objMsg.data.waterlevel 443 + local temp = objMsg.data.temperature 444 + addr_setword("@HDW20",water) 445 + addr_setword("@HDW10",temp) 446 +end 447 + 448 +--Send data (data upload to platform and encapsulate it with custom functions) 449 +function send_data() 450 + local pub_data = { 451 + timestamp = os.time(), 452 + messageId = 1, 453 + event = 'test_data', 454 + mfrs = 'V-Box', 455 + data = { 456 + id = uuid(), 457 + waterlevel = addr_getword("@HDW10"), 458 + temperature = addr_getword("@HDW20") 459 + } 460 + } 461 + return g_mq:publish(PUBLISH_TOPIC, json.encode(pub_data), 0, 0) 462 +end 463 + 464 + 465 +--main function fixed timed execution 466 +function MQTT.main() 467 + --dosomething 468 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main start") 469 + --determine the mqtt object whether exist 470 + if g_mq then 471 + --determine the mqtt object whether has been connected or not 472 + if g_mq:isconnected() then 473 + send_data() 474 + else 475 + --if exceed 20 sec not connect, reconnect once 476 + if os.time() - LAST_TIME > 20 then 477 + LAST_TIME = os.time() 478 + --connect to mqtt or reconnect 479 + mqtt_connect() 480 + end 481 + end 482 + else 483 + --mqtt object does not exist so create new one 484 + mqtt_init() 485 + end 486 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main end") 487 +end 488 +{{/code}} 489 + 490 +== **2.2 V-Box connect with customer server:grouprobotinfo.com** == 491 + 158 158 This demo does not use SSL certification. Script is as below 159 159 160 160 Demo1: 161 161 162 -{{code language=" Lua"}}496 +{{code language="lua"}} 163 163 -- Meta class 164 164 --main 165 165 function mq.main() ... ... @@ -280,7 +280,7 @@ 280 280 FSE=addr_getbit("@B_25395#W2.04"), 281 281 AVVSVV=addr_getbit("@B_25395#W1.12"), 282 282 ICHT=addr_getbit("@B_25395#W3.06") 283 - 617 + 284 284 } 285 285 286 286 -- ("@B_25395#CIO1.02") ... ... @@ -302,7 +302,7 @@ 302 302 end 303 303 {{/code}} 304 304 305 -== **2. 2V-Box connect with Azure platform** ==639 +== **2.3 V-Box connect with Azure platform** == 306 306 307 307 In this demo,V-Box connects with Azure by SSL certification. 308 308 ... ... @@ -312,137 +312,129 @@ 312 312 313 313 Script is as below 314 314 315 -{{code language="Lua"}} 316 ---https://support.huaweicloud.com/qs-IoT/iot_05_0005.html mqtt.fx monitor to connect azure iot 649 +(% class="box infomessage" %) 650 +((( 651 +~-~-https:~/~/support.huaweicloud.com/qs-IoT/iot_05_0005.html mqtt.fx monitor to connect azure iot 317 317 sprint = print 318 318 319 ---Get custom configuration parameters (vbox custom information) 320 ---local CUSTOM = bns_get_config("bind") 321 ---local DS_ID = CUSTOM.DSID or "60a71ccbbbe12002c08f3a1a_WECON" 654 +~-~-Get custom configuration parameters (vbox custom information) 655 +~-~-local CUSTOM = bns_get_config("bind") 656 +~-~-local DS_ID = CUSTOM.DSID or "60a71ccbbbe12002c08f3a1a_WECON" 322 322 323 323 324 - 325 ---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) 659 +~-~-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) 326 326 local MQTT_URL, MQTT_CLIENTID, MQTT_CFG, MQTT_LWT, MQTT_CART = mqtt.setup_cfg() 327 327 328 ---MQTT_CFG.username = '60a71ccbbbe12002c08f3a1a_WECON' 329 ---MQTT_CFG.password='wecon123' 330 ---MQTT_CLIENTID = '60a71ccbbbe12002c08f3a1a_WECON_0_0_2021052110usernxame:60a71ccbbbe12002c08f3a1a_WECONpassword:a0a951581855aa8e0262129da6cf1b43f2c0ecfac4fa56117fc5a20c90be169a' 662 +~-~-MQTT_CFG.username = '60a71ccbbbe12002c08f3a1a_WECON' 663 +~-~-MQTT_CFG.password='wecon123' 664 +~-~-MQTT_CLIENTID = '60a71ccbbbe12002c08f3a1a_WECON_0_0_2021052110usernxame:60a71ccbbbe12002c08f3a1a_WECONpassword:a0a951581855aa8e0262129da6cf1b43f2c0ecfac4fa56117fc5a20c90be169a' 331 331 332 ---publish to topics 666 +~-~-publish to topics 333 333 local pub_RE_TOPIC = string.format('devices/wecon_02/messages/events/') 334 ---Subscribe topics 668 +~-~-Subscribe topics 335 335 local Subscribe_RE_TOPIC1 = string.format('devices/wecon_02/messages/devicebound/#') 336 336 337 ---variable 671 +~-~-variable 338 338 local last_time = 0 339 339 340 340 341 - 342 ---Timing main function 675 +~-~-Timing main function 343 343 function Azure.main() 344 344 345 - 346 - 347 - 348 - 349 - 350 - 351 - 352 - 353 - 354 - 355 - 356 - 357 - 358 - 678 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main start") 679 + if g_mq then 680 + if g_mq:isconnected() then 681 + send_Data() 682 + else 683 + if os.time() - last_time > 20 then 684 + last_time = os.time() 685 + mymqtt_connect() 686 + end 687 + end 688 + else 689 + mymqtt_init() 690 + end 691 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main end") 359 359 end 360 360 361 --- Initialize MQTT 694 +~-~- Initialize MQTT 362 362 function mymqtt_init() 363 - 364 - 365 - 366 - 367 - 368 - 369 - 370 - 696 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID)) 697 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable 698 + if g_mq then 699 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks 700 + sprint("mqtt init success") 701 + else 702 + sprint("mqtt init failed:", err) 703 + end 371 371 end 372 372 373 --- Connect to MQTT server 706 +~-~- Connect to MQTT server 374 374 function mymqtt_connect() 375 - 376 - 377 - 378 - 379 - 380 - 381 - 382 - 383 - 708 + sprint("mqtt connecting...") 709 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 710 + if stat == nil then 711 + sprint("mqtt connect failed:", err) 712 + return 713 + else 714 + sprint("mqtt connected") 715 + end 716 + g_mq:subscribe(Subscribe_RE_TOPIC1, 0) 384 384 end 385 385 386 --- Receive MQTT message callback function 719 +~-~- Receive MQTT message callback function 387 387 function mymqtt_msg_callback(topic, msg) 388 - 389 - 390 - 391 - 392 --- if string.match(topic,Subscribe_RE_TOPIC1) then 393 - 394 - 395 - 721 + print("topic:",topic) 722 + print("revdata:",msg) 723 + ~-~- local revData = json.decode(msg) 724 + ~-~- if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud 725 +~-~- if string.match(topic,Subscribe_RE_TOPIC1) then 726 + ~-~- print("topi11:",topic) 727 + setValue(revData) 728 + ~-~- end 396 396 end 397 397 398 ---Process the received data 399 ---function setValue(revData) 400 - 401 - 402 - 403 - 404 - 405 ---end 731 +~-~-Process the received data 732 +~-~-function setValue(revData) 733 + ~-~- if revData ~~=nil then 734 + ~-~- for i,v in pairs(revData) do 735 + ~-~- print("Data received:",i,v) 736 + ~-~- end 737 + ~-~- end 738 +~-~-end 406 406 407 ---Get real-time data 740 +~-~-Get real-time data 408 408 function getData() 409 - 410 - 411 - 412 - 413 - 414 - 415 - 416 - 417 - 418 -end 742 + local jdata = {} 743 + local addr = bns_get_alldata() 744 + print(json.encode(addr)) 745 + for i,v in pairs(addr) do 746 + if v[2] == 1 then 747 + jdata[v[3]] = v[4] 748 + end 749 + end 750 + return jdata 751 +end 419 419 420 420 421 - 422 ---send data 754 +~-~-send data 423 423 function send_Data() 424 - local pub_data = {100 425 - -- services={{ 426 - 427 - --serviceId ='Temperature', 428 - -- properties={ 429 - -- value = 55 430 - -- }, 431 - -- }} 756 + local pub_data = {100 757 + ~-~- services=~{~{ 758 +\\ ~-~-serviceId ='Temperature', 759 + ~-~- properties={ 760 + ~-~- value = 55 761 + ~-~- }, 762 + ~-~- }} 432 432 } 433 433 sprint(json.encode(pub_data)) 434 434 print("..........",pub_RE_TOPIC) 435 - 766 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0) 436 436 end 437 -{{/code}} 438 - 439 -== **2.3 How to configure the Huawei platform?** == 440 - 441 -(% class="box infomessage" %) 442 -((( 443 -✎Note: Huawei IOT DA function is only in China area.If you want this function,you need to use chinese mobile to register 444 444 ))) 445 445 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)** == 771 + 446 446 1.Register a account: [[https:~~/~~/www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ>>https://www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ]] 447 447 448 448 2.log in the Huawei IOTDA ... ... @@ -590,7 +590,7 @@ 590 590 (% style="text-align:center" %) 591 591 [[image:1624441186851-536.png||height="434" width="700" class="img-thumbnail"]] 592 592 593 -== **2. 4V-Box connect with Huawei platform** ==919 +== **2.5 V-Box connect with Huawei platform** == 594 594 595 595 In this demo,V-Box connects with Huawei by SSL certification. 596 596 ... ... @@ -711,7 +711,7 @@ 711 711 (% style="text-align:center" %) 712 712 [[image:1624506666650-161.png||height="547" width="1000" class="img-thumbnail"]] 713 713 714 -== **2. 5V-Box connect with AWS platform** ==1040 +== **2.6 V-Box connect with AWS platform** == 715 715 716 716 === **Log in AWS** === 717 717 ... ... @@ -768,99 +768,67 @@ 768 768 } 769 769 {{/code}} 770 770 771 - 1.**Create things**1097 +=== **Create things** === 772 772 773 773 Click “Manage”~-~-->“Things”~-~-->“Create things”~-~-->“Create single thing” 774 774 1101 +[[image:image-20220709165402-6.png]] 775 775 776 -| 777 -| |[[image:image-20220709165402-6.png]] 1103 +[[image:image-20220709165402-7.png]] 778 778 779 -| 780 -| |[[image:image-20220709165402-7.png]] 781 - 782 -| 783 -| |[[image:image-20220709165402-8.png]] 784 - 785 785 Name the thing~-~-->Click “Next” 786 786 1107 +[[image:image-20220709165402-8.png]] 787 787 788 788 Select the way to create certificate 789 789 1111 +[[image:image-20220709165402-9.png]] 790 790 791 -| 792 -| |[[image:image-20220709165402-9.png]] 793 - 794 794 Select policy 795 795 1115 +[[image:image-20220709165402-10.png]] 796 796 797 -| 798 -| |[[image:image-20220709165402-10.png]] 1117 +[[image:image-20220709165402-11.png]] 799 799 800 800 1120 +=== **Test with MQTT.fx tool** === 801 801 802 - 803 - 804 -| 805 -| |[[image:image-20220709165402-11.png]] 806 - 807 - 808 -1. **Test with MQTT.fx tool** 809 - 810 810 Click “View Setting” to get the “Broker Adress” 811 811 1124 +[[image:image-20220709165402-13.png]] 812 812 813 -| 814 -| |[[image:image-20220709165402-12.png]] 1126 +[[image:image-20220709165402-12.png]] 815 815 816 -| 817 -| |[[image:image-20220709165402-13.png]] 818 - 819 - 820 - 821 - 822 -| 823 -| |[[image:image-20220709165402-14.png]] 824 - 825 825 Create one connection in MQTT.fx tool, set broker port as 8883. 826 826 1130 +[[image:image-20220709165402-14.png]] 1131 + 827 827 Upload the CA File, Client Certificate File, Client Key File 828 828 1134 +[[image:image-20220709165402-15.png]] 829 829 830 -| 831 -| |[[image:image-20220709165402-15.png]] 832 - 833 833 Publish message to topic “TEST” 834 834 1138 +[[image:image-20220709165402-17.png]] 835 835 836 -| 837 -| |[[image:image-20220709165402-16.png]] 838 - 839 -| 840 -| |[[image:image-20220709165402-17.png]] 841 - 842 842 Click”Test”~-~-->”MQTT test client”~-~-->”Subscrible to a topic”, to get message publish from MQTT.fx tool. 843 843 1142 +[[image:image-20220709173500-1.png]] 1143 + 844 844 And we can also send message form AWS platform to MQTT.fx tool. 845 845 1146 +[[image:image-20220709165402-18.png]] 846 846 847 -| 848 -| |[[image:image-20220709165402-18.png]] 1148 +=== **Configurate in CloudTool** === 849 849 850 -1. **Configurate in CloudTool** 851 - 852 852 Copy the same setting in MQTT.fx to MQTT configuration 853 853 1152 +[[image:image-20220709165402-19.png]] 854 854 855 -| 856 -| |[[image:image-20220709165402-19.png]] 857 - 858 858 Add a lua script and copy the lua demo into it. 859 859 1156 +[[image:image-20220709165402-20.png]] 860 860 861 -| 862 -| |[[image:image-20220709165402-20.png]] 863 - 864 864 sprint = print 865 865 866 866 ~-~-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) ... ... @@ -1041,10 +1041,6 @@ 1041 1041 1042 1042 end 1043 1043 1044 - 1045 - 1046 1046 Get message in AWS 1047 1047 1048 - 1049 -| 1050 -| |[[image:image-20220709165402-21.png]] 1340 +[[image:image-20220709165402-21.png]]
- image-20220709173500-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Jim - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.5 MB - Content