summaryrefslogtreecommitdiff
path: root/src/conf_mode
diff options
context:
space:
mode:
authorhagbard <vyosdev@derith.de>2018-08-23 13:50:12 -0700
committerhagbard <vyosdev@derith.de>2018-08-23 13:50:12 -0700
commit96778964422910e5d07cfa02b1edb01f6bd870e1 (patch)
tree9ebe7a8221b88d228af8c9447c2087b361737cd4 /src/conf_mode
parent8e685a16a1a478a7aead5b655dac99c3987af35c (diff)
downloadvyos-1x-96778964422910e5d07cfa02b1edb01f6bd870e1.tar.gz
vyos-1x-96778964422910e5d07cfa02b1edb01f6bd870e1.zip
T793: fwmark implementation
Diffstat (limited to 'src/conf_mode')
-rwxr-xr-xsrc/conf_mode/wireguard.py11
1 files changed, 10 insertions, 1 deletions
diff --git a/src/conf_mode/wireguard.py b/src/conf_mode/wireguard.py
index 032a407ca..4e83537bf 100755
--- a/src/conf_mode/wireguard.py
+++ b/src/conf_mode/wireguard.py
@@ -18,6 +18,7 @@
#### TODO:
# fwmark
# preshared key
+# mtu
####
@@ -71,7 +72,8 @@ def get_config():
'status' : 'exists',
'state' : 'enabled',
'mtu' : 1420,
- 'peer' : {}
+ 'peer' : {},
+ 'fwmark' : 0
}
}
)
@@ -104,6 +106,9 @@ def get_config():
### mtu
if c.exists(cnf + ' mtu'):
config_data['interfaces'][intfc]['mtu'] = c.return_value(cnf + ' mtu')
+ ### fwmark
+ if c.exists(cnf + ' fwmark'):
+ config_data['interfaces'][intfc]['fwmark'] = c.return_value(cnf + ' fwmark')
### peers
if c.exists(cnf + ' peer'):
@@ -259,10 +264,14 @@ def configure_interface(c, intf):
## persistent-keepalive
if 'persistent-keepalive' in c['interfaces'][intf]['peer'][p]:
wg_config['keepalive'] = c['interfaces'][intf]['peer'][p]['persistent-keepalive']
+
+ ## fwmark
+ wg_config['fwmark'] = hex(int(c['interfaces'][intf]['fwmark']))
### assemble wg command
cmd = "sudo wg set " + intf
cmd += " listen-port " + str(wg_config['listen-port'])
+ cmd += " fwmark " + wg_config['fwmark']
cmd += " private-key " + wg_config['private-key']
cmd += " peer " + wg_config['peer']['pubkey']
cmd += " allowed-ips "