All OpenWRT functionality moved to lua script
authorRoman Bazalevsky <rvb@rvb.name>
Wed, 2 Sep 2015 15:11:51 +0000 (18:11 +0300)
committerRoman Bazalevsky <rvb@rvb.name>
Wed, 2 Sep 2015 15:11:51 +0000 (18:11 +0300)
Bugs fixed

weathermon.lua
weathermon.sh [deleted file]
weathermon.uci
weathermon.uci~ [new file with mode: 0644]

index 20f5aca9fa194d32e9a1b9d128dfa65d86a43ffc..19cd912b13ffa8612f36eea9fdba9c71c43c4aa4 100755 (executable)
@@ -10,16 +10,28 @@ function getConfig()
   web_user = cur.get(config,"web","user")
   web_pass = cur.get(config,"web","password")
   web_devid = cur.get(config,"web","devid")
+
+  web_iface = cur.get(config,"web","iface")
   
-  io.input("/sys/class/net/eth0/address")
+  if web_iface then
+    io.input("/sys/class/net/"..web_iface.."/address")
+  else
+    io.input("/sys/class/net/eth0/address")
+  end
+
   mac = io.read("*line")
   mac = mac:gsub(":","")
   mac = mac:upper()
 
   web_devid = web_devid or mac
-
   logging = cur.get(config,"logging","enabled") 
 
+  serial_port = cur.get(config,"serial","port")
+  serial_baud = cur.get(config,"serial","baud")
+
+  command = "stty -F  "..serial_port.." "..serial_baud
+  os.execute(command)
+
 end
 
 require "socket"
@@ -59,21 +71,21 @@ end
 
 function submitValue(type,id,param,val)
 
-  printLog("URL="..web_url)
-
   url = web_url.."?stype="..type.."&sid="..id.."&param="..param.."&value="..val
 
-  printLog(url)
-
   command = "curl"
 
+  if web_iface then
+    command = command.." --interface "..web_iface
+  end
+
   if web_user then
     command = command.." -u "..web_user..":"..web_pass
   end
 
   command = command.." \""..url.."\""
 
-  printLog("COMMAND=\""..command.."\"")
+  print(command)
   os.execute(command)
   print("")
 
@@ -110,8 +122,8 @@ function processLine(str)
       end
     end
     for k,v in pairs(sensor) do
-      printLog("Type = "..sensor_type..", ID = "..sensor_id..", Param = "..key..", Value = "..value)
-      submitValue(sensor_type,sensor_id,key,value)
+      printLog("Type = "..sensor_type..", ID = "..sensor_id..", Param = "..k..", Value = "..v)
+      submitValue(sensor_type,sensor_id,k,v)
     end
   end
 
@@ -119,6 +131,9 @@ end
 
 getConfig()
 
-line=arg[1]
-print(line)
-processLine(line)
+serialin=io.open(serial_port,"r")
+while 1 do
+  line=serialin:read()
+  print(line)
+  processLine(line)
+end
diff --git a/weathermon.sh b/weathermon.sh
deleted file mode 100755 (executable)
index 3f42275..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-#!/bin/sh
-
-ARDUINO_PORT=`uci get weathermon.serial.port`
-BAUD=`uci get weathermon.serial.baud`
-stty -F $ARDUINO_PORT $BAUD
-
-while read LINE; do
-  weathermon.lua $LINE
-done < $ARDUINO_PORT
index 490ba91f742aa0290dd69bf078ba698ebb07a319..27631ac5a8d8978c4b0af25586e1222a1b8a66a5 100644 (file)
@@ -2,6 +2,7 @@ config internal 'web'
        option url http://estia.rvb-home.lan/meteo/send.php
        option user meteo
        option password somestrictpassword
+       option iface eth0
 
 config internal 'serial'
        option port /dev/ttyUSB0
diff --git a/weathermon.uci~ b/weathermon.uci~
new file mode 100644 (file)
index 0000000..490ba91
--- /dev/null
@@ -0,0 +1,12 @@
+config internal 'web'
+       option url http://estia.rvb-home.lan/meteo/send.php
+       option user meteo
+       option password somestrictpassword
+
+config internal 'serial'
+       option port /dev/ttyUSB0
+       option timeout 100
+       option baud 9600
+
+config internal 'logging'
+       option enabled on