Добавлена опциональная авторизация MQTT
[weathermon.git] / weathermon.lua
index 3e940cd8b89baa0962c1cde14284305fa894a8f2..5e193487d37bbdeeca22f122a8ed4f3b35a50a92 100755 (executable)
@@ -13,6 +13,14 @@ function getConfig()
 
   web_iface = cur.get(config,"web","iface")
 
 
   web_iface = cur.get(config,"web","iface")
 
+  if web_iface then
+  
+    command = '/sbin/ifconfig '..web_iface..' | grep \'\\<inet\\>\' | sed -n \'1p\' | tr -s \' \' | cut -d \' \' -f3 | cut -d \':\' -f2'
+    f=io.popen(command,'r')
+    ip_addr=f:read()
+  
+  end
+
   if not web_devid then
   
     if web_iface then
   if not web_devid then
   
     if web_iface then
@@ -34,6 +42,10 @@ function getConfig()
   serial_port = cur.get(config,"serial","port")
   serial_baud = cur.get(config,"serial","baud")
 
   serial_port = cur.get(config,"serial","port")
   serial_baud = cur.get(config,"serial","baud")
 
+  input_file = cur.get(config,"input","file")
+  input_exec = cur.get(config,"input","exec")
+  alarm_exec = cur.get(config,"alarm","exec")
+
   if serial_port then
 
     command = "stty -F  "..serial_port.." "..serial_baud
   if serial_port then
 
     command = "stty -F  "..serial_port.." "..serial_baud
@@ -45,6 +57,10 @@ function getConfig()
   mqtt_port = cur.get(config,"mqtt","port")
   mqtt_id = cur.get(config,"mqtt","id")
   mqtt_topic = cur.get(config,"mqtt","topic")
   mqtt_port = cur.get(config,"mqtt","port")
   mqtt_id = cur.get(config,"mqtt","id")
   mqtt_topic = cur.get(config,"mqtt","topic")
+  mqtt_alarm_topic = cur.get(config,"mqtt","alarm_topic")
+
+  mqtt_user = cur.get(config,"mqtt","user")
+  mqtt_passwd = cur.get(config,"mqtt","password")
 
   if mqtt_host and not mqtt_id then
     mqtt_id="weather-"..web_devid
 
   if mqtt_host and not mqtt_id then
     mqtt_id="weather-"..web_devid
@@ -58,6 +74,10 @@ function getConfig()
     mqtt_topic = 'weathermon/'..web_devid
   end
 
     mqtt_topic = 'weathermon/'..web_devid
   end
 
+  if mqtt_host and not mqtt_alarm_topic then
+    mqtt_alarm_topic = 'alarm/'..web_devid
+  end
+
 end
 
 require "socket"
 end
 
 require "socket"
@@ -102,7 +122,7 @@ function submitValue(type,id,param,val)
   command = "curl"
 
   if web_iface then
   command = "curl"
 
   if web_iface then
-    command = command.." --interface "..web_iface
+    command = command.." --interface "..ip_addr
   end
 
   if web_user then
   end
 
   if web_user then
@@ -111,9 +131,8 @@ function submitValue(type,id,param,val)
 
   command = command.." \""..url.."\""
 
 
   command = command.." \""..url.."\""
 
-  print(command)
   os.execute(command)
   os.execute(command)
-  print("")
+  print()
 
 end
 
 
 end
 
@@ -153,11 +172,45 @@ function processLine(str)
       submitValue(sensor_type,sensor_id,k,v)
       mqtt_param[k]=v
     end
       submitValue(sensor_type,sensor_id,k,v)
       mqtt_param[k]=v
     end
-    mqtt_msg = { type=sensor_type, data=mqtt_param }
+    mqtt_msg = { type=sensor_type, id=sensor_id, data=mqtt_param }
     if mqtt_client then
       serializedString = json.encode(mqtt_msg)
       mqtt_client:publish(mqtt_topic,serializedString)
     end
     if mqtt_client then
       serializedString = json.encode(mqtt_msg)
       mqtt_client:publish(mqtt_topic,serializedString)
     end
+  elseif msg_type=="ALARM" then
+    printLog("ALARM: "..msg_body)  
+    sens = splitStr(msg_body,",")
+    sensor = {}
+    idx = 1
+    sensor_type = nil
+    sensor_id = web_devid
+    mqtt_param = {}
+    for i,rec in ipairs(sens) do
+      recrd=splitStr(rec,'=')
+      key=recrd[1] or nil
+      value=recrd[2] or nil
+      if value then
+        if key=="TYPE" then
+          alarm_type=value
+        elseif key=="ID" then
+          alarm_id=value
+        else
+          mqtt_param[key]=value
+        end
+      end
+    end
+    if mqtt_client then
+      mqtt_msg = { type = alarm_type, id = alarm_id, data = mqtt_param }
+      serializedString = json.encode(mqtt_msg)
+      mqtt_client:publish(mqtt_alarm_topic,serializedString)
+    end
+    if alarm_exec then
+      command=alarm_exec..
+        " \""..string.gsub(alarm_type,"\"","\\\"")..
+        "\" \""..string.gsub(alarm_id,"\"","\\\"")..
+        "\" \""..string.gsub(msg_body,"\"","\\\"").."\""
+      os.execute(command)
+    end
   end
 
 end
   end
 
 end
@@ -167,11 +220,25 @@ getConfig()
 if mqtt_host then
   MQTT = require "paho.mqtt"
   mqtt_client = MQTT.client.create(mqtt_host, mqtt_port)
 if mqtt_host then
   MQTT = require "paho.mqtt"
   mqtt_client = MQTT.client.create(mqtt_host, mqtt_port)
+  if mqtt_user then
+    mqtt_client:auth(mqtt_user, mqtt_passwd)
+  end
   mqtt_client:connect(mqtt_id)
   json = require( "json" )
 end
 
   mqtt_client:connect(mqtt_id)
   json = require( "json" )
 end
 
-serialin=io.open(serial_port,"r")
+if serial_port then
+  serialin=io.open(serial_port,"r")
+elseif input_file == "-" then
+  serialin=io.stdin;
+elseif input_file then
+  serialin=io.open(input_file,"r")
+elseif input_exec then
+  serialin=io.popen(input_exec,"r")
+else
+  printLog("No input selected")
+  return
+end  
 while 1 do
   line=serialin:read()
   print(line)
 while 1 do
   line=serialin:read()
   print(line)