luci-app-openvpn: various fixes and optimizations
authorVladimir Ulrich <admin@evl.su>
Thu, 23 Jun 2016 16:12:18 +0000 (19:12 +0300)
committerJo-Philipp Wich <jo@mein.io>
Tue, 28 Jun 2016 14:40:23 +0000 (16:40 +0200)
Closes #628 as suggestion was implemented and tested.
Added PID handling function (Fixes https://dev.openwrt.org/ticket/21506).

Signed-off-by: Vladimir Ulrich <admin@evl.su>
applications/luci-app-openvpn/luasrc/model/cbi/openvpn-advanced.lua
applications/luci-app-openvpn/luasrc/model/cbi/openvpn-basic.lua
applications/luci-app-openvpn/luasrc/model/cbi/openvpn.lua

index af515fc..1bbee83 100644 (file)
@@ -235,7 +235,6 @@ for _, option in ipairs(params) do
                o.value = option[3]
        else
                if option[1] == DynamicList then
                o.value = option[3]
        else
                if option[1] == DynamicList then
-                       o.cast = nil
                        function o.cfgvalue(...)
                                local val = AbstractValue.cfgvalue(...)
                                return ( val and type(val) ~= "table" ) and { val } or val
                        function o.cfgvalue(...)
                                local val = AbstractValue.cfgvalue(...)
                                return ( val and type(val) ~= "table" ) and { val } or val
index 8385839..aaa1979 100644 (file)
@@ -62,7 +62,6 @@ for _, option in ipairs(basicParams) do
                o.value = option[3]
        else
                if option[1] == DynamicList then
                o.value = option[3]
        else
                if option[1] == DynamicList then
-                       o.cast = nil
                        function o.cfgvalue(...)
                                local val = AbstractValue.cfgvalue(...)
                                return ( val and type(val) ~= "table" ) and { val } or val
                        function o.cfgvalue(...)
                                local val = AbstractValue.cfgvalue(...)
                                return ( val and type(val) ~= "table" ) and { val } or val
index 1a1d33a..719145b 100644 (file)
@@ -25,8 +25,13 @@ uci:foreach( "openvpn_recipes", "openvpn_recipe",
        end
 )
 
        end
 )
 
-function s.getPID(section)
-       return sys.exec("%s | grep -w %s | grep openvpn | grep -v grep | awk '{print $1}'" % { psstring,section} )
+function s.getPID(section) -- Universal function which returns valid pid # or nil
+       local pid = sys.exec("%s | grep -w %s | grep openvpn | grep -v grep | awk '{print $1}'" % { psstring,section} )
+       if pid and #pid > 0 and tonumber(pid) ~= nil then
+               return tonumber(pid)
+       else
+               return nil
+       end
 end
 
 function s.parse(self, section)
 end
 
 function s.parse(self, section)
@@ -73,7 +78,7 @@ s:option( Flag, "enabled", translate("Enabled") )
 local active = s:option( DummyValue, "_active", translate("Started") )
 function active.cfgvalue(self, section)
        local pid = s.getPID(section)
 local active = s:option( DummyValue, "_active", translate("Started") )
 function active.cfgvalue(self, section)
        local pid = s.getPID(section)
-       if pid and #pid > 0 and tonumber(pid) ~= nil then
+       if pid ~= nil then
                return (sys.process.signal(pid, 0))
                        and translatef("yes (%i)", pid)
                        or  translate("no")
                return (sys.process.signal(pid, 0))
                        and translatef("yes (%i)", pid)
                        or  translate("no")
@@ -88,7 +93,7 @@ updown.redirect = luci.dispatcher.build_url(
 )
 function updown.cbid(self, section)
        local pid = s.getPID(section)
 )
 function updown.cbid(self, section)
        local pid = s.getPID(section)
-       self._state = pid and #pid > 0 and sys.process.signal(pid, 0)
+       self._state = pid ~= nil and sys.process.signal(pid, 0)
        self.option = self._state and "stop" or "start"
        return AbstractValue.cbid(self, section)
 end
        self.option = self._state and "stop" or "start"
        return AbstractValue.cbid(self, section)
 end
@@ -99,7 +104,9 @@ end
 function updown.write(self, section, value)
        if self.option == "stop" then
                local pid = s.getPID(section)
 function updown.write(self, section, value)
        if self.option == "stop" then
                local pid = s.getPID(section)
-               sys.process.signal(pid,15)
+               if pid ~= nil then
+                       sys.process.signal(pid,15)
+               end
        else
                luci.sys.call("/etc/init.d/openvpn start %s" % section)
        end
        else
                luci.sys.call("/etc/init.d/openvpn start %s" % section)
        end