gluon-mesh-vpn-openvpn: initial
This commit is contained in:
parent
435eb64dc6
commit
68f22154c2
13
package/gluon-mesh-vpn-openvpn/Makefile
Normal file
13
package/gluon-mesh-vpn-openvpn/Makefile
Normal file
@ -0,0 +1,13 @@
|
||||
include $(TOPDIR)/rules.mk
|
||||
|
||||
PKG_NAME:=gluon-mesh-vpn-openvpn
|
||||
PKG_VERSION:=3
|
||||
|
||||
include ../gluon.mk
|
||||
|
||||
define Package/gluon-mesh-vpn-openvpn
|
||||
TITLE:=Support for connecting meshes via custom openvpn configuration
|
||||
DEPENDS:=+gluon-core +gluon-mesh-vpn-core +openvpn
|
||||
endef
|
||||
|
||||
$(eval $(call BuildPackageGluon,gluon-mesh-vpn-openvpn))
|
1
package/gluon-mesh-vpn-openvpn/check_site.lua
Normal file
1
package/gluon-mesh-vpn-openvpn/check_site.lua
Normal file
@ -0,0 +1 @@
|
||||
need_string(in_domain({'mesh_vpn', 'openvpn', 'config'}))
|
@ -0,0 +1,2 @@
|
||||
#!/bin/sh
|
||||
/etc/init.d/openvpn stop
|
@ -0,0 +1,2 @@
|
||||
#!/bin/sh
|
||||
/etc/init.d/openvpn start
|
@ -0,0 +1 @@
|
||||
*/5 * * * * /usr/bin/openvpn-watchdog
|
@ -0,0 +1,31 @@
|
||||
#!/usr/bin/lua
|
||||
|
||||
local site = require 'gluon.site'
|
||||
local util = require 'gluon.util'
|
||||
local vpn_core = require 'gluon.mesh-vpn'
|
||||
|
||||
local uci = require('simple-uci').cursor()
|
||||
|
||||
|
||||
local enabled
|
||||
|
||||
local file = '/etc/openvpn/mesh_vpn.ovpn'
|
||||
|
||||
-- TODO: support for directly specifying options in site conf
|
||||
|
||||
fd = io.open(file, 'w')
|
||||
fd:write(site.mesh_vpn.openvpn.config())
|
||||
fd:close()
|
||||
|
||||
uci:section('openvpn', 'mesh_vpn', {
|
||||
enabled = enabled,
|
||||
config = file,
|
||||
-- uuid = util.node_id(),
|
||||
-- interface = vpn_core.get_interface(),
|
||||
-- bind_interface = 'br-wan',
|
||||
-- group = 'gluon-mesh-vpn',
|
||||
-- broker_selection = 'usage',
|
||||
-- address = site.mesh_vpn.openvpn.brokers(),
|
||||
})
|
||||
|
||||
uci:save('openvpn')
|
@ -0,0 +1,46 @@
|
||||
#!/usr/bin/lua
|
||||
|
||||
local uci = require('simple-uci').cursor()
|
||||
|
||||
local function restart_openvpn()
|
||||
os.execute('logger -t openvpn-watchdog "Restarting openvpn."')
|
||||
os.execute('/etc/init.d/openvpn restart')
|
||||
end
|
||||
|
||||
local function read_pid_file()
|
||||
local pid_file = io.open('/var/run/openvpn.mesh-vpn.pid', 'r')
|
||||
if not pid_file then
|
||||
return nil
|
||||
end
|
||||
local pid = pid_file:read('*l')
|
||||
pid_file:close()
|
||||
return pid
|
||||
end
|
||||
|
||||
local function has_mesh_vpn_neighbours()
|
||||
local handle = io.popen('batctl o', 'r')
|
||||
if not handle then
|
||||
return false
|
||||
end
|
||||
for line in handle:lines() do
|
||||
if line:find('mesh%-vpn') then
|
||||
handle:close()
|
||||
return true
|
||||
end
|
||||
end
|
||||
handle:close()
|
||||
return false
|
||||
end
|
||||
|
||||
if uci:get_bool('openvpn', 'mesh_vpn', 'enabled') then
|
||||
-- if io.popen('pgrep -x /usr/bin/openvpn'):read('*l') ~= read_pid_file() then
|
||||
-- os.execute('logger -t openvpn-watchdog "Process-Pid does not match with pid-File."')
|
||||
-- restart_openvpn()
|
||||
-- return
|
||||
-- end
|
||||
-- if not has_mesh_vpn_neighbours() then
|
||||
-- os.execute('logger -t openvpn-watchdog "No vpn-mesh neighbours found."')
|
||||
-- restart_openvpn()
|
||||
-- return
|
||||
-- end
|
||||
end
|
@ -0,0 +1,42 @@
|
||||
local uci = require('simple-uci').cursor()
|
||||
|
||||
local site = require 'gluon.site'
|
||||
local vpn_core = require 'gluon.mesh-vpn'
|
||||
|
||||
local M = {}
|
||||
|
||||
function M.public_key()
|
||||
return nil
|
||||
end
|
||||
|
||||
function M.enable(val)
|
||||
uci:set('openvpn', 'mesh_vpn', 'enabled', val)
|
||||
uci:save('openvpn')
|
||||
end
|
||||
|
||||
function M.active()
|
||||
return site.mesh_vpn.openvpn() ~= nil
|
||||
end
|
||||
|
||||
function M.set_limit(ingress_limit, egress_limit)
|
||||
if ingress_limit ~= nil then
|
||||
uci:set('openvpn', 'mesh_vpn', 'limit_bw_down', ingress_limit)
|
||||
else
|
||||
uci:delete('openvpn', 'mesh_vpn', 'limit_bw_down')
|
||||
end
|
||||
|
||||
if egress_limit ~= nil then
|
||||
uci:section('simple-tc', 'interface', 'mesh_vpn', {
|
||||
ifname = vpn_core.get_interface(),
|
||||
enabled = true,
|
||||
limit_egress = egress_limit,
|
||||
})
|
||||
else
|
||||
uci:delete('simple-tc', 'mesh_vpn')
|
||||
end
|
||||
|
||||
uci:save('openvpn')
|
||||
uci:save('simple-tc')
|
||||
end
|
||||
|
||||
return M
|
Loading…
Reference in New Issue
Block a user