aboutsummaryrefslogtreecommitdiff
path: root/share/provision/files/ipredator/usr/local/bin/fermreload.sh
diff options
context:
space:
mode:
authorSilvio Rhatto <rhatto@riseup.net>2019-01-03 17:01:29 -0200
committerSilvio Rhatto <rhatto@riseup.net>2019-01-03 17:01:29 -0200
commit81fbd1a3b93b8ec7abc5af38e9ffa4fa492e3f74 (patch)
tree8c60706bd046ebdb33f8953402772dba160de815 /share/provision/files/ipredator/usr/local/bin/fermreload.sh
parent35e0621effa975cfe0e64d1bd5c71bda69c65332 (diff)
downloadkvmx-81fbd1a3b93b8ec7abc5af38e9ffa4fa492e3f74.tar.gz
kvmx-81fbd1a3b93b8ec7abc5af38e9ffa4fa492e3f74.tar.bz2
Provision: IPredator: firewall support
Diffstat (limited to 'share/provision/files/ipredator/usr/local/bin/fermreload.sh')
-rwxr-xr-xshare/provision/files/ipredator/usr/local/bin/fermreload.sh39
1 files changed, 39 insertions, 0 deletions
diff --git a/share/provision/files/ipredator/usr/local/bin/fermreload.sh b/share/provision/files/ipredator/usr/local/bin/fermreload.sh
new file mode 100755
index 0000000..cebf7cc
--- /dev/null
+++ b/share/provision/files/ipredator/usr/local/bin/fermreload.sh
@@ -0,0 +1,39 @@
+#!/bin/bash
+#
+# fermreload.sh
+# V: 0.1
+#
+# Reloads the ferm firewall ruleset and is invoked by
+# the udev via /etc/udev/rules.d/81-vpn-firewall.rules.
+#
+# IPredator 2014
+# Released under the Kopimi license.
+#
+# Blog post: https://blog.ipredator.se/linux-firewall-howto.html
+#
+
+LOGGER=/usr/bin/logger
+LOGGER_TAG=$0
+
+UDEV_ACTION=$1
+
+FERM=/usr/sbin/ferm
+FERM_CONF=/etc/ferm/ferm.conf
+
+MSG_FW_RULE_ADD="Adding VPN firewall rules."
+MSG_FW_RULE_REMOVE="Removing VPN firewall rules."
+MSG_UDEV_ACTION_UNKNOWN="Unknown udev action."
+
+case "$UDEV_ACTION" in
+ add)
+ $LOGGER -t $LOGGER_TAG $MSG_FW_RULE_ADD
+ $FERM $FERM_CONF
+ ;;
+ remove)
+ $LOGGER -t $LOGGER_TAG $MSG_FW_RULE_REMOVE
+ $FERM $FERM_CONF
+ ;;
+ *)
+ $LOGGER -t $LOGGER_TAG $MSG_UDEV_ACTION_UNKNOWN
+ exit 1
+esac