Changes for page 2 Script

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

From version 51.1
edited by Hunter
on 2023/05/06 10:19
Change comment: There is no comment for this version
To version 19.1
edited by Hunter
on 2022/07/29 15:56
Change comment: There is no comment for this version

Summary

Details

Page properties
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.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.04 Lua Script.01 Lua Functions.WebHome]]
17 17  
18 18  == **1.2 Arithmetic** ==
19 19  
... ... @@ -27,19 +27,25 @@
27 27  
28 28  == **1.4 Short message** ==
29 29  
30 -The following demo shows that when the alarm condition is reached: temp1 > 5 & temp2 >10 & temp3 < 20(lasts more than 5 seconds) , then send an "alarm trigger" sms.
30 +When the alarm condition is reached: temp1 > 5 & temp2 >10 & temp3 < 20(lasts more than 5 seconds) , then send an "alarm trigger" sms.
31 31  
32 -When the alarm condition is released,then send an  "alarm release" sms. Script is as below:
32 +When the alarm condition is released,then send an "alarm release" sms.
33 33  
34 -{{code language="lua"}}
34 +(% style="text-align:center" %)
35 +[[image:1645535936750-316.png||height="385" width="400" class="img-thumbnail"]]
36 +
37 +Script is as below:
38 +
39 +(% class="box infomessage" %)
40 +(((
35 35  function sms.main()
36 -------send condition------
42 +~-~-~-~-~-~-send condition~-~-~-~-~-~-
37 37  local temp1 = addr_getword("@Temperature1")
38 38  local temp2 = addr_getword("@Temperature2")
39 39  local temp3 = addr_getword("@Temperature3")
40 40  local timer = addr_getword("@Timer")
41 41  local tag = addr_getbit("@Tag")
42 -------lasting time------
48 +~-~-~-~-~-~-lasting time~-~-~-~-~-~-
43 43  if temp1 > 5 and temp2 > 10 and temp3 < 20 then
44 44   timer = timer + 1
45 45   addr_setword("@Timer",timer)
... ... @@ -47,7 +47,7 @@
47 47   timer = 0
48 48   addr_setword("@Timer",timer)
49 49  end
50 -------send sms & output Y0------
56 +~-~-~-~-~-~-send sms & output Y0~-~-~-~-~-~-
51 51  if timer > 5 then
52 52   if tag == 0 then
53 53   send_sms_ira("19859254700","alarm trigger")
... ... @@ -58,18 +58,12 @@
58 58  addr_setbit("@Tag",0)
59 59  end
60 60  end
61 -{{/code}}
67 +)))
62 62  
63 63  == **1.5 Telegram notification** ==
64 64  
65 65  This example shows how to use the Bot API to send message into Telegram group or channel. When monitoring bit "@HDX" changes, it will trigger and send the message. Please replace with your own Token and chat id.
66 66  
67 -As for How to get the botToken and chatID, please check the followig videos:
68 -
69 -[[https:~~/~~/www.youtube.com/watch?v=zh6yYlnjX7k>>https://www.youtube.com/watch?v=zh6yYlnjX7k]]
70 -
71 -[[https:~~/~~/www.youtube.com/watch?v=Pj8mwuMZZvg>>https://www.youtube.com/watch?v=Pj8mwuMZZvg]]
72 -
73 73  {{code language="Lua"}}
74 74  local tempBit = 0
75 75  local tempWord = 0
... ... @@ -135,343 +135,7 @@
135 135  end
136 136  {{/code}}
137 137  
138 -== **1.6 LINE Notify** ==
139 139  
140 -This example shows how to use the LINE Notify to send message into LINE group. When monitoring bit "@test" changes, it will trigger and send the message. Please replace with your own Token.
141 -
142 -{{code language="lua"}}
143 -local tempBit = 0
144 -local tempWord = 0
145 -
146 -local LineToken = "08XCpubkOdwGdGgRTXF0x8umiyrALtoM0v6lBFUV6PC"
147 -
148 -local https = require("https")
149 -local json = require("json")
150 -local ltn12 = require("ltn12")
151 -
152 --- Send http.get request and return response result
153 -function getHttpsUrl(url,header,reqbody)
154 - local body = {}
155 - local bodyJson = json.encode(body)
156 - local result_table, code, headers, status = https.request{
157 - method = "POST",
158 - url = url,
159 - source = ltn12.source.string(reqbody),
160 - headers = header,
161 - sink = ltn12.sink.table(body)
162 - }
163 - print("code:"..code)
164 - if code~= 200 then
165 - return
166 - else
167 - return body
168 - end
169 -end
170 -
171 -function getMessageUrl(lineMessage)
172 - local url = "https://notify-api.line.me/api/notify"
173 - local reqMess = "message="..lineMessage
174 - local headers =
175 - {
176 - ["Authorization"] = "Bearer "..LineToken,
177 - ["Content-Type"] = "application/x-www-form-urlencoded",
178 - ["Content-Length"] = #reqMess
179 - }
180 -
181 - print("Get the link:"..url)
182 - getHttpsUrl(url, headers, reqMess)
183 -end
184 -
185 -
186 -function linenotify.main()
187 - local bitValue = addr_getbit("@test");
188 - local message = ''
189 - print("b=="..bitValue)
190 - if bitValue == 1 and bitValue ~= tempBit then
191 - message = 'Alarm V-Box triggered, the output is '.. bitValue
192 - getMessageUrl(message)
193 - print("Notification pushed of triggering alarm,"..bitValue)
194 - elseif bitValue == 0 and bitValue ~= tempBit then
195 - message = 'Alarm V-Box dismissed, the output is '.. bitValue
196 - getMessageUrl(message)
197 - print("Notification pushed of dismissing alarm,"..bitValue)
198 - end
199 - tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform
200 -
201 - local wordValue = addr_getword("@t2")
202 - print("w=="..wordValue)
203 - --dosomething
204 - if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then
205 - message = 'Alarm V-Box triggered, the temperature is '.. wordValue
206 - getMessageUrl(message)
207 - print("Notification pushed of triggering alarm,"..wordValue)
208 - elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then
209 - message = 'Alarm V-Box dismissed, the temperature is '.. wordValue
210 - getMessageUrl(message)
211 - print("Notification pushed of dismissing alarm,"..wordValue)
212 - end
213 - tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform
214 -end
215 -{{/code}}
216 -
217 -== **1.7 Twilio WhatsApp Messaging** ==
218 -
219 -This example shows how to use the Twilio API to send WhatsApp message to private number. When monitoring bit "@testBit" changes, it will trigger and send the message. Please replace with your own SID, Token, twilioPhoneNumber and receiverPhoneNumber.
220 -
221 -About how to register the Twilio API, please check the following video:
222 -
223 -[[https:~~/~~/www.youtube.com/watch?v=Id4lKichauU>>https://www.youtube.com/watch?v=Id4lKichauU]]
224 -
225 -{{code language="Lua"}}
226 -local tempBit = 0
227 -local tempWord = 0
228 -
229 -local https = require("https")
230 -local json = require("json")
231 -local ltn12 = require("ltn12")
232 -
233 -local SID = 'AC1703bd710ffa98006d2bcc0b********'
234 -local Token = 'd3c11897623c39e538b20263ec19****'
235 -
236 -local twilioPhoneNumber = '+14155238886'
237 -local receiverPhoneNumber = '+8615880018277'
238 -
239 -local b='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'
240 -function encodingBase64(data)
241 - return ((data:gsub('.', function(x)
242 - local r,b='',x:byte()
243 - for i=8,1,-1 do r=r..(b%2^i-b%2^(i-1)>0 and '1' or '0') end
244 - return r;
245 - end)..'0000'):gsub('%d%d%d?%d?%d?%d?', function(x)
246 - if (#x < 6) then return '' end
247 - local c=0
248 - for i=1,6 do c=c+(x:sub(i,i)=='1' and 2^(6-i) or 0) end
249 - return b:sub(c+1,c+1)
250 - end)..({ '', '==', '=' })[#data%3+1])
251 -end
252 -
253 -function encodeUrl(str)
254 - str = string.gsub(str, "([^%w%.%- ])", function(c)
255 - return string.format("%%%02X", string.byte(c)) end)
256 - return string.gsub(str, " ", "+")
257 -end
258 -
259 -
260 -
261 -
262 -function requestBodySplice(message, sender, receiver)
263 - local reqBody = ''
264 - local encodeMess = encodeUrl(message)
265 - local encodeSend = encodeUrl(sender)
266 - local encodeRece = encodeUrl(receiver)
267 - --reqBody = "Body=Hello%20Wecon2&From=whatsapp%3A%2B14155238886&To=whatsapp%3A%2B8615880018277"
268 - reqBody = string.format("Body=%s&From=whatsapp:%s&To=whatsapp:%s", encodeMess, encodeSend, encodeRece)
269 - print(reqBody)
270 - return reqBody
271 -end
272 -
273 -
274 --- Send http.get request and return response result
275 -function getHttpsUrl(url,header,reqbody)
276 - local body = {}
277 - local bodyJson = json.encode(body)
278 - local result_table, code, headers, status = https.request{
279 - method = "POST",
280 - url = url,
281 - source = ltn12.source.string(reqbody),
282 - headers = header,
283 - sink = ltn12.sink.table(body)
284 - }
285 - print("code:"..code)
286 - if code~= 200 then
287 - return
288 - else
289 - return body
290 - end
291 -end
292 -
293 -function getMessageUrl(whatsAppMessage)
294 - local auth = SID..':'..Token
295 - local url = "https://api.twilio.com/2010-04-01/Accounts/"..SID.."/Messages"
296 - --local reqMess = "message="..twilioMessage
297 - local reqMess = requestBodySplice(whatsAppMessage, twilioPhoneNumber, receiverPhoneNumber)
298 - local headers =
299 - {
300 - ["Authorization"] = "Basic "..encodingBase64(auth),
301 - ["Content-Type"] = "application/x-www-form-urlencoded",
302 - ["Content-Length"] = #reqMess
303 - }
304 -
305 - print("Get the link:"..url)
306 - getHttpsUrl(url, headers, reqMess)
307 -end
308 -
309 -
310 -
311 -function Twilio.main()
312 - --dosomething
313 - --local auth = SID..':'..Token
314 - --print(requestBodySplice("HelloWorld", twilioPhoneNumber, receiverPhoneNumber))
315 - --print(encodingBase64(auth))
316 - local bitValue = addr_getbit("@testBit");
317 - local message = ''
318 - print("b=="..bitValue)
319 - if bitValue == 1 and bitValue ~= tempBit then
320 - message = 'Alarm V-Box triggered, the output is '.. bitValue
321 - getMessageUrl(message)
322 - print("Notification pushed of triggering alarm,"..bitValue)
323 - elseif bitValue == 0 and bitValue ~= tempBit then
324 - message = 'Alarm V-Box dismissed, the output is '.. bitValue
325 - getMessageUrl(message)
326 - print("Notification pushed of dismissing alarm,"..bitValue)
327 - end
328 - tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform
329 -
330 - local wordValue = addr_getword("@testWord")
331 - print("w=="..wordValue)
332 - --dosomething
333 - if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then
334 - message = 'Alarm V-Box triggered, the temperature is '.. wordValue
335 - getMessageUrl(message)
336 - print("Notification pushed of triggering alarm,"..wordValue)
337 - elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then
338 - message = 'Alarm V-Box dismissed, the temperature is '.. wordValue
339 - getMessageUrl(message)
340 - print("Notification pushed of dismissing alarm,"..wordValue)
341 - end
342 - tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform
343 -end
344 -{{/code}}
345 -
346 -== **1.8 How to parse value from HTTP response body** ==
347 -
348 -This example use [[https:~~/~~/www.weatherapi.com/>>https://www.weatherapi.com/]] as example, to show how to parse value from HTTP response body. When we input the city name into address "@HDW5050":
349 -
350 -(% style="text-align:center" %)
351 -[[image:InputHTTPparameter.png]]
352 -
353 -Then the response body would be like as following:
354 -
355 -{{code language="json"}}
356 -{
357 - "location": {
358 - "name": "Madrid",
359 - "region": "Madrid",
360 - "country": "Spain",
361 - "lat": 40.4,
362 - "lon": -3.68,
363 - "tz_id": "Europe/Madrid",
364 - "localtime_epoch": 1669022636,
365 - "localtime": "2022-11-21 10:23"
366 - },
367 - "current": {
368 - "last_updated_epoch": 1669022100,
369 - "last_updated": "2022-11-21 10:15",
370 - "temp_c": 13.0,
371 - "temp_f": 55.4,
372 - "is_day": 1,
373 - "condition": {
374 - "text": "Partly cloudy",
375 - "icon": "//cdn.weatherapi.com/weather/64x64/day/116.png",
376 - "code": 1003
377 - },
378 - "wind_mph": 11.9,
379 - "wind_kph": 19.1,
380 - "wind_degree": 210,
381 - "wind_dir": "SSW",
382 - "pressure_mb": 1015.0,
383 - "pressure_in": 29.97,
384 - "precip_mm": 0.0,
385 - "precip_in": 0.0,
386 - "humidity": 88,
387 - "cloud": 75,
388 - "feelslike_c": 10.8,
389 - "feelslike_f": 51.4,
390 - "vis_km": 10.0,
391 - "vis_miles": 6.0,
392 - "uv": 3.0,
393 - "gust_mph": 22.1,
394 - "gust_kph": 35.6
395 - }
396 -}
397 -{{/code}}
398 -
399 -(% class="wikigeneratedid" %)
400 -So we decode json into lua object to assign the value into addresses HDW6060(temperature), HDW7070(humidity), the code example like follows:
401 -
402 -{{code language="lua"}}
403 -local APIkey = '70faaecf926b4341b1974006221711'
404 -
405 -
406 -local http = require("socket.http")
407 -local json = require("json")
408 -
409 --- Send http.get request and return response result
410 -function getHttpsUrl(url)
411 - local result_table, code, headers, status = http.request(url)
412 - print("code:"..code)
413 - if code~= 200 then
414 - return
415 - else
416 - return result_table
417 - end
418 -end
419 -
420 -function sendAPI(key, city)
421 - local url = "http://api.weatherapi.com/v1/current.json?key="..key.."&q="..city.."&aqi=no"
422 - --local url = 'http://v-box.net'
423 - --local url = 'https://www.google.com/'
424 - --http://api.weatherapi.com/v1/current.json?key=70faaecf926b4341b1974006221711&q=Barcelona&aqi=no
425 - print("Get the link:"..url)
426 - local body = getHttpsUrl(url)
427 - --print(body)
428 - local jsonBody = json.decode(body)
429 - --print(jsonBody["current"]["temp_c"])
430 - --print(type(jsonBody["current"]["temp_c"]))
431 - --print(type(jsonBody["current"]["humidity"]))
432 - addr_setfloat("@HDW6060", jsonBody["current"]["temp_c"])
433 - addr_setword("@HDW7070", jsonBody["current"]["humidity"])
434 -end
435 -
436 -
437 -function Weather.main()
438 - local cityName = addr_getstring("@HDW5050",6)
439 - print("cityName: "..cityName)
440 - sendAPI(APIkey, cityName)
441 -end
442 -{{/code}}
443 -
444 -== **1.9 High-Low Byte Switch** ==
445 -
446 -The following example is converting the floating number from order 1234 to order 3412, and formating output the number with 2 decimal point. About which high-low word order corresponding to which value, please refer to the [[Address Operation Table>>doc:V-BOX.V-Net.Manual.04 Lua Script.01 Lua Functions.WebHome||anchor="H2Addressoperation"]].
447 -
448 -{{code language="lua"}}
449 -function highLowByteSwitch(floatNumber)
450 - addr_setfloat("@W_0#HDW23036",floatNumber,0,2)
451 - local newFloat = addr_getfloat("@W_0#HDW23036")
452 - local formattedFloat = string.format("%.2f",newFloat)
453 - print("The formatted float value is the : "..formattedFloat)
454 - return formattedFloat
455 -end
456 -{{/code}}
457 -
458 -== **1.10 Read 64bits Unsigned Value** ==
459 -
460 -In our built-in function library doesn't have the function for reading 64-bit unsigned format value, so the following function is for solve this. But if the number is greater 2^53, the precision will be lost. So the final result will be a little bit different from the original value.
461 -
462 -{{code language="lua"}}
463 -function addr_getquatra(address)
464 - local highAddress = addr_newnoaddr(address,2)
465 - local low32 = addr_getdword(address)
466 - local high32 = addr_getdword(highAddress)
467 - --print("the low number is "..low32)
468 - --print("the high number is "..high32)
469 - local formatVal = string.format("%64.0f",2^32*high32+low32)
470 - print("the format value is ".. formatVal)
471 - return formatVal
472 -end
473 -{{/code}}
474 -
475 475  = **2 V-Box connect with third part server** =
476 476  
477 477  V-Box have two mode.One is for V-Net,User need to use WECON server to store data.We call this V-NET platform.
... ... @@ -490,304 +490,157 @@
490 490  
491 491  (% class="mark" %)2.If your server requires SSL certificate to log in,please use OpenCloud.Because only OpenCloud platform can support to upload certificate
492 492  
493 -{{info}}
494 -**✎Note: **Before program the script of MQTT, please make sure the server(MQTT broker) can be connected through MQTT Client tool.
495 -{{/info}}
157 +== **2.1 V-Box connect with customer server:grouprobotinfo.com** ==
496 496  
497 -(% class="wikigeneratedid" %)
498 -Tool link: **[[MQTT.fx>>http://mqttfx.jensd.de/index.php/download]]**
159 +This demo does not use SSL certification. Script is as below
499 499  
500 -== **2.1 V-Box connect with test server(General Example)** ==
161 +Demo1:
501 501  
502 -The following example is trying to publish to the topic "testtopic/test/no1/7890", and subscribe the topic "testtopic/test/no1/123456".
503 -
504 -And the JSON message is like follows:
505 -
506 -{{code language="JSON"}}
507 -{
508 - "timestamp": 1631152760,
509 - "messageId": 1,
510 - "event": "test_data",
511 - "mfrs": "HMI/box",
512 - "data":
513 - {
514 - "id" : 1436217747670454274,
515 - "waterlevel" : 48,
516 - "temperture" : 23
517 - }
518 -}
519 -{{/code}}
520 -
521 521  {{code language="lua"}}
522 ---MQTT configuration table
523 -local MQTT_CFG={}
524 -MQTT_CFG.username = "weconsupport"
525 -MQTT_CFG.password = "123456"
526 -MQTT_CFG.netway = 0
527 -MQTT_CFG.keepalive = 60
528 -MQTT_CFG.cleansession = 1
529 ---TCP URL
530 -MQTT_URL = "tcp://mq.tongxinmao.com:1883"
531 ---Client ID
532 -MQTT_CLIENT_ID = "V-BOXH-AG"
164 +-- Meta class
165 +--main
166 +function mq.main()
167 + if not mq.m then
168 +  local err = ""
533 533  
534 ---Generate UUID
535 -function uuid()
536 - local seed = {'e','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'}
537 - local tb = {}
538 - for i=1, 32 do
539 - table.insert(tb, seed[math.random(1,16)])
540 - end
541 - local sid=table.concat(tb)
542 - return string.format('%s',
543 - string.sub(sid,1,32)
544 - )
545 -end
170 +  mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID")  -- create connection
171 +  if mq.m then
172 +   mq.config = {
173 +    username = "",-- ID
174 +    password = "",-- password
175 +    netway = 1, -- Ethernet connection, WIFI=1
176 +    -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds.
177 +    -- cleansession = 0, -- Optional, keep session
178 +   }
179 +   mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks
180 +    local str = string.format("%s:%s", topic, msg)
181 +    -- print("mqtt msg:", str) -- Print out the received topics and content
182 +   end
183 +   )
184 +   mq.m:on("offline", function (cause) -- Register for lost connection callbacks
185 +    -- addr_setstring("@xxx", "cause"..(cause or " got nil"))
186 +   end)
187 +   mq.m:on("arrived", function() -- Registration for sending messages to callbacks 
188 +    print("msg arrived")
189 +   end)
190 +  else
191 +   print("mqtt create failed:", err) -- Create object failed
192 +  end
193 + else
194 +  if mq.m:isconnected() then -- If online, post a message
195 +     local phaseStatus ="unknow"
196 +     if addr_getbit("@Standby")== 1 then
197 +         phaseStatus = "Standby"
198 +     elseif addr_getbit("@Pre-Freeze")==1 then
199 +         phaseStatus= "Pre-Freeze"
200 +     elseif addr_getbit("@Prepare")==1 then
201 +         phaseStatus ="Prepare"
202 +     elseif addr_getbit("@Primary Dry")==1 then
203 +         phaseStatus = "Primary dry"
204 +     elseif addr_getbit("@Secondary Dry")==1 then
205 +         phaseStatus = "Secondary Dry"
206 +     end
207 +--   print(addr_getbit("@Primary Dry"))
208 +-------------------------------------------------------------------------------------------------------------------------
209 +     local activating ="unknow"
210 +     if addr_getbit("@Compressor")==1 then
211 +         activating = ",".."Compressor"
212 +     end
213 +     if addr_getbit("@Silicone Pump")==1 then
214 +         activating = activating..",".."Silicone Pump"
215 +     end
216 +     if addr_getbit("@Vacuum Pump")==1 then
217 +         activating = activating..",".."Vacuum Pump"
218 +     end
219 +     if addr_getbit("@Root Pump")==1 then
220 +         activating = activating..",".."Root Pump"
221 +     end
222 +     if addr_getbit("@Heater")==1 then
223 +         activating = activating..",".."Heater"
224 +     end
225 +     if addr_getbit("@Valve Silicone")==1 then
226 +         activating = activating..",".."Valve Silicone"
227 +     end
228 +     if addr_getbit("@Valve Ice Condenser")==1 then
229 +         activating = activating..",".."Valve Ice Condenser"
230 +     end
231 +     if addr_getbit("@Valve Vacuum Pump")==1 then
232 +         activating = activating..",".."Valve Vacuum Pump"
233 +     end
234 +     local pr_activating =string.sub(activating,2)
235 +    --  print(pr_activating)  
546 546  
547 547  
548 ---Topic name to subscribed
549 -local SUBSCRIBE_TOPIC = 'testtopic/test/no1/123456'
550 550  
551 ---Topic name to be published
552 -local PUBLISH_TOPIC = 'testtopic/test/no1/7890'
239 +     local status_text ="unknow"
240 +     if addr_getbit("@Status Run")==1 then
241 +         status_text = "RUNNING"
242 +     else
243 +         status_text = "STOP"
244 +     end
245 +-------------------------------------------------------------------------------------------------------------------------      
553 553  
247 +     local js =  {type="status",
248 +                  mc_name ="FD300",
249 +                  status=status_text,
250 +                  elapsed_time={
251 +                                hour=addr_getword("@Elapsed Time (Hour)"),
252 +                                min=addr_getword("@Elapsed Time (Minute)"),
253 +                                sec=addr_getword("@Elapsed Time (Second)")
254 +                                },
255 +                   phase = phaseStatus,
256 +                   step = addr_getword("@Step"),
257 +                   activating_output = pr_activating,
258 +                   sv=addr_getshort("@SV Silicone")/10,
259 +                   pv=addr_getshort("@PV Silicone")/10,
260 +                   product1=addr_getshort("@Product 1")/10,
554 554  
555 ---real time
556 -local LAST_TIME = 0
262 +                   product2=addr_getshort("@Product 2")/10,
263 +                   product3=addr_getshort("@Product 3")/10,
264 +                   product4=addr_getshort("@Product 4")/10,
265 +                   ice1=addr_getshort("@Ice condenser 1")/10,
266 +                   ice2=addr_getshort("@Ice condenser 2")/10,
267 +                   vacuum=addr_getfloat("@Vacuum")
557 557  
269 +                }
270 +     local jsAlarm = {  HPC = addr_getbit("@B_25395#W0.00"),
271 +                        ODPC = addr_getbit("@B_25395#W0.01"),
272 +                        MTPC=addr_getbit("@B_25395#W0.02"),
273 +                        HTT = addr_getbit("@B_25395#W1.03"),
274 +                        CPC = addr_getbit("@B_25395#W0.08"),
275 +                        CPSP =addr_getbit("@B_25395#W1.00"),
276 +                        CPVP =addr_getbit("@B_25395#W0.10"),
277 +                        CPRP =addr_getbit("@B_25395#W0.11"),
278 +                        HP =addr_getbit("@B_25395#W1.01"),
279 +                        PP= addr_getbit("@B_25395#W1.02"),
280 +                        PO=addr_getbit("@B_25395#W0.07"),
281 +                        FSE=addr_getbit("@B_25395#W2.04"),
282 +                        AVVSVV=addr_getbit("@B_25395#W1.12"),
283 +                        ICHT=addr_getbit("@B_25395#W3.06")
558 558  
559 ---initialize mqtt
560 -function mqtt_init()
561 - print(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENT_ID))
562 - if g_mq then
563 - mqtt.close() --Close mqtt object
564 - end
565 - g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENT_ID) -- create mqtt object,and declare it as a global variable
566 - if g_mq then
567 - g_mq:on("message", mqtt_msg_callback) -- Register a callback for receiving messages
568 - g_mq:on("offline", mqtt_msg_offline) -- Register a callback for offline
569 - print("mqtt init success")
570 - else
571 - print("mqtt init failed:", err)
572 - end
573 -end
285 +                }
574 574  
575 --- connect to mqtt
576 -function mqtt_connect()
577 - print("mqtt connecting...")
578 - local stat, err = g_mq:connect(MQTT_CFG)
579 - if stat == nil then
580 - print("mqtt connect failed:", err)
581 - return
582 - else
583 - print("mqtt connected")
584 - end
585 - g_mq:subscribe(SUBSCRIBE_TOPIC, 0)
586 -end
287 +    -- ("@B_25395#CIO1.02")
288 +     mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0)
289 +     mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0)
290 +  else
291 +   local stat, err = mq.m:connect(mq.config) -- connection
292 +   if stat == nil then --Determine whether to connect
293 +    print("mqtt connect failed:", err)
294 +    return -- Connection failed, return directly
295 +   end
296 +   mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics
587 587  
588 ---Offline callback function
589 -function mqtt_msg_offline(cause)
590 - print("mqtt offline, cause:", cause)
298 +  end
299 +  -- mq.m:unsubscribe("stc/test")
300 +  -- mq.m:disconnect() -- close matt
301 +  -- mq.m:close() -- close clase
302 + end
591 591  end
592 -
593 --- Received message callback function
594 -function mqtt_msg_callback(topic, msg)
595 - print("topic:", topic)
596 - print("msg:", msg)
597 - local objMsg = json.decode(msg)
598 - local water = objMsg.data.waterlevel
599 - local temp = objMsg.data.temperature
600 - addr_setword("@HDW20",water)
601 - addr_setword("@HDW10",temp)
602 -end
603 -
604 ---Send data (data upload to platform and encapsulate it with custom functions)
605 -function send_data()
606 - local pub_data = {
607 - timestamp = os.time(),
608 - messageId = 1,
609 - event = 'test_data',
610 - mfrs = 'V-Box',
611 - data = {
612 - id = uuid(),
613 - waterlevel = addr_getword("@HDW10"),
614 - temperature = addr_getword("@HDW20")
615 - }
616 - }
617 - return g_mq:publish(PUBLISH_TOPIC, json.encode(pub_data), 0, 0)
618 -end
619 -
620 -
621 ---main function fixed timed execution
622 -function MQTT.main()
623 - --dosomething
624 - print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main start")
625 - --determine the mqtt object whether exist
626 - if g_mq then
627 - --determine the mqtt object whether has been connected or not
628 - if g_mq:isconnected() then
629 - send_data()
630 - else
631 - --if exceed 5 sec not connect, reconnect once
632 - if os.time() - LAST_TIME > 5 then
633 - LAST_TIME = os.time()
634 - --reinitial the mqtt object
635 - mqtt_init()
636 - --connect to mqtt or reconnect
637 - mqtt_connect()
638 - end
639 - end
640 - else
641 - --mqtt object does not exist so create new one
642 - mqtt_init()
643 - end
644 - print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main end")
645 -end
646 646  {{/code}}
647 647  
648 -== **2.2 V-Box connect with customer server:grouprobotinfo.com** ==
306 +== **2.2 V-Box connect with Azure platform** ==
649 649  
650 -This demo does not use SSL certification. Script is as below
651 -
652 -Demo1:
653 -
654 -{{code language="lua"}}
655 --- Meta class
656 ---main
657 -function mq.main()
658 - if not mq.m then
659 - local err = ""
660 -
661 - mq.m, err = mqtt.create("tcp://grouprobotinfo.com:1883", "ClienID") -- create connection
662 - if mq.m then
663 - mq.config = {
664 - username = "",-- ID
665 - password = "",-- password
666 - netway = 1, -- Ethernet connection, WIFI=1
667 - -- keepalive = 100, -- Optional, set the connection heartbeat interval for 100 seconds.
668 - -- cleansession = 0, -- Optional, keep session
669 - }
670 - mq.m:on("message", function(topic, msg) -- Register for receiving message callbacks
671 - local str = string.format("%s:%s", topic, msg)
672 - -- print("mqtt msg:", str) -- Print out the received topics and content
673 - end)
674 - mq.m:on("offline", function (cause) -- Register for lost connection callbacks
675 - -- addr_setstring("@xxx", "cause"..(cause or " got nil"))
676 - end)
677 - mq.m:on("arrived", function() -- Registration for sending messages to callbacks
678 - print("msg arrived")
679 - end)
680 - else
681 - print("mqtt create failed:", err) -- Create object failed
682 - end
683 - else
684 - if mq.m:isconnected() then -- If online, post a message
685 - local phaseStatus ="unknow"
686 - if addr_getbit("@Standby")== 1 then
687 - phaseStatus = "Standby"
688 - elseif addr_getbit("@Pre-Freeze")==1 then
689 - phaseStatus= "Pre-Freeze"
690 - elseif addr_getbit("@Prepare")==1 then
691 - phaseStatus ="Prepare"
692 - elseif addr_getbit("@Primary Dry")==1 then
693 - phaseStatus = "Primary dry"
694 - elseif addr_getbit("@Secondary Dry")==1 then
695 - phaseStatus = "Secondary Dry"
696 - end
697 - --print(addr_getbit("@Primary Dry"))
698 --------------------------------------------------------------------------------------------------------------------------
699 - local activating ="unknow"
700 - if addr_getbit("@Compressor")==1 then
701 - activating = ",".."Compressor"
702 - end
703 - if addr_getbit("@Silicone Pump")==1 then
704 - activating = activating..",".."Silicone Pump"
705 - end
706 - if addr_getbit("@Vacuum Pump")==1 then
707 - activating = activating..",".."Vacuum Pump"
708 - end
709 - if addr_getbit("@Root Pump")==1 then
710 - activating = activating..",".."Root Pump"
711 - end
712 - if addr_getbit("@Heater")==1 then
713 - activating = activating..",".."Heater"
714 - end
715 - if addr_getbit("@Valve Silicone")==1 then
716 - activating = activating..",".."Valve Silicone"
717 - end
718 - if addr_getbit("@Valve Ice Condenser")==1 then
719 - activating = activating..",".."Valve Ice Condenser"
720 - end
721 - if addr_getbit("@Valve Vacuum Pump")==1 then
722 - activating = activating..",".."Valve Vacuum Pump"
723 - end
724 - local pr_activating =string.sub(activating,2)
725 - -- print(pr_activating)
726 - local status_text ="unknow"
727 - if addr_getbit("@Status Run")==1 then
728 - status_text = "RUNNING"
729 - else
730 - status_text = "STOP"
731 - end
732 --------------------------------------------------------------------------------------------------------------------------
733 - local js = {type="status",
734 - mc_name ="FD300",
735 - status=status_text,
736 - elapsed_time={
737 - hour=addr_getword("@Elapsed Time (Hour)"),
738 - min=addr_getword("@Elapsed Time (Minute)"),
739 - sec=addr_getword("@Elapsed Time (Second)")
740 - },
741 - phase = phaseStatus,
742 - step = addr_getword("@Step"),
743 - activating_output = pr_activating,
744 - sv=addr_getshort("@SV Silicone")/10,
745 - pv=addr_getshort("@PV Silicone")/10,
746 - product1=addr_getshort("@Product 1")/10,
747 -
748 - product2=addr_getshort("@Product 2")/10,
749 - product3=addr_getshort("@Product 3")/10,
750 - product4=addr_getshort("@Product 4")/10,
751 - ice1=addr_getshort("@Ice condenser 1")/10,
752 - ice2=addr_getshort("@Ice condenser 2")/10,
753 - vacuum=addr_getfloat("@Vacuum")
754 - }
755 - local jsAlarm = { HPC = addr_getbit("@B_25395#W0.00"),
756 - ODPC = addr_getbit("@B_25395#W0.01"),
757 - MTPC=addr_getbit("@B_25395#W0.02"),
758 - HTT = addr_getbit("@B_25395#W1.03"),
759 - CPC = addr_getbit("@B_25395#W0.08"),
760 - CPSP =addr_getbit("@B_25395#W1.00"),
761 - CPVP =addr_getbit("@B_25395#W0.10"),
762 - CPRP =addr_getbit("@B_25395#W0.11"),
763 - HP =addr_getbit("@B_25395#W1.01"),
764 - PP= addr_getbit("@B_25395#W1.02"),
765 - PO=addr_getbit("@B_25395#W0.07"),
766 - FSE=addr_getbit("@B_25395#W2.04"),
767 - AVVSVV=addr_getbit("@B_25395#W1.12"),
768 - ICHT=addr_getbit("@B_25395#W3.06")
769 - }
770 - -- ("@B_25395#CIO1.02")
771 - mq.m:publish("mqtt-v-box-epsilon-fd300", json.encode(js) , 0, 0)
772 - mq.m:publish("mqtt-v-box-epsilon-alarm-fd300", json.encode(jsAlarm) , 0, 0)
773 - else
774 - local stat, err = mq.m:connect(mq.config) -- connection
775 - if stat == nil then --Determine whether to connect
776 - print("mqtt connect failed:", err)
777 - return -- Connection failed, return directly
778 - end
779 - mq.m:subscribe("mqtt-v-box-epsilon", 0)-- Subscribe to topics
780 -
781 - end
782 - -- mq.m:unsubscribe("stc/test")
783 - -- mq.m:disconnect() -- close matt
784 - -- mq.m:close() -- close clase
785 - end
786 -end
787 -{{/code}}
788 -
789 -== **2.3 V-Box connect with Azure platform** ==
790 -
791 791  In this demo,V-Box connects with Azure by SSL certification.
792 792  
793 793  Video link: [[https:~~/~~/youtu.be/cdI6rIQcpMY?list=PL_Bpnb2RgaksCic9HCcVAZhU9sYwCRKzW>>https://youtu.be/cdI6rIQcpMY?list=PL_Bpnb2RgaksCic9HCcVAZhU9sYwCRKzW]]
... ... @@ -917,7 +917,7 @@
917 917  end
918 918  )))
919 919  
920 -== **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)** ==
437 +== **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)** ==
921 921  
922 922  1.Register a account: [[https:~~/~~/www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ>>https://www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ]]
923 923  
... ... @@ -1066,7 +1066,7 @@
1066 1066  (% style="text-align:center" %)
1067 1067  [[image:1624441186851-536.png||height="434" width="700" class="img-thumbnail"]]
1068 1068  
1069 -== **2.5 V-Box connect with Huawei platform** ==
586 +== **2.4 V-Box connect with Huawei platform** ==
1070 1070  
1071 1071  In this demo,V-Box connects with Huawei by SSL certification.
1072 1072  
... ... @@ -1187,7 +1187,7 @@
1187 1187  (% style="text-align:center" %)
1188 1188  [[image:1624506666650-161.png||height="547" width="1000" class="img-thumbnail"]]
1189 1189  
1190 -== **2.6 V-Box connect with AWS platform** ==
707 +== **2.5 V-Box connect with AWS platform** ==
1191 1191  
1192 1192  === **Log in AWS** ===
1193 1193  
... ... @@ -1212,20 +1212,35 @@
1212 1212  
1213 1213  {{code language="java"}}
1214 1214  {
732 +
1215 1215    "Version": "2012-10-17",
734 +
1216 1216    "Statement": [
736 +
1217 1217      {
738 +
1218 1218        "Effect": "Allow",
740 +
1219 1219        "Action": [
742 +
1220 1220          "iot:Connect",
744 +
1221 1221          "iot:Publish",
746 +
1222 1222          "iot:Subscribe",
748 +
1223 1223          "iot:Receive",
750 +
1224 1224          "greengrass:Discover"
752 +
1225 1225        ],
754 +
1226 1226        "Resource": "*"
756 +
1227 1227      }
758 +
1228 1228    ]
760 +
1229 1229  }
1230 1230  {{/code}}
1231 1231  
... ... @@ -1290,190 +1290,185 @@
1290 1290  
1291 1291  [[image:image-20220709165402-20.png]]
1292 1292  
1293 -{{info}}
1294 -**✎Note:** Before using the following demo script, please make sure the V-Box firmware is newer than 22110701
1295 -{{/info}}
1296 -
1297 -{{code language="lua"}}
1298 1298  sprint = print
1299 1299  
1300 ---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)
827 +~-~-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)
1301 1301  
1302 1302  local MQTT_URL, MQTT_CLIENTID, MQTT_CFG, MQTT_LWT, MQTT_CART = mqtt.setup_cfg()
1303 1303  
1304 ---publish to topics
831 +~-~-publish to topics
1305 1305  
1306 1306  local pub_RE_TOPIC = string.format('TEST')
1307 1307  
1308 ---Subscribe topics
835 +~-~-Subscribe topics
1309 1309  
1310 1310  local Subscribe_RE_TOPIC1 = string.format('TEST')
1311 1311  
1312 ---variable
839 +~-~-variable
1313 1313  
1314 1314  local last_time = 0
1315 1315  
1316 ---Timing main function
843 +~-~-Timing main function
1317 1317  
1318 1318  function aws.main()
1319 1319  
1320 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start")
847 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main start")
1321 1321  
1322 - if g_mq then
849 + if g_mq then
1323 1323  
1324 - if g_mq:isconnected() then
851 + if g_mq:isconnected() then
1325 1325  
1326 - send_Data()
853 + send_Data()
1327 1327  
1328 - else
855 + else
1329 1329  
1330 - if os.time() - last_time > 5 then
857 + if os.time() - last_time > 5 then
1331 1331  
1332 - last_time = os.time()
859 + last_time = os.time()
1333 1333  
1334 - mymqtt_connect()
861 + mymqtt_connect()
1335 1335  
1336 - end
1337 -
1338 1338   end
1339 1339  
1340 - else
865 + end
1341 1341  
1342 - mymqtt_init()
867 + else
1343 1343  
1344 - end
869 + mymqtt_init()
1345 1345  
1346 - sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end")
871 + end
1347 1347  
873 + sprint(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " aws.main end")
874 +
1348 1348  end
1349 1349  
1350 1350  
878 +~-~- Initialize MQTT
1351 1351  
1352 --- Initialize MQTT
1353 -
1354 1354  function mymqtt_init()
1355 1355  
1356 - sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID))
882 + sprint(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENTID))
1357 1357  
1358 - 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
884 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENTID) ~-~- Create the object and declare it as a global variable
1359 1359  
1360 - if g_mq then
886 + if g_mq then
1361 1361  
1362 - g_mq:on("message", mymqtt_msg_callback) -- Register to receive message callbacks
888 + g_mq:on("message", mymqtt_msg_callback) ~-~- Register to receive message callbacks
1363 1363  
1364 - sprint("mqtt init success")
890 + sprint("mqtt init success")
1365 1365  
1366 - else
892 + else
1367 1367  
1368 - sprint("mqtt init failed:", err)
894 + sprint("mqtt init failed:", err)
1369 1369  
1370 - end
896 + end
1371 1371  
1372 1372  end
1373 1373  
1374 --- Connect to MQTT server
900 +~-~- Connect to MQTT server
1375 1375  
1376 1376  function mymqtt_connect()
1377 1377  
1378 - sprint("mqtt connecting...")
904 + sprint("mqtt connecting...")
1379 1379  
1380 - local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART)
906 + local stat, err = g_mq:connect(MQTT_CFG,MQTT_LWT, MQTT_CART)
1381 1381  
1382 - if stat == nil then
908 + if stat == nil then
1383 1383  
1384 - sprint("mqtt connect failed:", err)
910 + sprint("mqtt connect failed:", err)
1385 1385  
1386 - return
912 + return
1387 1387  
1388 - else
914 + else
1389 1389  
1390 - sprint("mqtt connected")
916 + sprint("mqtt connected")
1391 1391  
1392 - end
918 + end
1393 1393  
1394 - g_mq:subscribe(Subscribe_RE_TOPIC1, 0)
920 + g_mq:subscribe(TEST, 0)
1395 1395  
1396 1396  end
1397 1397  
1398 --- Receive MQTT message callback function
924 +~-~- Receive MQTT message callback function
1399 1399  
1400 1400  function mymqtt_msg_callback(topic, msg)
1401 1401  
1402 - print("topic:",topic)
928 + print("topic:",topic)
1403 1403  
1404 - print("revdata:",msg)
930 + print("revdata:",msg)
1405 1405  
1406 - local revData = json.decode(msg)
932 + local revData = json.decode(msg)
1407 1407  
1408 - print (revData)
934 + print (revData)
1409 1409  
1410 - if topic == Subscribe_RE_TOPIC1 then --Process topic information subscribed from the cloud
936 + if topic == Subscribe_RE_TOPIC1 then ~-~-Process topic information subscribed from the cloud
1411 1411  
1412 - if string.match(topic,Subscribe_RE_TOPIC1) then
938 +if string.match(topic,Subscribe_RE_TOPIC1) then
1413 1413  
1414 - --if revData ~= nil then
940 + ~-~-if revData ~~= nil then
1415 1415  
1416 - for k,v in pairs (revData) do
942 + for k,v in pairs (revData) do
1417 1417  
1418 - print("printing revdata after kv here")
944 + print("printing revdata after kv here")
1419 1419  
1420 - print (k,v)
946 + print (k,v)
1421 1421  
1422 - end
948 + end
1423 1423  
1424 - print ("current state is",fanstate)
950 + print ("current state is",fanstate)
1425 1425  
1426 - --end
952 + ~-~-end
1427 1427  
1428 - end
954 +end
1429 1429  
1430 - end
956 +end
1431 1431  
1432 1432  end
1433 1433  
1434 1434  
961 +~-~-Get real-time data
1435 1435  
1436 ---Get real-time data
1437 -
1438 1438  function getData()
1439 1439  
1440 - local jdata = {}
965 + local jdata = {}
1441 1441  
1442 - local addr = bns_get_alldata()
967 + local addr = bns_get_alldata()
1443 1443  
1444 - print(json.encode(addr))
969 + print(json.encode(addr))
1445 1445  
1446 - for i,v in pairs(addr) do
971 + for i,v in pairs(addr) do
1447 1447  
1448 - if v[2] == 1 then
973 + if v[2] == 1 then
1449 1449  
1450 - jdata[v[3]] = v[4]
975 + jdata[v[3]] = v[4]
1451 1451  
1452 - end
977 + end
1453 1453  
1454 - end
979 + end
1455 1455  
1456 - return jdata
981 + return jdata
1457 1457  
1458 1458  end
1459 1459  
1460 ---send data
985 +~-~-send data
1461 1461  
1462 1462  function send_Data()
1463 1463  
1464 - local pub_data =
1465 - {
1466 - 123
1467 - }
989 + local pub_data =
1468 1468  
991 + {
992 +
993 +123
994 +
995 +}
996 +
1469 1469  sprint(json.encode(pub_data))
1470 1470  
1471 1471  print("..........",pub_RE_TOPIC)
1472 1472  
1473 - return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0)
1001 + return g_mq:publish(pub_RE_TOPIC, json.encode(pub_data), 0, 0)
1474 1474  
1475 1475  end
1476 -{{/code}}
1477 1477  
1478 1478  Get message in AWS
1479 1479  
InputHTTPparameter.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.Hunter
Size
... ... @@ -1,1 +1,0 @@
1 -17.9 KB
Content