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, 2 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,312 @@ 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 +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 + 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,157 +153,285 @@ 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** == 468 +{{info}} 469 +**✎Note: **Before program the script of MQTT, please make sure the server(MQTT broker) can be connected through MQTT Client tool. 470 +{{/info}} 157 157 158 -This demo does not use SSL certification. Script is as below 472 +(% class="wikigeneratedid" %) 473 +Tool link: **[[MQTT.fx>>http://mqttfx.jensd.de/index.php/download]]** 159 159 160 - Demo1:475 +== **2.1 V-Box connect with test server(General Example)** == 161 161 162 -{{code language="Lua"}} 163 --- Meta class 164 ---main 165 -function mq.main() 166 - if not mq.m then 167 - local err = "" 477 +{{code language="lua"}} 478 +--MQTT configuration table 479 +local MQTT_CFG={} 480 +MQTT_CFG.username = "weconsupport" 481 +MQTT_CFG.password = "123456" 482 +MQTT_CFG.netway = 0 483 +MQTT_CFG.keepalive = 60 484 +MQTT_CFG.cleansession = 1 485 +--TCP URL 486 +MQTT_URL = "tcp://mq.tongxinmao.com:1883" 487 +--Client ID 488 +MQTT_CLIENT_ID = "V-BOXH-AG" 168 168 169 - mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 170 - if mq.m then 171 - mq.config = { 172 - username = "",-- ID 173 - password = "",-- password 174 - netway = 1, -- Ethernet connection, WIFI=1 175 - -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 176 - -- cleansession = 0, -- Optional, keep session 177 - } 178 - mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 179 - local str = string.format("%s:%s", topic, msg) 180 - -- print("mqtt msg:", str) -- Print out the received topics and content 181 - end 182 - ) 183 - mq.m:on("offline", function (cause) -- Register for lost connection callbacks 184 - -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 185 - end) 186 - mq.m:on("arrived", function() -- Registration for sending messages to callbacks 187 - print("msg arrived") 188 - end) 189 - else 190 - print("mqtt create failed:", err) -- Create object failed 191 - end 192 - else 193 - if mq.m:isconnected() then -- If online, post a message 194 - local phaseStatus ="unknow" 195 - if addr_getbit("@Standby")== 1 then 196 - phaseStatus = "Standby" 197 - elseif addr_getbit("@Pre-Freeze")==1 then 198 - phaseStatus= "Pre-Freeze" 199 - elseif addr_getbit("@Prepare")==1 then 200 - phaseStatus ="Prepare" 201 - elseif addr_getbit("@Primary Dry")==1 then 202 - phaseStatus = "Primary dry" 203 - elseif addr_getbit("@Secondary Dry")==1 then 204 - phaseStatus = "Secondary Dry" 205 - end 206 --- print(addr_getbit("@Primary Dry")) 207 -------------------------------------------------------------------------------------------------------------------------- 208 - local activating ="unknow" 209 - if addr_getbit("@Compressor")==1 then 210 - activating = ",".."Compressor" 211 - end 212 - if addr_getbit("@Silicone Pump")==1 then 213 - activating = activating..",".."Silicone Pump" 214 - end 215 - if addr_getbit("@Vacuum Pump")==1 then 216 - activating = activating..",".."Vacuum Pump" 217 - end 218 - if addr_getbit("@Root Pump")==1 then 219 - activating = activating..",".."Root Pump" 220 - end 221 - if addr_getbit("@Heater")==1 then 222 - activating = activating..",".."Heater" 223 - end 224 - if addr_getbit("@Valve Silicone")==1 then 225 - activating = activating..",".."Valve Silicone" 226 - end 227 - if addr_getbit("@Valve Ice Condenser")==1 then 228 - activating = activating..",".."Valve Ice Condenser" 229 - end 230 - if addr_getbit("@Valve Vacuum Pump")==1 then 231 - activating = activating..",".."Valve Vacuum Pump" 232 - end 233 - local pr_activating =string.sub(activating,2) 234 - -- print(pr_activating) 490 +--Generate UUID 491 +function uuid() 492 + local seed = {'e','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} 493 + local tb = {} 494 + for i=1, 32 do 495 + table.insert(tb, seed[math.random(1,16)]) 496 + end 497 + local sid=table.concat(tb) 498 + return string.format('%s', 499 + string.sub(sid,1,32) 500 + ) 501 +end 235 235 236 236 504 +--Topic name to subscribed 505 +local SUBSCRIBE_TOPIC = 'testtopic/test/no1/123456' 237 237 238 - local status_text ="unknow" 239 - if addr_getbit("@Status Run")==1 then 240 - status_text = "RUNNING" 241 - else 242 - status_text = "STOP" 243 - end 244 -------------------------------------------------------------------------------------------------------------------------- 507 +--Topic name to be published 508 +local PUBLISH_TOPIC = 'testtopic/test/no1/7890' 245 245 246 - local js = {type="status", 247 - mc_name ="FD300", 248 - status=status_text, 249 - elapsed_time={ 250 - hour=addr_getword("@Elapsed Time (Hour)"), 251 - min=addr_getword("@Elapsed Time (Minute)"), 252 - sec=addr_getword("@Elapsed Time (Second)") 253 - }, 254 - phase = phaseStatus, 255 - step = addr_getword("@Step"), 256 - activating_output = pr_activating, 257 - sv=addr_getshort("@SV Silicone")/10, 258 - pv=addr_getshort("@PV Silicone")/10, 259 - product1=addr_getshort("@Product 1")/10, 260 260 261 - product2=addr_getshort("@Product 2")/10, 262 - product3=addr_getshort("@Product 3")/10, 263 - product4=addr_getshort("@Product 4")/10, 264 - ice1=addr_getshort("@Ice condenser 1")/10, 265 - ice2=addr_getshort("@Ice condenser 2")/10, 266 - vacuum=addr_getfloat("@Vacuum") 511 +--real time 512 +local LAST_TIME = 0 267 267 268 - } 269 - local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 270 - ODPC = addr_getbit("@B_25395#W0.01"), 271 - MTPC=addr_getbit("@B_25395#W0.02"), 272 - HTT = addr_getbit("@B_25395#W1.03"), 273 - CPC = addr_getbit("@B_25395#W0.08"), 274 - CPSP =addr_getbit("@B_25395#W1.00"), 275 - CPVP =addr_getbit("@B_25395#W0.10"), 276 - CPRP =addr_getbit("@B_25395#W0.11"), 277 - HP =addr_getbit("@B_25395#W1.01"), 278 - PP= addr_getbit("@B_25395#W1.02"), 279 - PO=addr_getbit("@B_25395#W0.07"), 280 - FSE=addr_getbit("@B_25395#W2.04"), 281 - AVVSVV=addr_getbit("@B_25395#W1.12"), 282 - ICHT=addr_getbit("@B_25395#W3.06") 283 - 284 - } 285 285 286 - -- ("@B_25395#CIO1.02") 287 - mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 288 - mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 289 - else 290 - local stat, err = mq.m:connect(mq.config) -- connection 291 - if stat == nil then --Determine whether to connect 292 - print("mqtt connect failed:", err) 293 - return -- Connection failed, return directly 294 - end 295 - mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 515 +--initialize mqtt 516 +function mqtt_init() 517 + print(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENT_ID)) 518 + if g_mq then 519 + mqtt.close() --Close mqtt object 520 + end 521 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENT_ID) -- create mqtt object,and declare it as a global variable 522 + if g_mq then 523 + g_mq:on("message", mqtt_msg_callback) -- Register a callback for receiving messages 524 + g_mq:on("offline", mqtt_msg_offline) -- Register a callback for offline 525 + print("mqtt init success") 526 + else 527 + print("mqtt init failed:", err) 528 + end 529 +end 296 296 297 - end 298 - -- mq.m:unsubscribe("stc/test") 299 - -- mq.m:disconnect() -- close matt 300 - -- mq.m:close() -- close clase 301 - end 531 +-- connect to mqtt 532 +function mqtt_connect() 533 + print("mqtt connecting...") 534 + local stat, err = g_mq:connect(MQTT_CFG) 535 + if stat == nil then 536 + print("mqtt connect failed:", err) 537 + return 538 + else 539 + print("mqtt connected") 540 + end 541 + g_mq:subscribe(SUBSCRIBE_TOPIC, 0) 302 302 end 543 + 544 +--Offline callback function 545 +function mqtt_msg_offline(cause) 546 + print("mqtt offline, cause:", cause) 547 +end 548 + 549 +-- Received message callback function 550 +function mqtt_msg_callback(topic, msg) 551 + print("topic:", topic) 552 + print("msg:", msg) 553 + local objMsg = json.decode(msg) 554 + local water = objMsg.data.waterlevel 555 + local temp = objMsg.data.temperature 556 + addr_setword("@HDW20",water) 557 + addr_setword("@HDW10",temp) 558 +end 559 + 560 +--Send data (data upload to platform and encapsulate it with custom functions) 561 +function send_data() 562 + local pub_data = { 563 + timestamp = os.time(), 564 + messageId = 1, 565 + event = 'test_data', 566 + mfrs = 'V-Box', 567 + data = { 568 + id = uuid(), 569 + waterlevel = addr_getword("@HDW10"), 570 + temperature = addr_getword("@HDW20") 571 + } 572 + } 573 + return g_mq:publish(PUBLISH_TOPIC, json.encode(pub_data), 0, 0) 574 +end 575 + 576 + 577 +--main function fixed timed execution 578 +function MQTT.main() 579 + --dosomething 580 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main start") 581 + --determine the mqtt object whether exist 582 + if g_mq then 583 + --determine the mqtt object whether has been connected or not 584 + if g_mq:isconnected() then 585 + send_data() 586 + else 587 + --if exceed 5 sec not connect, reconnect once 588 + if os.time() - LAST_TIME > 5 then 589 + LAST_TIME = os.time() 590 + --reinitial the mqtt object 591 + mqtt_init() 592 + --connect to mqtt or reconnect 593 + mqtt_connect() 594 + end 595 + end 596 + else 597 + --mqtt object does not exist so create new one 598 + mqtt_init() 599 + end 600 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main end") 601 +end 303 303 {{/code}} 304 304 305 -== **2.2 V-Box connect with Azure platform** ==604 +== **2.2 V-Box connect with customer server:grouprobotinfo.com** == 306 306 606 +This demo does not use SSL certification. Script is as below 607 + 608 +Demo1: 609 + 610 +{{code language="lua"}} 611 +-- Meta class 612 +--main 613 +function mq.main() 614 + if not mq.m then 615 + local err = "" 616 + 617 + mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection 618 + if mq.m then 619 + mq.config = { 620 + username = "",-- ID 621 + password = "",-- password 622 + netway = 1, -- Ethernet connection, WIFI=1 623 + -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds. 624 + -- cleansession = 0, -- Optional, keep session 625 + } 626 + mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks 627 + local str = string.format("%s:%s", topic, msg) 628 + -- print("mqtt msg:", str) -- Print out the received topics and content 629 + end) 630 + mq.m:on("offline", function (cause) -- Register for lost connection callbacks 631 + -- addr_setstring("@xxx", "cause"..(cause or " got nil")) 632 + end) 633 + mq.m:on("arrived", function() -- Registration for sending messages to callbacks 634 + print("msg arrived") 635 + end) 636 + else 637 + print("mqtt create failed:", err) -- Create object failed 638 + end 639 + else 640 + if mq.m:isconnected() then -- If online, post a message 641 + local phaseStatus ="unknow" 642 + if addr_getbit("@Standby")== 1 then 643 + phaseStatus = "Standby" 644 + elseif addr_getbit("@Pre-Freeze")==1 then 645 + phaseStatus= "Pre-Freeze" 646 + elseif addr_getbit("@Prepare")==1 then 647 + phaseStatus ="Prepare" 648 + elseif addr_getbit("@Primary Dry")==1 then 649 + phaseStatus = "Primary dry" 650 + elseif addr_getbit("@Secondary Dry")==1 then 651 + phaseStatus = "Secondary Dry" 652 + end 653 + --print(addr_getbit("@Primary Dry")) 654 +------------------------------------------------------------------------------------------------------------------------- 655 + local activating ="unknow" 656 + if addr_getbit("@Compressor")==1 then 657 + activating = ",".."Compressor" 658 + end 659 + if addr_getbit("@Silicone Pump")==1 then 660 + activating = activating..",".."Silicone Pump" 661 + end 662 + if addr_getbit("@Vacuum Pump")==1 then 663 + activating = activating..",".."Vacuum Pump" 664 + end 665 + if addr_getbit("@Root Pump")==1 then 666 + activating = activating..",".."Root Pump" 667 + end 668 + if addr_getbit("@Heater")==1 then 669 + activating = activating..",".."Heater" 670 + end 671 + if addr_getbit("@Valve Silicone")==1 then 672 + activating = activating..",".."Valve Silicone" 673 + end 674 + if addr_getbit("@Valve Ice Condenser")==1 then 675 + activating = activating..",".."Valve Ice Condenser" 676 + end 677 + if addr_getbit("@Valve Vacuum Pump")==1 then 678 + activating = activating..",".."Valve Vacuum Pump" 679 + end 680 + local pr_activating =string.sub(activating,2) 681 + -- print(pr_activating) 682 + local status_text ="unknow" 683 + if addr_getbit("@Status Run")==1 then 684 + status_text = "RUNNING" 685 + else 686 + status_text = "STOP" 687 + end 688 +------------------------------------------------------------------------------------------------------------------------- 689 + local js = {type="status", 690 + mc_name ="FD300", 691 + status=status_text, 692 + elapsed_time={ 693 + hour=addr_getword("@Elapsed Time (Hour)"), 694 + min=addr_getword("@Elapsed Time (Minute)"), 695 + sec=addr_getword("@Elapsed Time (Second)") 696 + }, 697 + phase = phaseStatus, 698 + step = addr_getword("@Step"), 699 + activating_output = pr_activating, 700 + sv=addr_getshort("@SV Silicone")/10, 701 + pv=addr_getshort("@PV Silicone")/10, 702 + product1=addr_getshort("@Product 1")/10, 703 + 704 + product2=addr_getshort("@Product 2")/10, 705 + product3=addr_getshort("@Product 3")/10, 706 + product4=addr_getshort("@Product 4")/10, 707 + ice1=addr_getshort("@Ice condenser 1")/10, 708 + ice2=addr_getshort("@Ice condenser 2")/10, 709 + vacuum=addr_getfloat("@Vacuum") 710 + } 711 + local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"), 712 + ODPC = addr_getbit("@B_25395#W0.01"), 713 + MTPC=addr_getbit("@B_25395#W0.02"), 714 + HTT = addr_getbit("@B_25395#W1.03"), 715 + CPC = addr_getbit("@B_25395#W0.08"), 716 + CPSP =addr_getbit("@B_25395#W1.00"), 717 + CPVP =addr_getbit("@B_25395#W0.10"), 718 + CPRP =addr_getbit("@B_25395#W0.11"), 719 + HP =addr_getbit("@B_25395#W1.01"), 720 + PP= addr_getbit("@B_25395#W1.02"), 721 + PO=addr_getbit("@B_25395#W0.07"), 722 + FSE=addr_getbit("@B_25395#W2.04"), 723 + AVVSVV=addr_getbit("@B_25395#W1.12"), 724 + ICHT=addr_getbit("@B_25395#W3.06") 725 + } 726 + -- ("@B_25395#CIO1.02") 727 + mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0) 728 + mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0) 729 + else 730 + local stat, err = mq.m:connect(mq.config) -- connection 731 + if stat == nil then --Determine whether to connect 732 + print("mqtt connect failed:", err) 733 + return -- Connection failed, return directly 734 + end 735 + mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics 736 + 737 + end 738 + -- mq.m:unsubscribe("stc/test") 739 + -- mq.m:disconnect() -- close matt 740 + -- mq.m:close() -- close clase 741 + end 742 +end 743 +{{/code}} 744 + 745 +== **2.3 V-Box connect with Azure platform** == 746 + 307 307 In this demo,V-Box connects with Azure by SSL certification. 308 308 309 309 Video link: [[https:~~/~~/youtu.be/cdI6rIQcpMY?list=PL_Bpnb2RgaksCic9HCcVAZhU9sYwCRKzW>>https://youtu.be/cdI6rIQcpMY?list=PL_Bpnb2RgaksCic9HCcVAZhU9sYwCRKzW]] ... ... @@ -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 755 +(% class="box infomessage" %) 756 +((( 757 +~-~-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" 760 +~-~-Get custom configuration parameters (vbox custom information) 761 +~-~-local CUSTOM = bns_get_config("bind") 762 +~-~-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) 765 +~-~-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' 768 +~-~-MQTT_CFG.username = '60a71ccbbbe12002c08f3a1a_WECON' 769 +~-~-MQTT_CFG.password='wecon123' 770 +~-~-MQTT_CLIENTID = '60a71ccbbbe12002c08f3a1a_WECON_0_0_2021052110usernxame:60a71ccbbbe12002c08f3a1a_WECONpassword:a0a951581855aa8e0262129da6cf1b43f2c0ecfac4fa56117fc5a20c90be169a' 331 331 332 ---publish to topics 772 +~-~-publish to topics 333 333 local pub_RE_TOPIC = string.format('devices/wecon_02/messages/events/') 334 ---Subscribe topics 774 +~-~-Subscribe topics 335 335 local Subscribe_RE_TOPIC1 = string.format('devices/wecon_02/messages/devicebound/#') 336 336 337 ---variable 777 +~-~-variable 338 338 local last_time = 0 339 339 340 340 341 - 342 ---Timing main function 781 +~-~-Timing main function 343 343 function Azure.main() 344 344 345 - 346 - 347 - 348 - 349 - 350 - 351 - 352 - 353 - 354 - 355 - 356 - 357 - 358 - 784 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main start") 785 + if g_mq then 786 + if g_mq:isconnected() then 787 + send_Data() 788 + else 789 + if os.time() - last_time > 20 then 790 + last_time = os.time() 791 + mymqtt_connect() 792 + end 793 + end 794 + else 795 + mymqtt_init() 796 + end 797 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main end") 359 359 end 360 360 361 --- Initialize MQTT 800 +~-~- Initialize MQTT 362 362 function mymqtt_init() 363 - 364 - 365 - 366 - 367 - 368 - 369 - 370 - 802 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID)) 803 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable 804 + if g_mq then 805 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks 806 + sprint("mqtt init success") 807 + else 808 + sprint("mqtt init failed:", err) 809 + end 371 371 end 372 372 373 --- Connect to MQTT server 812 +~-~- Connect to MQTT server 374 374 function mymqtt_connect() 375 - 376 - 377 - 378 - 379 - 380 - 381 - 382 - 383 - 814 + sprint("mqtt connecting...") 815 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 816 + if stat == nil then 817 + sprint("mqtt connect failed:", err) 818 + return 819 + else 820 + sprint("mqtt connected") 821 + end 822 + g_mq:subscribe(Subscribe_RE_TOPIC1, 0) 384 384 end 385 385 386 --- Receive MQTT message callback function 825 +~-~- 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 - 827 + print("topic:",topic) 828 + print("revdata:",msg) 829 + ~-~- local revData = json.decode(msg) 830 + ~-~- if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud 831 +~-~- if string.match(topic,Subscribe_RE_TOPIC1) then 832 + ~-~- print("topi11:",topic) 833 + setValue(revData) 834 + ~-~- end 396 396 end 397 397 398 ---Process the received data 399 ---function setValue(revData) 400 - 401 - 402 - 403 - 404 - 405 ---end 837 +~-~-Process the received data 838 +~-~-function setValue(revData) 839 + ~-~- if revData ~~=nil then 840 + ~-~- for i,v in pairs(revData) do 841 + ~-~- print("Data received:",i,v) 842 + ~-~- end 843 + ~-~- end 844 +~-~-end 406 406 407 ---Get real-time data 846 +~-~-Get real-time data 408 408 function getData() 409 - 410 - 411 - 412 - 413 - 414 - 415 - 416 - 417 - 418 -end 848 + local jdata = {} 849 + local addr = bns_get_alldata() 850 + print(json.encode(addr)) 851 + for i,v in pairs(addr) do 852 + if v[2] == 1 then 853 + jdata[v[3]] = v[4] 854 + end 855 + end 856 + return jdata 857 +end 419 419 420 420 421 - 422 ---send data 860 +~-~-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 - -- }} 862 + local pub_data = {100 863 + ~-~- services=~{~{ 864 +\\ ~-~-serviceId ='Temperature', 865 + ~-~- properties={ 866 + ~-~- value = 55 867 + ~-~- }, 868 + ~-~- }} 432 432 } 433 433 sprint(json.encode(pub_data)) 434 434 print("..........",pub_RE_TOPIC) 435 - 872 + 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 876 +== **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)** == 877 + 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** ==1025 +== **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** ==1146 +== **2.6 V-Box connect with AWS platform** == 715 715 716 716 === **Log in AWS** === 717 717 ... ... @@ -736,315 +736,269 @@ 736 736 737 737 {{code language="java"}} 738 738 { 739 - 740 740 "Version": "2012-10-17", 741 - 742 742 "Statement": [ 743 - 744 744 { 745 - 746 746 "Effect": "Allow", 747 - 748 748 "Action": [ 749 - 750 750 "iot:Connect", 751 - 752 752 "iot:Publish", 753 - 754 754 "iot:Subscribe", 755 - 756 756 "iot:Receive", 757 - 758 758 "greengrass:Discover" 759 - 760 760 ], 761 - 762 762 "Resource": "*" 763 - 764 764 } 765 - 766 766 ] 767 - 768 768 } 769 769 {{/code}} 770 770 771 - 1.**Create things**1188 +=== **Create things** === 772 772 773 773 Click “Manage”~-~-->“Things”~-~-->“Create things”~-~-->“Create single thing” 774 774 1192 +[[image:image-20220709165402-6.png]] 775 775 776 -| 777 -| |[[image:image-20220709165402-6.png]] 1194 +[[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 1198 +[[image:image-20220709165402-8.png]] 787 787 788 788 Select the way to create certificate 789 789 1202 +[[image:image-20220709165402-9.png]] 790 790 791 -| 792 -| |[[image:image-20220709165402-9.png]] 793 - 794 794 Select policy 795 795 1206 +[[image:image-20220709165402-10.png]] 796 796 797 -| 798 -| |[[image:image-20220709165402-10.png]] 1208 +[[image:image-20220709165402-11.png]] 799 799 800 800 1211 +=== **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 1215 +[[image:image-20220709165402-13.png]] 812 812 813 -| 814 -| |[[image:image-20220709165402-12.png]] 1217 +[[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 1221 +[[image:image-20220709165402-14.png]] 1222 + 827 827 Upload the CA File, Client Certificate File, Client Key File 828 828 1225 +[[image:image-20220709165402-15.png]] 829 829 830 -| 831 -| |[[image:image-20220709165402-15.png]] 832 - 833 833 Publish message to topic “TEST” 834 834 1229 +[[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 1233 +[[image:image-20220709173500-1.png]] 1234 + 844 844 And we can also send message form AWS platform to MQTT.fx tool. 845 845 1237 +[[image:image-20220709165402-18.png]] 846 846 847 -| 848 -| |[[image:image-20220709165402-18.png]] 1239 +=== **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 1243 +[[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 1247 +[[image:image-20220709165402-20.png]] 860 860 861 -| 862 -| |[[image:image-20220709165402-20.png]] 1249 +{{info}} 1250 +**✎Note:** Before using the following demo script, please make sure the V-Box firmware is newer than 22110701 1251 +{{/info}} 863 863 1253 +{{code language="lua"}} 864 864 sprint = print 865 865 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)1256 +--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) 867 867 868 868 local MQTT_URL, MQTT_CLIENTID, MQTT_CFG, MQTT_LWT, MQTT_CART = mqtt.setup_cfg() 869 869 870 - ~-~-publish to topics1260 +--publish to topics 871 871 872 872 local pub_RE_TOPIC = string.format('TEST') 873 873 874 - ~-~-Subscribe topics1264 +--Subscribe topics 875 875 876 876 local Subscribe_RE_TOPIC1 = string.format('TEST') 877 877 878 - ~-~-variable1268 +--variable 879 879 880 880 local last_time = 0 881 881 882 - ~-~-Timing main function1272 +--Timing main function 883 883 884 884 function aws.main() 885 885 886 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start") 1276 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start") 887 887 888 - if g_mq then 1278 + if g_mq then 889 889 890 - if g_mq:isconnected() then 1280 + if g_mq:isconnected() then 891 891 892 - send_Data() 1282 + send_Data() 893 893 894 - else 1284 + else 895 895 896 - if os.time() - last_time > 5 then 1286 + if os.time() - last_time > 5 then 897 897 898 - last_time = os.time() 1288 + last_time = os.time() 899 899 900 - mymqtt_connect() 1290 + mymqtt_connect() 901 901 1292 + end 1293 + 902 902 end 903 903 904 - e nd1296 + else 905 905 906 - else1298 + mymqtt_init() 907 907 908 - mymqtt_init()1300 + end 909 909 910 - end 1302 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end") 911 911 912 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end") 913 - 914 914 end 915 915 916 916 917 -~-~- Initialize MQTT 918 918 1308 +-- Initialize MQTT 1309 + 919 919 function mymqtt_init() 920 920 921 - sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID)) 1312 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID)) 922 922 923 - g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable1314 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID, 1) -- Create the object and declare it as a global variable, 1 means using the domain to connect 924 924 925 - if g_mq then 1316 + if g_mq then 926 926 927 - g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks1318 + g_mq:on("message", mymqtt_msg_callback) -- Register to receive message callbacks 928 928 929 - sprint("mqtt init success") 1320 + sprint("mqtt init success") 930 930 931 - else 1322 + else 932 932 933 - sprint("mqtt init failed:", err) 1324 + sprint("mqtt init failed:", err) 934 934 935 - end 1326 + end 936 936 937 937 end 938 938 939 - ~-~- Connect to MQTT server1330 +-- Connect to MQTT server 940 940 941 941 function mymqtt_connect() 942 942 943 - sprint("mqtt connecting...") 1334 + sprint("mqtt connecting...") 944 944 945 - local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 1336 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART) 946 946 947 - if stat == nil then 1338 + if stat == nil then 948 948 949 - sprint("mqtt connect failed:", err) 1340 + sprint("mqtt connect failed:", err) 950 950 951 - return 1342 + return 952 952 953 - else 1344 + else 954 954 955 - sprint("mqtt connected") 1346 + sprint("mqtt connected") 956 956 957 - end 1348 + end 958 958 959 - g_mq:subscribe( TEST, 0)1350 + g_mq:subscribe(Subscribe_RE_TOPIC1, 0) 960 960 961 961 end 962 962 963 - ~-~- Receive MQTT message callback function1354 +-- Receive MQTT message callback function 964 964 965 965 function mymqtt_msg_callback(topic, msg) 966 966 967 - print("topic:",topic) 1358 + print("topic:",topic) 968 968 969 - print("revdata:",msg) 1360 + print("revdata:",msg) 970 970 971 - local revData = json.decode(msg) 1362 + local revData = json.decode(msg) 972 972 973 - print (revData) 1364 + print (revData) 974 974 975 - if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud1366 + if topic == Subscribe_RE_TOPIC1 then --Process topic information subscribed from the cloud 976 976 977 -if string.match(topic,Subscribe_RE_TOPIC1) then 1368 + if string.match(topic,Subscribe_RE_TOPIC1) then 978 978 979 - ~-~-if revData ~~= nil then1370 + --if revData ~= nil then 980 980 981 - for k,v in pairs (revData) do 1372 + for k,v in pairs (revData) do 982 982 983 - print("printing revdata after kv here") 1374 + print("printing revdata after kv here") 984 984 985 - print (k,v) 1376 + print (k,v) 986 986 987 - end 1378 + end 988 988 989 - print ("current state is",fanstate) 1380 + print ("current state is",fanstate) 990 990 991 - ~-~-end1382 + --end 992 992 993 -end 1384 + end 994 994 995 -end 1386 + end 996 996 997 997 end 998 998 999 999 1000 -~-~-Get real-time data 1001 1001 1392 +--Get real-time data 1393 + 1002 1002 function getData() 1003 1003 1004 - local jdata = {} 1396 + local jdata = {} 1005 1005 1006 - local addr = bns_get_alldata() 1398 + local addr = bns_get_alldata() 1007 1007 1008 - print(json.encode(addr)) 1400 + print(json.encode(addr)) 1009 1009 1010 - for i,v in pairs(addr) do 1402 + for i,v in pairs(addr) do 1011 1011 1012 - if v[2] == 1 then 1404 + if v[2] == 1 then 1013 1013 1014 - jdata[v[3]] = v[4] 1406 + jdata[v[3]] = v[4] 1015 1015 1016 - end 1408 + end 1017 1017 1018 - end 1410 + end 1019 1019 1020 - return jdata 1412 + return jdata 1021 1021 1022 1022 end 1023 1023 1024 - ~-~-send data1416 +--send data 1025 1025 1026 1026 function send_Data() 1027 1027 1028 - local pub_data = 1420 + local pub_data = 1421 + { 1422 + 123 1423 + } 1029 1029 1030 - { 1031 - 1032 -123 1033 - 1034 -} 1035 - 1036 1036 sprint(json.encode(pub_data)) 1037 1037 1038 1038 print("..........",pub_RE_TOPIC) 1039 1039 1040 - return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0) 1429 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0) 1041 1041 1042 1042 end 1432 +{{/code}} 1043 1043 1044 - 1045 - 1046 1046 Get message in AWS 1047 1047 1048 - 1049 -| 1050 -| |[[image:image-20220709165402-21.png]] 1436 +[[image:image-20220709165402-21.png]]
- InputHTTPparameter.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Hunter - Size
-
... ... @@ -1,0 +1,1 @@ 1 +17.9 KB - Content
- image-20220709173500-1.png
-
- Author
-
... ... @@ -1,0 +1,1 @@ 1 +XWiki.Jim - Size
-
... ... @@ -1,0 +1,1 @@ 1 +1.5 MB - Content