Changes for page 2 Script
Last modified by Devin Chen on 2025/06/06 14:03
Summary
-
Page properties (1 modified, 0 added, 0 removed)
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.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 ... ... @@ -135,7 +135,210 @@ 135 135 end 136 136 {{/code}} 137 137 138 +== **1.6 LINE Notify** == 138 138 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}} 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 "@test" changes, it will trigger and send the message. Please replace with your own SID, Token, twilioPhoneNumber and receiverPhoneNumber. 220 + 221 +{{code language="Lua"}} 222 +local tempBit = 0 223 +local tempWord = 0 224 + 225 +local https = require("https") 226 +local json = require("json") 227 +local ltn12 = require("ltn12") 228 + 229 +local SID = 'AC1703bd710ffa98006d2bcc0b8d6ca63a' 230 +local Token = 'd3c11897623c39e538b20263ec190ae0' 231 + 232 +local twilioPhoneNumber = '+14155238886' 233 +local receiverPhoneNumber = '+8615880018277' 234 + 235 +local b='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/' 236 +function encodingBase64(data) 237 + return ((data:gsub('.', function(x) 238 + local r,b='',x:byte() 239 + for i=8,1,-1 do r=r..(b%2^i-b%2^(i-1)>0 and '1' or '0') end 240 + return r; 241 + end)..'0000'):gsub('%d%d%d?%d?%d?%d?', function(x) 242 + if (#x < 6) then return '' end 243 + local c=0 244 + for i=1,6 do c=c+(x:sub(i,i)=='1' and 2^(6-i) or 0) end 245 + return b:sub(c+1,c+1) 246 + end)..({ '', '==', '=' })[#data%3+1]) 247 +end 248 + 249 +function encodeUrl(str) 250 + str = string.gsub(str, "([^%w%.%- ])", function(c) 251 + return string.format("%%%02X", string.byte(c)) end) 252 + return string.gsub(str, " ", "+") 253 +end 254 + 255 + 256 + 257 + 258 +function requestBodySplice(message, sender, receiver) 259 + local reqBody = '' 260 + local encodeMess = encodeUrl(message) 261 + local encodeSend = encodeUrl(sender) 262 + local encodeRece = encodeUrl(receiver) 263 + --reqBody = "Body=Hello%20Wecon2&From=whatsapp%3A%2B14155238886&To=whatsapp%3A%2B8615880018277" 264 + reqBody = string.format("Body=%s&From=whatsapp:%s&To=whatsapp:%s", encodeMess, encodeSend, encodeRece) 265 + print(reqBody) 266 + return reqBody 267 +end 268 + 269 + 270 +-- Send http.get request and return response result 271 +function getHttpsUrl(url,header,reqbody) 272 + local body = {} 273 + local bodyJson = json.encode(body) 274 + local result_table, code, headers, status = https.request{ 275 + method = "POST", 276 + url = url, 277 + source = ltn12.source.string(reqbody), 278 + headers = header, 279 + sink = ltn12.sink.table(body) 280 + } 281 + print("code:"..code) 282 + if code~= 200 then 283 + return 284 + else 285 + return body 286 + end 287 +end 288 + 289 +function getMessageUrl(whatsAppMessage) 290 + local auth = SID..':'..Token 291 + local url = "https://api.twilio.com/2010-04-01/Accounts/"..SID.."/Messages" 292 + --local reqMess = "message="..twilioMessage 293 + local reqMess = requestBodySplice(whatsAppMessage, twilioPhoneNumber, receiverPhoneNumber) 294 + local headers = 295 + { 296 + ["Authorization"] = "Basic "..encodingBase64(auth), 297 + ["Content-Type"] = "application/x-www-form-urlencoded", 298 + ["Content-Length"] = #reqMess 299 + } 300 + 301 + print("Get the link:"..url) 302 + getHttpsUrl(url, headers, reqMess) 303 +end 304 + 305 + 306 + 307 +function Twilio.main() 308 + --dosomething 309 + --local auth = SID..':'..Token 310 + --print(requestBodySplice("HelloWorld", twilioPhoneNumber, receiverPhoneNumber)) 311 + --print(encodingBase64(auth)) 312 + local bitValue = addr_getbit("@testBit"); 313 + local message = '' 314 + print("b=="..bitValue) 315 + if bitValue == 1 and bitValue ~= tempBit then 316 + message = 'Alarm V-Box triggered, the output is '.. bitValue 317 + getMessageUrl(message) 318 + print("Notification pushed of triggering alarm,"..bitValue) 319 + elseif bitValue == 0 and bitValue ~= tempBit then 320 + message = 'Alarm V-Box dismissed, the output is '.. bitValue 321 + getMessageUrl(message) 322 + print("Notification pushed of dismissing alarm,"..bitValue) 323 + end 324 + tempBit = bitValue----Prevent monitoring values from continuous being sent to the platform 325 + 326 + local wordValue = addr_getword("@testWord") 327 + print("w=="..wordValue) 328 + --dosomething 329 + if wordValue >= 100 and wordValue ~= tempWord and tempWord <= 100 then 330 + message = 'Alarm V-Box triggered, the temperature is '.. wordValue 331 + getMessageUrl(message) 332 + print("Notification pushed of triggering alarm,"..wordValue) 333 + elseif wordValue < 100 and wordValue ~= tempWord and tempWord >= 100 then 334 + message = 'Alarm V-Box dismissed, the temperature is '.. wordValue 335 + getMessageUrl(message) 336 + print("Notification pushed of dismissing alarm,"..wordValue) 337 + end 338 + tempWord = wordValue----Prevent monitoring values from continuous being sent to the platform 339 +end 340 +{{/code}} 341 + 139 139 = **2 V-Box connect with third part server** = 140 140 141 141 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. ... ... @@ -154,8 +154,132 @@ 154 154 155 155 (% class="mark" %)2.If your server requires SSL certificate to log in,please use OpenCloud.Because only OpenCloud platform can support to upload certificate 156 156 157 -== **2.1 V-Box connect with customer server:grouprobotinfo.com** == 360 +(% class="wikigeneratedid" %) 361 +**✎Note: **Before program the script of MQTT, please make sure the server(MQTT broker) can be connected through MQTT Client tool. 158 158 363 +(% class="wikigeneratedid" %) 364 +Tool link: **[[MQTT.fx>>http://mqttfx.jensd.de/index.php/download]]** 365 + 366 +== **2.1 V-Box connect with test server(General Example)** == 367 + 368 +{{code language="lua"}} 369 +--MQTT configuration table 370 +local MQTT_CFG={} 371 +MQTT_CFG.username = "weconsupport" 372 +MQTT_CFG.password = "123456" 373 +MQTT_CFG.netway = 0 374 +MQTT_CFG.keepalive = 60 375 +MQTT_CFG.cleansession = 1 376 +--TCP URL 377 +MQTT_URL = "tcp://mq.tongxinmao.com:1883" 378 +--Client ID 379 +MQTT_CLIENT_ID = "V-BOXH-AG" 380 + 381 +--Generate UUID 382 +function uuid() 383 + local seed = {'e','1','2','3','4','5','6','7','8','9','a','b','c','d','e','f'} 384 + local tb = {} 385 + for i=1, 32 do 386 + table.insert(tb, seed[math.random(1,16)]) 387 + end 388 + local sid=table.concat(tb) 389 + return string.format('%s', 390 + string.sub(sid,1,32) 391 + ) 392 +end 393 + 394 + 395 +--Topic name to subscribed 396 +local SUBSCRIBE_TOPIC = 'testtopic/test/no1/123456' 397 + 398 +--Topic name to be published 399 +local PUBLISH_TOPIC = 'testtopic/test/no1/7890' 400 + 401 + 402 +--real time 403 +local LAST_TIME = 0 404 + 405 + 406 +--initialize mqtt 407 +function mqtt_init() 408 + print(string.format("mqtt init mqtt_url:%s mqtt_clientid:%s", MQTT_URL, MQTT_CLIENT_ID)) 409 + g_mq, err = mqtt.create(MQTT_URL, MQTT_CLIENT_ID) -- create mqtt object,and declare it as a global variable 410 + if g_mq then 411 + g_mq:on("message", mqtt_msg_callback) -- Register a callback for receiving messages 412 + print("mqtt init success") 413 + else 414 + print("mqtt init failed:", err) 415 + end 416 +end 417 + 418 +-- connect to mqtt 419 +function mqtt_connect() 420 + print("mqtt connecting...") 421 + local stat, err = g_mq:connect(MQTT_CFG) 422 + if stat == nil then 423 + print("mqtt connect failed:", err) 424 + return 425 + else 426 + print("mqtt connected") 427 + end 428 + g_mq:subscribe(SUBSCRIBE_TOPIC, 0) 429 +end 430 + 431 +-- Received message callback function 432 +function mqtt_msg_callback(topic, msg) 433 + print("topic:", topic) 434 + print("msg:", msg) 435 + local objMsg = json.decode(msg) 436 + local water = objMsg.data.waterlevel 437 + local temp = objMsg.data.temperature 438 + addr_setword("@HDW20",water) 439 + addr_setword("@HDW10",temp) 440 +end 441 + 442 +--Send data (data upload to platform and encapsulate it with custom functions) 443 +function send_data() 444 + local pub_data = { 445 + timestamp = os.time(), 446 + messageId = 1, 447 + event = 'test_data', 448 + mfrs = 'V-Box', 449 + data = { 450 + id = uuid(), 451 + waterlevel = addr_getword("@HDW10"), 452 + temperature = addr_getword("@HDW20") 453 + } 454 + } 455 + return g_mq:publish(PUBLISH_TOPIC, json.encode(pub_data), 0, 0) 456 +end 457 + 458 + 459 +--main function fixed timed execution 460 +function MQTT.main() 461 + --dosomething 462 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main start") 463 + --determine the mqtt object whether exist 464 + if g_mq then 465 + --determine the mqtt object whether has been connected or not 466 + if g_mq:isconnected() then 467 + send_data() 468 + else 469 + --if exceed 20 sec not connect, reconnect once 470 + if os.time() - LAST_TIME > 20 then 471 + LAST_TIME = os.time() 472 + --connect to mqtt or reconnect 473 + mqtt_connect() 474 + end 475 + end 476 + else 477 + --mqtt object does not exist so create new one 478 + mqtt_init() 479 + end 480 + print(os.date("%Y-%m-%d %H:%M %S", os.time()) .. " main end") 481 +end 482 +{{/code}} 483 + 484 +== **2.2 V-Box connect with customer server:grouprobotinfo.com** == 485 + 159 159 This demo does not use SSL certification. Script is as below 160 160 161 161 Demo1: ... ... @@ -303,7 +303,7 @@ 303 303 end 304 304 {{/code}} 305 305 306 -== **2. 2V-Box connect with Azure platform** ==633 +== **2.3 V-Box connect with Azure platform** == 307 307 308 308 In this demo,V-Box connects with Azure by SSL certification. 309 309 ... ... @@ -434,7 +434,7 @@ 434 434 end 435 435 ))) 436 436 437 -== **2. 3How 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)** ==764 +== **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)** == 438 438 439 439 1.Register a account: [[https:~~/~~/www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ>>https://www.huaweicloud.com/intl/en-us/s/JUlPVERNJQ]] 440 440 ... ... @@ -583,7 +583,7 @@ 583 583 (% style="text-align:center" %) 584 584 [[image:1624441186851-536.png||height="434" width="700" class="img-thumbnail"]] 585 585 586 -== **2. 4V-Box connect with Huawei platform** ==913 +== **2.5 V-Box connect with Huawei platform** == 587 587 588 588 In this demo,V-Box connects with Huawei by SSL certification. 589 589 ... ... @@ -704,7 +704,7 @@ 704 704 (% style="text-align:center" %) 705 705 [[image:1624506666650-161.png||height="547" width="1000" class="img-thumbnail"]] 706 706 707 -== **2. 5V-Box connect with AWS platform** ==1034 +== **2.6 V-Box connect with AWS platform** == 708 708 709 709 === **Log in AWS** === 710 710