Changes for page 2 Script

Last modified by Devin Chen on 2025/06/06 14:03

From version 15.1
edited by Leo Wei
on 2022/07/09 17:44
Change comment: There is no comment for this version
To version 39.1
edited by Hunter
on 2023/03/17 15:50
Change comment: There is no comment for this version

Summary

Details

Page properties
Author
... ... @@ -1,1 +1,1 @@
1 -XWiki.admin
1 +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\.User Manual.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,280 @@
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 +-- Received message callback function
545 +function mqtt_msg_callback(topic, msg)
546 + print("topic:", topic)
547 + print("msg:", msg)
548 + local objMsg = json.decode(msg)
549 + local water = objMsg.data.waterlevel
550 + local temp = objMsg.data.temperature
551 + addr_setword("@HDW20",water)
552 + addr_setword("@HDW10",temp)
553 +end
554 +
555 +--Send data (data upload to platform and encapsulate it with custom functions)
556 +function send_data()
557 + local pub_data = {
558 + timestamp = os.time(),
559 + messageId = 1,
560 + event = 'test_data',
561 + mfrs = 'V-Box',
562 + data = {
563 + id = uuid(),
564 + waterlevel = addr_getword("@HDW10"),
565 + temperature = addr_getword("@HDW20")
566 + }
567 + }
568 + return g_mq:publish(PUBLISH_TOPIC, json.encode(pub_data), 0, 0)
569 +end
570 +
571 +
572 +--main function fixed timed execution
573 +function MQTT.main()
574 + --dosomething
575 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main start")
576 + --determine the mqtt object whether exist
577 + if g_mq then
578 + --determine the mqtt object whether has been connected or not
579 + if g_mq:isconnected() then
580 + send_data()
581 + else
582 + --if exceed 5 sec not connect, reconnect once
583 + if os.time() - LAST_TIME > 5 then
584 + LAST_TIME = os.time()
585 + --reinitial the mqtt object
586 + mqtt_init()
587 + --connect to mqtt or reconnect
588 + mqtt_connect()
589 + end
590 + end
591 + else
592 + --mqtt object does not exist so create new one
593 + mqtt_init()
594 + end
595 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main end")
596 +end
303 303  {{/code}}
304 304  
305 -== **2.2 V-Box connect with Azure platform** ==
599 +== **2.2 V-Box connect with customer server:grouprobotinfo.com** ==
306 306  
601 +This demo does not use SSL certification. Script is as below
602 +
603 +Demo1:
604 +
605 +{{code language="lua"}}
606 +-- Meta class
607 +--main
608 +function mq.main()
609 + if not mq.m then
610 + local err = ""
611 +
612 + mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection
613 + if mq.m then
614 + mq.config = {
615 + username = "",-- ID
616 + password = "",-- password
617 + netway = 1, -- Ethernet connection, WIFI=1
618 + -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds.
619 + -- cleansession = 0, -- Optional, keep session
620 + }
621 + mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks
622 + local str = string.format("%s:%s", topic, msg)
623 + -- print("mqtt msg:", str) -- Print out the received topics and content
624 + end)
625 + mq.m:on("offline", function (cause) -- Register for lost connection callbacks
626 + -- addr_setstring("@xxx", "cause"..(cause or " got nil"))
627 + end)
628 + mq.m:on("arrived", function() -- Registration for sending messages to callbacks
629 + print("msg arrived")
630 + end)
631 + else
632 + print("mqtt create failed:", err) -- Create object failed
633 + end
634 + else
635 + if mq.m:isconnected() then -- If online, post a message
636 + local phaseStatus ="unknow"
637 + if addr_getbit("@Standby")== 1 then
638 + phaseStatus = "Standby"
639 + elseif addr_getbit("@Pre-Freeze")==1 then
640 + phaseStatus= "Pre-Freeze"
641 + elseif addr_getbit("@Prepare")==1 then
642 + phaseStatus ="Prepare"
643 + elseif addr_getbit("@Primary Dry")==1 then
644 + phaseStatus = "Primary dry"
645 + elseif addr_getbit("@Secondary Dry")==1 then
646 + phaseStatus = "Secondary Dry"
647 + end
648 + --print(addr_getbit("@Primary Dry"))
649 +-------------------------------------------------------------------------------------------------------------------------
650 + local activating ="unknow"
651 + if addr_getbit("@Compressor")==1 then
652 + activating = ",".."Compressor"
653 + end
654 + if addr_getbit("@Silicone Pump")==1 then
655 + activating = activating..",".."Silicone Pump"
656 + end
657 + if addr_getbit("@Vacuum Pump")==1 then
658 + activating = activating..",".."Vacuum Pump"
659 + end
660 + if addr_getbit("@Root Pump")==1 then
661 + activating = activating..",".."Root Pump"
662 + end
663 + if addr_getbit("@Heater")==1 then
664 + activating = activating..",".."Heater"
665 + end
666 + if addr_getbit("@Valve Silicone")==1 then
667 + activating = activating..",".."Valve Silicone"
668 + end
669 + if addr_getbit("@Valve Ice Condenser")==1 then
670 + activating = activating..",".."Valve Ice Condenser"
671 + end
672 + if addr_getbit("@Valve Vacuum Pump")==1 then
673 + activating = activating..",".."Valve Vacuum Pump"
674 + end
675 + local pr_activating =string.sub(activating,2)
676 + -- print(pr_activating)
677 + local status_text ="unknow"
678 + if addr_getbit("@Status Run")==1 then
679 + status_text = "RUNNING"
680 + else
681 + status_text = "STOP"
682 + end
683 +-------------------------------------------------------------------------------------------------------------------------
684 + local js = {type="status",
685 + mc_name ="FD300",
686 + status=status_text,
687 + elapsed_time={
688 + hour=addr_getword("@Elapsed Time (Hour)"),
689 + min=addr_getword("@Elapsed Time (Minute)"),
690 + sec=addr_getword("@Elapsed Time (Second)")
691 + },
692 + phase = phaseStatus,
693 + step = addr_getword("@Step"),
694 + activating_output = pr_activating,
695 + sv=addr_getshort("@SV Silicone")/10,
696 + pv=addr_getshort("@PV Silicone")/10,
697 + product1=addr_getshort("@Product 1")/10,
698 +
699 + product2=addr_getshort("@Product 2")/10,
700 + product3=addr_getshort("@Product 3")/10,
701 + product4=addr_getshort("@Product 4")/10,
702 + ice1=addr_getshort("@Ice condenser 1")/10,
703 + ice2=addr_getshort("@Ice condenser 2")/10,
704 + vacuum=addr_getfloat("@Vacuum")
705 + }
706 + local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"),
707 + ODPC = addr_getbit("@B_25395#W0.01"),
708 + MTPC=addr_getbit("@B_25395#W0.02"),
709 + HTT = addr_getbit("@B_25395#W1.03"),
710 + CPC = addr_getbit("@B_25395#W0.08"),
711 + CPSP =addr_getbit("@B_25395#W1.00"),
712 + CPVP =addr_getbit("@B_25395#W0.10"),
713 + CPRP =addr_getbit("@B_25395#W0.11"),
714 + HP =addr_getbit("@B_25395#W1.01"),
715 + PP= addr_getbit("@B_25395#W1.02"),
716 + PO=addr_getbit("@B_25395#W0.07"),
717 + FSE=addr_getbit("@B_25395#W2.04"),
718 + AVVSVV=addr_getbit("@B_25395#W1.12"),
719 + ICHT=addr_getbit("@B_25395#W3.06")
720 + }
721 + -- ("@B_25395#CIO1.02")
722 + mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0)
723 + mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0)
724 + else
725 + local stat, err = mq.m:connect(mq.config) -- connection
726 + if stat == nil then --Determine whether to connect
727 + print("mqtt connect failed:", err)
728 + return -- Connection failed, return directly
729 + end
730 + mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics
731 +
732 + end
733 + -- mq.m:unsubscribe("stc/test")
734 + -- mq.m:disconnect() -- close matt
735 + -- mq.m:close() -- close clase
736 + end
737 +end
738 +{{/code}}
739 +
740 +== **2.3 V-Box connect with Azure platform** ==
741 +
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,131 +312,128 @@
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
750 +(% class="box infomessage" %)
751 +(((
752 +~-~-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"
755 +~-~-Get custom configuration parameters (vbox custom information)
756 +~-~-local CUSTOM = bns_get_config("bind")
757 +~-~-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)
760 +~-~-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'
763 +~-~-MQTT_CFG.username = '60a71ccbbbe12002c08f3a1a_WECON'
764 +~-~-MQTT_CFG.password='wecon123'
765 +~-~-MQTT_CLIENTID = '60a71ccbbbe12002c08f3a1a_WECON_0_0_2021052110usernxame:60a71ccbbbe12002c08f3a1a_WECONpassword:a0a951581855aa8e0262129da6cf1b43f2c0ecfac4fa56117fc5a20c90be169a'
331 331  
332 ---publish to topics
767 +~-~-publish to topics
333 333  local pub_RE_TOPIC = string.format('devices/wecon_02/messages/events/')
334 ---Subscribe topics
769 +~-~-Subscribe topics
335 335  local Subscribe_RE_TOPIC1 = string.format('devices/wecon_02/messages/devicebound/#')
336 336  
337 ---variable
772 +~-~-variable
338 338  local last_time = 0
339 339  
340 340  
341 -
342 ---Timing main function
776 +~-~-Timing main function
343 343  function Azure.main()
344 344  
345 -   sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main start")
346 -   if g_mq then
347 -        if g_mq:isconnected() then
348 -            send_Data()
349 -        else
350 -            if os.time() - last_time > 20 then
351 -                last_time = os.time()
352 -                mymqtt_connect()
353 -            end
354 -        end
355 -    else
356 -        mymqtt_init()
357 -    end
358 -    sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main end")
779 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main start")
780 + if g_mq then
781 + if g_mq:isconnected() then
782 + send_Data()
783 + else
784 + if os.time() - last_time > 20 then
785 + last_time = os.time()
786 + mymqtt_connect()
787 + end
788 + end
789 + else
790 + mymqtt_init()
791 + end
792 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " Azureiot.main end")
359 359  end
360 360  
361 --- Initialize MQTT
795 +~-~- Initialize MQTT
362 362  function mymqtt_init()
363 -    sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID))
364 -    g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) -- Create the object and declare it as a global variable
365 -    if g_mq then
366 -        g_mq:on("message", mymqtt_msg_callback) -- Register to receive message callbacks
367 -        sprint("mqtt init success")
368 -    else
369 -        sprint("mqtt init failed:", err)
370 -    end
797 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID))
798 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable
799 + if g_mq then
800 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks
801 + sprint("mqtt init success")
802 + else
803 + sprint("mqtt init failed:", err)
804 + end
371 371  end
372 372  
373 --- Connect to MQTT server
807 +~-~- Connect to MQTT server
374 374  function mymqtt_connect()
375 -    sprint("mqtt connecting...")
376 -    local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART)
377 -    if stat == nil then
378 -        sprint("mqtt connect failed:", err)
379 -        return
380 -    else
381 -        sprint("mqtt connected")
382 -    end
383 -    g_mq:subscribe(Subscribe_RE_TOPIC1, 0) 
809 + sprint("mqtt connecting...")
810 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART)
811 + if stat == nil then
812 + sprint("mqtt connect failed:", err)
813 + return
814 + else
815 + sprint("mqtt connected")
816 + end
817 + g_mq:subscribe(Subscribe_RE_TOPIC1, 0) 
384 384  end
385 385  
386 --- Receive MQTT message callback function
820 +~-~- Receive MQTT message callback function
387 387  function mymqtt_msg_callback(topic, msg)
388 -    print("topic:",topic)
389 -    print("revdata:",msg)
390 -   -- local revData = json.decode(msg)
391 - --  if topic == Subscribe_RE_TOPIC1 then --Process topic information subscribed from the cloud
392 --- if string.match(topic,Subscribe_RE_TOPIC1) then
393 -     --   print("topi11:",topic)
394 -       setValue(revData)
395 -   -- end
822 + print("topic:",topic)
823 + print("revdata:",msg)
824 + ~-~- local revData = json.decode(msg)
825 + ~-~- if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud
826 +~-~- if string.match(topic,Subscribe_RE_TOPIC1) then
827 + ~-~- print("topi11:",topic)
828 + setValue(revData)
829 + ~-~- end
396 396  end
397 397  
398 ---Process the received data
399 ---function setValue(revData)
400 -   -- if revData ~=nil then 
401 - --       for i,v in pairs(revData) do
402 -  --          print("Data received:",i,v)
403 -  --      end
404 -   -- end
405 ---end
832 +~-~-Process the received data
833 +~-~-function setValue(revData)
834 + ~-~- if revData ~~=nil then 
835 + ~-~- for i,v in pairs(revData) do
836 + ~-~- print("Data received:",i,v)
837 + ~-~- end
838 + ~-~- end
839 +~-~-end
406 406  
407 ---Get real-time data
841 +~-~-Get real-time data
408 408  function getData()
409 -    local jdata = {}
410 -    local addr = bns_get_alldata()
411 -    print(json.encode(addr))
412 -    for i,v in pairs(addr) do
413 -        if v[2] == 1 then
414 -           jdata[v[3]] = v[4]
415 -        end
416 -    end
417 -    return jdata
418 -end 
843 + local jdata = {}
844 + local addr = bns_get_alldata()
845 + print(json.encode(addr))
846 + for i,v in pairs(addr) do
847 + if v[2] == 1 then
848 + jdata[v[3]] = v[4]
849 + end
850 + end
851 + return jdata
852 +end
419 419  
420 420  
421 -
422 ---send data
855 +~-~-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 -       -- }}
857 + local pub_data = {100
858 + ~-~- services=~{~{
859 +\\ ~-~-serviceId ='Temperature',
860 + ~-~- properties={
861 + ~-~- value = 55
862 + ~-~- },
863 + ~-~- }}
432 432  }
433 433  sprint(json.encode(pub_data))
434 434  print("..........",pub_RE_TOPIC)
435 -    return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0)
867 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0)
436 436  end
437 -{{/code}}
869 +)))
438 438  
439 -== **2.3 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)** ==
871 +== **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)** ==
440 440  
441 441  1.Register a account: [[https:~~/~~/www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ>>https://www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ]]
442 442  
... ... @@ -585,7 +585,7 @@
585 585  (% style="text-align:center" %)
586 586  [[image:1624441186851-536.png||height="434" width="700" class="img-thumbnail"]]
587 587  
588 -== **2.4 V-Box connect with Huawei platform** ==
1020 +== **2.5 V-Box connect with Huawei platform** ==
589 589  
590 590  In this demo,V-Box connects with Huawei by SSL certification.
591 591  
... ... @@ -706,7 +706,7 @@
706 706  (% style="text-align:center" %)
707 707  [[image:1624506666650-161.png||height="547" width="1000" class="img-thumbnail"]]
708 708  
709 -== **2.5 V-Box connect with AWS platform** ==
1141 +== **2.6 V-Box connect with AWS platform** ==
710 710  
711 711  === **Log in AWS** ===
712 712  
... ... @@ -731,318 +731,269 @@
731 731  
732 732  {{code language="java"}}
733 733  {
734 -
735 735    "Version": "2012-10-17",
736 -
737 737    "Statement": [
738 -
739 739      {
740 -
741 741        "Effect": "Allow",
742 -
743 743        "Action": [
744 -
745 745          "iot:Connect",
746 -
747 747          "iot:Publish",
748 -
749 749          "iot:Subscribe",
750 -
751 751          "iot:Receive",
752 -
753 753          "greengrass:Discover"
754 -
755 755        ],
756 -
757 757        "Resource": "*"
758 -
759 759      }
760 -
761 761    ]
762 -
763 763  }
764 764  {{/code}}
765 765  
766 -1. **Create things**
1183 +=== **Create things** ===
767 767  
768 768  Click “Manage”~-~-->“Things”~-~-->“Create things”~-~-->“Create single thing”
769 769  
1187 +[[image:image-20220709165402-6.png]]
770 770  
771 -|
772 -| |[[image:image-20220709165402-6.png]]
1189 +[[image:image-20220709165402-7.png]]
773 773  
774 -|
775 -| |[[image:image-20220709165402-7.png]]
776 -
777 -|
778 -| |[[image:image-20220709165402-8.png]]
779 -
780 780  Name the thing~-~-->Click “Next”
781 781  
1193 +[[image:image-20220709165402-8.png]]
782 782  
783 783  Select the way to create certificate
784 784  
1197 +[[image:image-20220709165402-9.png]]
785 785  
786 -|
787 -| |[[image:image-20220709165402-9.png]]
788 -
789 789  Select policy
790 790  
1201 +[[image:image-20220709165402-10.png]]
791 791  
792 -|
793 -| |[[image:image-20220709165402-10.png]]
1203 +[[image:image-20220709165402-11.png]]
794 794  
795 795  
1206 +=== **Test with MQTT.fx tool** ===
796 796  
797 -
798 -
799 -
800 -|
801 -| |[[image:image-20220709165402-11.png]]
802 -
803 -
804 -
805 -1. **Test with MQTT.fx tool**
806 -
807 807  Click “View Setting” to get the “Broker Adress”
808 808  
1210 +[[image:image-20220709165402-13.png]]
809 809  
810 -|
811 -| |[[image:image-20220709165402-12.png]]
1212 +[[image:image-20220709165402-12.png]]
812 812  
813 -|
814 -| |[[image:image-20220709165402-13.png]]
815 -
816 -
817 -
818 -
819 -
820 -|
821 -| |[[image:image-20220709165402-14.png]]
822 -
823 823  Create one connection in MQTT.fx tool, set broker port as 8883.
824 824  
1216 +[[image:image-20220709165402-14.png]]
1217 +
825 825  Upload the CA File, Client Certificate File, Client Key File
826 826  
1220 +[[image:image-20220709165402-15.png]]
827 827  
828 -|
829 -| |[[image:image-20220709165402-15.png]]
830 -
831 831  Publish message to topic “TEST”
832 832  
1224 +[[image:image-20220709165402-17.png]]
833 833  
834 -|
835 -| |[[image:image-20220709165402-16.png]]
836 -
837 -|
838 -| |[[image:image-20220709165402-17.png]]
839 -
840 840  Click”Test”~-~-->”MQTT test client”~-~-->”Subscrible to a topic”, to get message publish from MQTT.fx tool.
841 841  
1228 +[[image:image-20220709173500-1.png]]
1229 +
842 842  And we can also send message form AWS platform to MQTT.fx tool.
843 843  
1232 +[[image:image-20220709165402-18.png]]
844 844  
845 -|
846 -| |[[image:image-20220709165402-18.png]]
1234 +=== **Configurate in CloudTool** ===
847 847  
848 -1. **Configurate in CloudTool**
849 -
850 850  Copy the same setting in MQTT.fx to MQTT configuration
851 851  
1238 +[[image:image-20220709165402-19.png]]
852 852  
853 -|
854 -| |[[image:image-20220709165402-19.png]]
855 -
856 856   Add a lua script and copy the lua demo into it.
857 857  
1242 +[[image:image-20220709165402-20.png]]
858 858  
859 -|
860 -| |[[image:image-20220709165402-20.png]]
1244 +{{info}}
1245 +**✎Note:** Before using the following demo script, please make sure the V-Box firmware is newer than 22110701
1246 +{{/info}}
861 861  
1248 +{{code language="lua"}}
862 862  sprint = print
863 863  
864 -~-~-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)
1251 +--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)
865 865  
866 866  local MQTT_URL, MQTT_CLIENTID, MQTT_CFG, MQTT_LWT, MQTT_CART = mqtt.setup_cfg()
867 867  
868 -~-~-publish to topics
1255 +--publish to topics
869 869  
870 870  local pub_RE_TOPIC = string.format('TEST')
871 871  
872 -~-~-Subscribe topics
1259 +--Subscribe topics
873 873  
874 874  local Subscribe_RE_TOPIC1 = string.format('TEST')
875 875  
876 -~-~-variable
1263 +--variable
877 877  
878 878  local last_time = 0
879 879  
880 -~-~-Timing main function
1267 +--Timing main function
881 881  
882 882  function aws.main()
883 883  
884 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start")
1271 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start")
885 885  
886 - if g_mq then
1273 + if g_mq then
887 887  
888 - if g_mq:isconnected() then
1275 + if g_mq:isconnected() then
889 889  
890 - send_Data()
1277 + send_Data()
891 891  
892 - else
1279 + else
893 893  
894 - if os.time() - last_time > 5 then
1281 + if os.time() - last_time > 5 then
895 895  
896 - last_time = os.time()
1283 + last_time = os.time()
897 897  
898 - mymqtt_connect()
1285 + mymqtt_connect()
899 899  
1287 + end
1288 +
900 900   end
901 901  
902 - end
1291 + else
903 903  
904 - else
1293 + mymqtt_init()
905 905  
906 - mymqtt_init()
1295 + end
907 907  
908 - end
1297 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end")
909 909  
910 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end")
911 -
912 912  end
913 913  
914 914  
915 -~-~- Initialize MQTT
916 916  
1303 +-- Initialize MQTT
1304 +
917 917  function mymqtt_init()
918 918  
919 - sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID))
1307 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID))
920 920  
921 - g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable
1309 + 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
922 922  
923 - if g_mq then
1311 + if g_mq then
924 924  
925 - g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks
1313 + g_mq:on("message", mymqtt_msg_callback) -- Register to receive message callbacks
926 926  
927 - sprint("mqtt init success")
1315 + sprint("mqtt init success")
928 928  
929 - else
1317 + else
930 930  
931 - sprint("mqtt init failed:", err)
1319 + sprint("mqtt init failed:", err)
932 932  
933 - end
1321 + end
934 934  
935 935  end
936 936  
937 -~-~- Connect to MQTT server
1325 +-- Connect to MQTT server
938 938  
939 939  function mymqtt_connect()
940 940  
941 - sprint("mqtt connecting...")
1329 + sprint("mqtt connecting...")
942 942  
943 - local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART)
1331 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART)
944 944  
945 - if stat == nil then
1333 + if stat == nil then
946 946  
947 - sprint("mqtt connect failed:", err)
1335 + sprint("mqtt connect failed:", err)
948 948  
949 - return
1337 + return
950 950  
951 - else
1339 + else
952 952  
953 - sprint("mqtt connected")
1341 + sprint("mqtt connected")
954 954  
955 - end
1343 + end
956 956  
957 - g_mq:subscribe(TEST, 0)
1345 + g_mq:subscribe(Subscribe_RE_TOPIC1, 0)
958 958  
959 959  end
960 960  
961 -~-~- Receive MQTT message callback function
1349 +-- Receive MQTT message callback function
962 962  
963 963  function mymqtt_msg_callback(topic, msg)
964 964  
965 - print("topic:",topic)
1353 + print("topic:",topic)
966 966  
967 - print("revdata:",msg)
1355 + print("revdata:",msg)
968 968  
969 - local revData = json.decode(msg)
1357 + local revData = json.decode(msg)
970 970  
971 - print (revData)
1359 + print (revData)
972 972  
973 - if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud
1361 + if topic == Subscribe_RE_TOPIC1 then --Process topic information subscribed from the cloud
974 974  
975 -if string.match(topic,Subscribe_RE_TOPIC1) then
1363 + if string.match(topic,Subscribe_RE_TOPIC1) then
976 976  
977 - ~-~-if revData ~~= nil then
1365 + --if revData ~= nil then
978 978  
979 - for k,v in pairs (revData) do
1367 + for k,v in pairs (revData) do
980 980  
981 - print("printing revdata after kv here")
1369 + print("printing revdata after kv here")
982 982  
983 - print (k,v)
1371 + print (k,v)
984 984  
985 - end
1373 + end
986 986  
987 - print ("current state is",fanstate)
1375 + print ("current state is",fanstate)
988 988  
989 - ~-~-end
1377 + --end
990 990  
991 -end
1379 + end
992 992  
993 -end
1381 + end
994 994  
995 995  end
996 996  
997 997  
998 -~-~-Get real-time data
999 999  
1387 +--Get real-time data
1388 +
1000 1000  function getData()
1001 1001  
1002 - local jdata = {}
1391 + local jdata = {}
1003 1003  
1004 - local addr = bns_get_alldata()
1393 + local addr = bns_get_alldata()
1005 1005  
1006 - print(json.encode(addr))
1395 + print(json.encode(addr))
1007 1007  
1008 - for i,v in pairs(addr) do
1397 + for i,v in pairs(addr) do
1009 1009  
1010 - if v[2] == 1 then
1399 + if v[2] == 1 then
1011 1011  
1012 - jdata[v[3]] = v[4]
1401 + jdata[v[3]] = v[4]
1013 1013  
1014 - end
1403 + end
1015 1015  
1016 - end
1405 + end
1017 1017  
1018 - return jdata
1407 + return jdata
1019 1019  
1020 1020  end
1021 1021  
1022 -~-~-send data
1411 +--send data
1023 1023  
1024 1024  function send_Data()
1025 1025  
1026 - local pub_data =
1415 + local pub_data =
1416 + {
1417 + 123
1418 + }
1027 1027  
1028 - {
1029 -
1030 -123
1031 -
1032 -}
1033 -
1034 1034  sprint(json.encode(pub_data))
1035 1035  
1036 1036  print("..........",pub_RE_TOPIC)
1037 1037  
1038 - return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0)
1424 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0)
1039 1039  
1040 1040  end
1427 +{{/code}}
1041 1041  
1042 -
1043 -
1044 1044  Get message in AWS
1045 1045  
1046 -
1047 -|
1048 -| |[[image:image-20220709165402-21.png]]
1431 +[[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