[OpenWrt-Devel] [PATCH] luci-proto-wwan minimal support
Aleksandr Kolesnik
neryba at gmail.com
Wed Apr 22 08:59:37 EDT 2015
Signed-off-by: Aleksandr Kolesnik <neryba at gmail.com>
--- a/contrib/package/luci/Makefile
+++ b/contrib/package/luci/Makefile
@@ -194,6 +194,7 @@ $(eval $(call protocol,ipv6,Support for
$(eval $(call protocol,3g,Support for 3G,+PACKAGE_luci-proto-3g:comgt))
$(eval $(call protocol,hso,Support for HSO,+PACKAGE_luci-proto-hso:comgt
+PACKAGE_luci-proto-hso:kmod-usb-net
+PACKAGE_luci-proto-hso:kmod-usb-net-hso))
$(eval $(call protocol,relay,Support for relayd pseudo
bridges,+PACKAGE_luci-proto-relay:relayd))
+$(eval $(call protocol,wwan,Support for 3G/4g
wwan,+PACKAGE_luci-proto-wwan:wwan))
### Modules ###
--- a/modules/base/luasrc/model/network.lua
+++ b/modules/base/luasrc/model/network.lua
@@ -756,7 +756,11 @@ function protocol.ifname(self)
end
function protocol.proto(self)
- return "none"
+ local p = self:_ubus("proto")
+ if not p then
+ p = "none"
+ end
+ return p
end
function protocol.get_i18n(self)
@@ -934,7 +938,16 @@ function protocol.del_interface(self, if
end
function protocol.get_interface(self)
- if self:is_virtual() then
+ if self:is_virtual() and self:proto() == "wwan" then
+ local ldev = self:_ubus("l3_device")
+ if ldev then
+ _tunnel[ldev] = true
+ return interface(ldev, self)
+ else
+ _tunnel[self:proto() .. "-" .. self.sid] = true
+ return interface(self:proto() .. "-" .. self.sid, self)
+ end
+ elseif self:is_virtual() then
_tunnel[self:proto() .. "-" .. self.sid] = true
return interface(self:proto() .. "-" .. self.sid, self)
elseif self:is_bridge() then
--- /dev/null
+++ b/protocols/wwan/Makefile
@@ -0,0 +1,2 @@
+include ../../build/config.mk
+include ../../build/module.mk
--- /dev/null
+++ b/protocols/wwan/luasrc/model/cbi/admin_network/proto_wwan.lua
@@ -0,0 +1,130 @@
+--[[
+LuCI - Lua Configuration Interface
+
+Copyright 2015 Aleksandr Kolesnik <neryba at gmail.com>
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+]]--
+
+local map, section, net = ...
+
+local apn, service, pincode, username, password
+local ipv6, maxwait, defaultroute, metric, peerdns, dns,
+ keepalive_failure, keepalive_interval, demand
+
+apn = section:taboption("general", Value, "apn", translate("APN"))
+
+
+pincode = section:taboption("general", Value, "pincode", translate("PIN"))
+
+
+username = section:taboption("general", Value, "username",
translate("PAP/CHAP username"))
+
+
+password = section:taboption("general", Value, "password",
translate("PAP/CHAP password"))
+password.password = true
+
+
+if luci.model.network:has_ipv6() then
+
+ ipv6 = section:taboption("advanced", Flag, "ipv6",
+ translate("Enable IPv6 negotiation on the PPP link"))
+
+ ipv6.default = ipv6.disabled
+
+end
+
+
+maxwait = section:taboption("advanced", Value, "maxwait",
+ translate("Modem init timeout"),
+ translate("Maximum amount of seconds to wait for the modem to become
ready"))
+
+maxwait.placeholder = "20"
+maxwait.datatype = "min(1)"
+
+
+defaultroute = section:taboption("advanced", Flag, "defaultroute",
+ translate("Use default gateway"),
+ translate("If unchecked, no default route is configured"))
+
+defaultroute.default = defaultroute.enabled
+
+
+metric = section:taboption("advanced", Value, "metric",
+ translate("Use gateway metric"))
+
+metric.placeholder = "0"
+metric.datatype = "uinteger"
+metric:depends("defaultroute", defaultroute.enabled)
+
+
+peerdns = section:taboption("advanced", Flag, "peerdns",
+ translate("Use DNS servers advertised by peer"),
+ translate("If unchecked, the advertised DNS server addresses are
ignored"))
+
+peerdns.default = peerdns.enabled
+
+
+dns = section:taboption("advanced", DynamicList, "dns",
+ translate("Use custom DNS servers"))
+
+dns:depends("peerdns", "")
+dns.datatype = "ipaddr"
+dns.cast = "string"
+
+
+keepalive_failure = section:taboption("advanced", Value,
"_keepalive_failure",
+ translate("LCP echo failure threshold"),
+ translate("Presume peer to be dead after given amount of LCP echo
failures, use 0 to ignore failures"))
+
+function keepalive_failure.cfgvalue(self, section)
+ local v = m:get(section, "keepalive")
+ if v and #v > 0 then
+ return tonumber(v:match("^(%d+)[ ,]+%d+") or v)
+ end
+end
+
+function keepalive_failure.write() end
+function keepalive_failure.remove() end
+
+keepalive_failure.placeholder = "0"
+keepalive_failure.datatype = "uinteger"
+
+
+keepalive_interval = section:taboption("advanced", Value,
"_keepalive_interval",
+ translate("LCP echo interval"),
+ translate("Send LCP echo requests at the given interval in seconds, only
effective in conjunction with failure threshold"))
+
+function keepalive_interval.cfgvalue(self, section)
+ local v = m:get(section, "keepalive")
+ if v and #v > 0 then
+ return tonumber(v:match("^%d+[ ,]+(%d+)"))
+ end
+end
+
+function keepalive_interval.write(self, section, value)
+ local f = tonumber(keepalive_failure:formvalue(section)) or 0
+ local i = tonumber(value) or 5
+ if i < 1 then i = 1 end
+ if f > 0 then
+ m:set(section, "keepalive", "%d %d" %{ f, i })
+ else
+ m:del(section, "keepalive")
+ end
+end
+
+keepalive_interval.remove = keepalive_interval.write
+keepalive_interval.placeholder = "5"
+keepalive_interval.datatype = "min(1)"
+
+
+demand = section:taboption("advanced", Value, "demand",
+ translate("Inactivity timeout"),
+ translate("Close inactive connection after the given amount of seconds,
use 0 to persist connection"))
+
+demand.placeholder = "0"
+demand.datatype = "uinteger"
--- /dev/null
+++ b/protocols/wwan/luasrc/model/network/proto_wwan.lua
@@ -0,0 +1,57 @@
+--[[
+LuCI - Network model - WWAN protocol extension
+
+Copyright 2015 Aleksandr Kolesnik <neryba at gmail.com>
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+ http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+
+]]--
+
+local netmod = luci.model.network
+
+local proto = netmod:register_protocol("wwan")
+
+function proto.ifname(self)
+ return "wwan-" .. self.sid
+end
+
+function proto.get_i18n(self)
+ return luci.i18n.translate("WWAN")
+end
+
+function proto.opkg_package(self)
+ return "wwan"
+end
+
+function proto.is_installed(self)
+ return nixio.fs.access("/lib/netifd/proto/wwan.sh")
+end
+
+function proto.is_floating(self)
+ return true
+end
+
+function proto.is_virtual(self)
+ return true
+end
+
+function proto.get_interfaces(self)
+ return nil
+end
+
+function proto.contains_interface(self,ifc)
+ return (netmod:ifnameof(ifc) == self:ifname())
+end
+
+netmod:register_pattern_virtual("^wwan-%%w")
+
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.infradead.org/pipermail/openwrt-devel/attachments/20150422/ab21ce4a/attachment.htm>
-------------- next part --------------
_______________________________________________
openwrt-devel mailing list
openwrt-devel at lists.openwrt.org
https://lists.openwrt.org/cgi-bin/mailman/listinfo/openwrt-devel
More information about the openwrt-devel
mailing list