Add gluon-mesh-wireless-sae package
This package adds support for SAE on 802.11s mesh connections. Enabling this package will require all 802.11s mesh connections to be encrypted using the SAE key agreement scheme. The security of SAE relies upon the authentication through a shared secret. In the context of public mesh networks a shared secret is an obvious oxymoron. Still this functionality provides an improvement over unencrypted mesh connections in that it protects against a passive attacker who did not observe the key agreement. In addition Management Frame Protection (802.11w) gets automatically enabled on mesh interfaces to prevent protocol-level deauthentication attacks. If `wifi.mesh.sae` is enabled a shared secret will automatically be derived from the `prefix6` variable. This is as secure as it gets for a public mesh network. For *private* mesh networks `wifi.mesh.sae_passphrase` should be set to your shared secret. Fixes #1636
This commit is contained in:
parent
bf04107048
commit
461d904086
@ -65,6 +65,7 @@ Several Freifunk communities in Germany use Gluon as the foundation of their Fre
|
|||||||
package/gluon-ebtables-source-filter
|
package/gluon-ebtables-source-filter
|
||||||
package/gluon-hoodselector
|
package/gluon-hoodselector
|
||||||
package/gluon-mesh-batman-adv
|
package/gluon-mesh-batman-adv
|
||||||
|
package/gluon-mesh-wireless-sae
|
||||||
package/gluon-radv-filterd
|
package/gluon-radv-filterd
|
||||||
package/gluon-scheduled-domain-switch
|
package/gluon-scheduled-domain-switch
|
||||||
package/gluon-web-admin
|
package/gluon-web-admin
|
||||||
|
49
docs/package/gluon-mesh-wireless-sae.rst
Normal file
49
docs/package/gluon-mesh-wireless-sae.rst
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
gluon-mesh-wireless-sae
|
||||||
|
=======================
|
||||||
|
|
||||||
|
This package adds support for SAE on 802.11s mesh connections.
|
||||||
|
|
||||||
|
Enabling this package will require all 802.11s mesh connections
|
||||||
|
to be encrypted using the SAE key agreement scheme. The security
|
||||||
|
of SAE relies upon the authentication through a shared secret.
|
||||||
|
|
||||||
|
In the context of public mesh networks a shared secret is an
|
||||||
|
obvious oxymoron. Still, this functionality may provide an improvement
|
||||||
|
over unencrypted mesh connections in that it protects against a
|
||||||
|
passive attacker who did not observe the key agreement. In addition
|
||||||
|
Management Frame Protection (802.11w) gets automatically enabled on
|
||||||
|
wireless mesh interfaces to prevent protocol-level deauthentication attacks.
|
||||||
|
|
||||||
|
If `wifi.mesh.sae` is enabled, a shared secret will automatically be
|
||||||
|
derived from the `prefix6` variable. This is as secure as it gets
|
||||||
|
for a public mesh network.
|
||||||
|
|
||||||
|
For *private* mesh networks `wifi.mesh.sae_passphrase` should be
|
||||||
|
set to your shared secret.
|
||||||
|
|
||||||
|
site.conf
|
||||||
|
---------
|
||||||
|
These settings apply to all 802.11s mesh interfaces on all radios.
|
||||||
|
|
||||||
|
wifi.mesh.sae \: optional
|
||||||
|
- ``true`` enables SAE on 802.11s mesh connections
|
||||||
|
- ``false`` disables SAE on 802.11s mesh connections
|
||||||
|
- defaults to ``false``
|
||||||
|
|
||||||
|
wifi.mesh.sae_passphrase \: optional
|
||||||
|
- sets a shared secret used to authenticate any two mesh nodes,
|
||||||
|
crucial for private mesh networks
|
||||||
|
- should not be set, if the shared secret is shared with untrusted
|
||||||
|
third parties, like in a publish mesh network
|
||||||
|
- defaults to an autogenerated value derived from ``prefix6``
|
||||||
|
|
||||||
|
|
||||||
|
Example::
|
||||||
|
|
||||||
|
wifi = {
|
||||||
|
mesh = {
|
||||||
|
sae = true,
|
||||||
|
-- sae_passphrase = "<shared secret>",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
|
13
package/gluon-mesh-wireless-sae/Makefile
Normal file
13
package/gluon-mesh-wireless-sae/Makefile
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
|
PKG_NAME:=gluon-mesh-wireless-sae
|
||||||
|
PKG_VERSION:=1
|
||||||
|
|
||||||
|
include ../gluon.mk
|
||||||
|
|
||||||
|
define Package/gluon-mesh-wireless-sae
|
||||||
|
TITLE:=Encryption of 802.11s Mesh Links through SAE
|
||||||
|
DEPENDS:=+gluon-core +wpa-supplicant-openssl
|
||||||
|
endef
|
||||||
|
|
||||||
|
$(eval $(call BuildPackageGluon,gluon-mesh-wireless-sae))
|
2
package/gluon-mesh-wireless-sae/check_site.lua
Normal file
2
package/gluon-mesh-wireless-sae/check_site.lua
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
need_boolean({'wifi', 'mesh', 'sae'}, false)
|
||||||
|
need_string({'wifi', 'mesh', 'sae_passphrase'}, false)
|
@ -0,0 +1,29 @@
|
|||||||
|
#!/usr/bin/lua
|
||||||
|
|
||||||
|
local util = require 'gluon.util'
|
||||||
|
local site = require 'gluon.site'
|
||||||
|
local hash = require 'hash'
|
||||||
|
local uci = require('simple-uci').cursor()
|
||||||
|
|
||||||
|
|
||||||
|
local function configure_sae(vif)
|
||||||
|
uci:set('wireless', vif, 'encryption', 'sae')
|
||||||
|
uci:set('wireless', vif, 'key', site.wifi.mesh.sae_passphrase() or hash.md5(site.prefix6()))
|
||||||
|
end
|
||||||
|
|
||||||
|
util.foreach_radio(uci, function(radio, _, _)
|
||||||
|
local radio_name = radio['.name']
|
||||||
|
local vif = 'mesh_' .. radio_name
|
||||||
|
local enable = site.wifi.mesh.sae(false)
|
||||||
|
|
||||||
|
if uci:get('wireless', vif) then
|
||||||
|
uci:delete('wireless', vif, 'encryption')
|
||||||
|
uci:delete('wireless', vif, 'key')
|
||||||
|
|
||||||
|
if enable then
|
||||||
|
configure_sae(vif)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
uci:save('wireless')
|
Loading…
Reference in New Issue
Block a user