main.lua 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. --[[
  2. demo说明:
  3. 1. 演示wifi联网操作
  4. 2. 演示长连接操作
  5. 3. 演示简易的网络状态灯
  6. ]]
  7. _G.sys = require("sys")
  8. _G.mqtt = require("mqtt")
  9. log.info("main", "simple mqtt demo")
  10. -- //////////////////////////////////////////////////////////////////////////////////////
  11. -- wifi 相关的代码
  12. if wlan ~= nil then
  13. log.info("mac", wlan.get_mac())
  14. local ssid = "uiot"
  15. local password = "12345678"
  16. -- 方式1 直接连接, 简单快捷
  17. wlan.connect(ssid, password) -- 直接连
  18. -- 方式2 先扫描,再连接. 例如根据rssi(信号强度)的不同, 择优选择ssid
  19. -- sys.taskInit(function()
  20. -- wlan.scan()
  21. -- sys.waitUntil("WLAN_SCAN_DONE", 30000)
  22. -- local re = wlan.scan_get_info()
  23. -- log.info("wlan", "scan done", #re)
  24. -- for i in ipairs(re) do
  25. -- log.info("wlan", "info", re[i].ssid, re[i].rssi)
  26. -- end
  27. -- log.info("wlan", "try connect to wifi")
  28. -- wlan.connect(ssid, password)
  29. -- sys.waitUntil("WLAN_READY", 15000)
  30. -- log.info("wifi", "self ip", socket.ip())
  31. -- end)
  32. -- 方法3 airkiss配网, 可参考 app/playit/main.lua
  33. end
  34. -- airkiss.auto(27) -- 预留的功能,未完成
  35. -- //////////////////////////////////////////////////////////////////////////////////////
  36. --- 从这里开始, 代码与具体网络无关
  37. -- 联网后自动同步时间
  38. sys.subscribe("NET_READY", function ()
  39. log.info("net", "!!! network ready event !!! send ntp")
  40. sys.taskInit(function()
  41. sys.wait(2000)
  42. socket.ntpSync()
  43. end)
  44. end)
  45. gpio.setup(21, 0)
  46. _G.use_netled = 1 -- 启用1, 关闭0
  47. sys.taskInit(function()
  48. while 1 do
  49. --log.info("wlan", "ready?", wlan.ready())
  50. if socket.isReady() then
  51. --log.info("netled", "net ready, slow")
  52. gpio.set(21, 1 * use_netled)
  53. sys.wait(1900)
  54. gpio.set(21, 0)
  55. sys.wait(100)
  56. else
  57. --log.info("netled", "net not ready, fast")
  58. gpio.set(21, 1 * use_netled)
  59. sys.wait(100)
  60. gpio.set(21, 0)
  61. sys.wait(100)
  62. end
  63. end
  64. end)
  65. sys.taskInit(function()
  66. local host, port, selfid = "lbsmqtt.airm2m.com", 1884, wlan.getMac():lower()
  67. -- 等待联网成功
  68. while true do
  69. while not socket.isReady() do
  70. log.info("net", "wait for network ready")
  71. sys.waitUntil("NET_READY", 1000)
  72. end
  73. log.info("main", "mqtt loop")
  74. collectgarbage("collect")
  75. collectgarbage("collect")
  76. local mqttc = mqtt.client(wlan.getMac(), nil, nil, false)
  77. while not mqttc:connect(host, port) do sys.wait(2000) end
  78. local topic_req = string.format("/device/%s/req", selfid)
  79. local topic_report = string.format("/device/%s/report", selfid)
  80. local topic_resp = string.format("/device/%s/resp", selfid)
  81. log.info("mqttc", "mqtt seem ok", "try subscribe", topic_req)
  82. if mqttc:subscribe(topic_req) then
  83. log.info("mqttc", "mqtt subscribe ok", "try publish")
  84. if mqttc:publish(topic_report, "test publish " .. os.time(), 1) then
  85. while true do
  86. log.info("mqttc", "wait for new msg")
  87. local r, data, param = mqttc:receive(120000, "pub_msg")
  88. log.info("mqttc", "mqttc:receive", r, data, param)
  89. if r then
  90. log.info("mqttc", "get message from server", data.payload or "nil", data.topic)
  91. elseif data == "pub_msg" then
  92. log.info("mqttc", "send message to server", data, param)
  93. mqttc:publish(topic_resp, "response " .. param)
  94. elseif data == "timeout" then
  95. log.info("mqttc", "wait timeout, send custom report")
  96. mqttc:publish(topic_report, "test publish " .. os.time() .. wlan.getMac())
  97. else
  98. log.info("mqttc", "ok, something happen", "close connetion")
  99. break
  100. end
  101. end
  102. end
  103. end
  104. mqttc:disconnect()
  105. sys.wait(5000)
  106. end
  107. end)
  108. sys.run()