main.lua 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. PROJECT = "airtun"
  2. VERSION = "1.0.0"
  3. -- sys库是标配
  4. _G.sys = require("sys")
  5. -- _G.sysplus = require("sysplus")
  6. ----------------------------------------
  7. -- 报错信息自动上报到平台,默认是iot.openluat.com
  8. -- 支持自定义, 详细配置请查阅API手册
  9. -- 开启后会上报开机原因, 这需要消耗流量,请留意
  10. if errDump then
  11. errDump.config(true, 600)
  12. end
  13. ----------------------------------------
  14. local wsc = nil
  15. sys.taskInit(function()
  16. if rtos.bsp():startsWith("ESP32") then
  17. local ssid = "uiot"
  18. local password = "1234567890"
  19. log.info("wifi", ssid, password)
  20. -- TODO 改成esptouch配网
  21. LED = gpio.setup(12, 0, gpio.PULLUP)
  22. wlan.init()
  23. wlan.setMode(wlan.STATION)
  24. wlan.connect(ssid, password, 1)
  25. local result, data = sys.waitUntil("IP_READY", 30000)
  26. log.info("wlan", "IP_READY", result, data)
  27. device_id = wlan.getMac()
  28. elseif rtos.bsp() == "AIR105" then
  29. w5500.init(spi.HSPI_0, 24000000, pin.PC14, pin.PC01, pin.PC00)
  30. w5500.config() --默认是DHCP模式
  31. w5500.bind(socket.ETH0)
  32. LED = gpio.setup(62, 0, gpio.PULLUP)
  33. sys.wait(1000)
  34. -- TODO 获取mac地址作为device_id
  35. elseif rtos.bsp() == "EC618" then
  36. --mobile.simid(2)
  37. LED = gpio.setup(27, 0, gpio.PULLUP)
  38. device_id = mobile.imei()
  39. sys.waitUntil("IP_READY", 30000)
  40. end
  41. -- 这是个测试服务, 当发送的是json,且action=echo,就会回显所发送的内容
  42. wsc = websocket.create(nil, "ws://echo.airtun.air32.cn/ws/echo")
  43. if wsc.headers then
  44. wsc:headers({Auth="Basic ABCDEGG"})
  45. end
  46. wsc:autoreconn(true, 3000) -- 自动重连机制
  47. wsc:on(function(wsc, event, data, fin, optcode)
  48. -- event 事件, 当前有conack和recv
  49. -- data 当事件为recv是有接收到的数据
  50. -- fin 是否为最后一个数据包, 0代表还有数据, 1代表是最后一个数据包
  51. -- optcode, 0 - 中间数据包, 1 - 文本数据包, 2 - 二进制数据包
  52. -- 因为lua并不区分文本和二进制数据, 所以optcode通常可以无视
  53. -- 若数据不多, 小于1400字节, 那么fid通常也是1, 同样可以忽略
  54. log.info("wsc", event, data, fin, optcode)
  55. if event == "conack" then -- 连接websocket服务后, 会有这个事件
  56. wsc:send((json.encode({action="echo", device_id=device_id})))
  57. sys.publish("wsc_conack")
  58. end
  59. end)
  60. wsc:connect()
  61. -- 等待conack是可选的
  62. --sys.waitUntil("wsc_conack", 15000)
  63. -- 定期发业务ping也是可选的, 但为了保存连接, 也为了继续持有wsc对象, 这里周期性发数据
  64. while true do
  65. sys.wait(45000)
  66. -- wsc:send("{\"room\":\"topic:okfd7qcob2iujp1br83nn7lcg5\",\"action\":\"join\"}")
  67. wsc:send((json.encode({action="echo", msg=os.date()})))
  68. end
  69. wsc:close()
  70. wsc = nil
  71. end)
  72. -- 用户代码已结束---------------------------------------------
  73. -- 结尾总是这一句
  74. sys.run()
  75. -- sys.run()之后后面不要加任何语句!!!!!