#!/bin/bash # # init script for the Ethernet Bridge filter tables # # Written by Dag Wieers <dag@wieers.com> # Modified by Rok Papez <rok.papez@arnes.si> # Bart De Schuymer <bdschuym@pandora.be> # Adapted to Debian by Jan Christoph Nordholz <hesso@pool.math.tu-berlin.de> # # chkconfig: - 15 85 # description: Ethernet Bridge filtering tables # ### BEGIN INIT INFO # Provides: ebtables # Required-Start: # Required-Stop: # Should-Start: $local_fs # Should-Stop: $local_fs # Default-Start: S # Default-Stop: 0 1 6 # Short-Description: ebtables ruleset management # Description: Saves and restores the state of the ebtables rulesets. ### END INIT INFO . /lib/lsb/init-functions test -f /sbin/ebtables || exit 0 EBTABLES_DUMPFILE_STEM=/etc/ebtables RETVAL=0 prog="ebtables" desc="Ethernet bridge filtering" umask 0077 #default configuration EBTABLES_MODULES_UNLOAD="yes" EBTABLES_LOAD_ON_START="no" EBTABLES_SAVE_ON_STOP="no" EBTABLES_SAVE_ON_RESTART="no" EBTABLES_SAVE_COUNTER="no" EBTABLES_BACKUP_SUFFIX="~" config=/etc/default/$prog [ -f "$config" ] && . "$config" function get_supported_tables() { EBTABLES_SUPPORTED_TABLES= /sbin/ebtables -t filter -L 2>&1 1>/dev/null | grep -q permission if [ $? -eq 0 ]; then log_failure_msg "Error: insufficient privileges to access the ebtables rulesets." return fi for table in filter nat broute; do /sbin/ebtables -t $table -L &> /dev/null if [ $? -eq 0 ]; then EBTABLES_SUPPORTED_TABLES="${EBTABLES_SUPPORTED_TABLES} $table" fi done } function load() { RETVAL=0 get_supported_tables log_daemon_msg "Restoring ebtables rulesets" for table in $EBTABLES_SUPPORTED_TABLES; do log_progress_msg "$table" if [ -s ${EBTABLES_DUMPFILE_STEM}.$table ]; then /sbin/ebtables -t $table --atomic-file ${EBTABLES_DUMPFILE_STEM}.$table --atomic-commit RET=$? if [ $RET -ne 0 ]; then log_progress_msg "(failed)" RETVAL=$RET fi else log_progress_msg "(no saved state)" fi done if [ -z "$EBTABLES_SUPPORTED_TABLES" ]; then log_progress_msg "no kernel support" else log_progress_msg "done" fi log_end_msg $RETVAL } function clear() { RETVAL=0 get_supported_tables log_daemon_msg "Clearing ebtables rulesets" for table in $EBTABLES_SUPPORTED_TABLES; do log_progress_msg "$table" /sbin/ebtables -t $table --init-table done if [ "$EBTABLES_MODULES_UNLOAD" = "yes" ]; then for mod in $(grep -E '^(ebt|ebtable)_' /proc/modules | cut -d' ' -f1) ebtables; do rmmod $mod 2> /dev/null done fi if [ -z "$EBTABLES_SUPPORTED_TABLES" ]; then log_progress_msg "no kernel support" else log_progress_msg "done" fi log_end_msg $RETVAL } function save() { RETVAL=0 get_supported_tables log_daemon_msg "Saving ebtables rulesets" for table in $EBTABLES_SUPPORTED_TABLES; do log_progress_msg "$table" [ -n "$EBTABLES_BACKUP_SUFFIX" ] && [ -s ${EBTABLES_DUMPFILE_STEM}.$table ] && \ mv ${EBTABLES_DUMPFILE_STEM}.$table ${EBTABLES_DUMPFILE_STEM}.$table$EBTABLES_BACKUP_SUFFIX /sbin/ebtables -t $table --atomic-file ${EBTABLES_DUMPFILE_STEM}.$table --atomic-save RET=$? if [ $RET -ne 0 ]; then log_progress_msg "(failed)" RETVAL=$RET else if [ "$EBTABLES_SAVE_COUNTER" = "no" ]; then /sbin/ebtables -t $table --atomic-file ${EBTABLES_DUMPFILE_STEM}.$table -Z fi fi done if [ -z "$EBTABLES_SUPPORTED_TABLES" ]; then log_progress_msg "no kernel support" else log_progress_msg "done" fi log_end_msg $RETVAL } case "$1" in start) [ "$EBTABLES_LOAD_ON_START" = "yes" ] && load ;; stop) [ "$EBTABLES_SAVE_ON_STOP" = "yes" ] && save clear # Never return failure for stop; it's not helpful, and causes problems # in some cases during pkg upgrade, e.g. LP: #1774120 RETVAL=0 ;; restart|reload|force-reload) [ "$EBTABLES_SAVE_ON_RESTART" = "yes" ] && save clear [ "$EBTABLES_LOAD_ON_START" = "yes" ] && load ;; load) load ;; save) save ;; status) get_supported_tables if [ -z "$EBTABLES_SUPPORTED_TABLES" ]; then log_failure_msg "No kernel support for ebtables." RETVAL=1 else log_daemon_msg "Ebtables support available, number of installed rules" for table in $EBTABLES_SUPPORTED_TABLES; do COUNT=$(( $(/sbin/ebtables -t $table -L | sed -e "/^Bridge chain/! d" -e "s/^.*entries: //" -e "s/,.*$/ +/") 0 )) log_progress_msg "$table($COUNT)" done log_end_msg 0 RETVAL=0 fi ;; *) echo "Usage: $0 {start|stop|restart|reload|force-reload|load|save|status}" >&2 RETVAL=1 esac exit $RETVAL
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
acpid | File | 2.22 KB | 0755 |
|
apache-htcacheclean | File | 2.43 KB | 0755 |
|
apache2 | File | 7.99 KB | 0755 |
|
apparmor | File | 4.23 KB | 0755 |
|
apport | File | 2.85 KB | 0755 |
|
atd | File | 1.05 KB | 0755 |
|
cgroupfs-mount | File | 1.86 KB | 0755 |
|
console-setup.sh | File | 1.2 KB | 0755 |
|
cron | File | 2.98 KB | 0755 |
|
cryptdisks | File | 937 B | 0755 |
|
cryptdisks-early | File | 978 B | 0755 |
|
danted | File | 3.72 KB | 0755 |
|
dbus | File | 2.75 KB | 0755 |
|
docker | File | 3.42 KB | 0755 |
|
ebtables | File | 4.38 KB | 0755 |
|
grub-common | File | 985 B | 0755 |
|
hddtemp | File | 2.99 KB | 0755 |
|
hwclock.sh | File | 3.72 KB | 0755 |
|
irqbalance | File | 2.39 KB | 0755 |
|
iscsid | File | 1.47 KB | 0755 |
|
keyboard-setup.sh | File | 1.44 KB | 0755 |
|
kmod | File | 2 KB | 0755 |
|
lm-sensors | File | 883 B | 0755 |
|
lvm2 | File | 695 B | 0755 |
|
lvm2-lvmetad | File | 571 B | 0755 |
|
lvm2-lvmpolld | File | 586 B | 0755 |
|
lxcfs | File | 2.32 KB | 0755 |
|
lxd | File | 2.19 KB | 0755 |
|
mdadm | File | 2.59 KB | 0755 |
|
mdadm-waitidle | File | 1.22 KB | 0755 |
|
mysql | File | 5.48 KB | 0755 |
|
netfilter-persistent | File | 1.33 KB | 0755 |
|
network-manager | File | 1.9 KB | 0755 |
|
open-iscsi | File | 2.44 KB | 0755 |
|
open-vm-tools | File | 1.8 KB | 0755 |
|
openvpn | File | 8.92 KB | 0755 |
|
plymouth | File | 1.33 KB | 0755 |
|
plymouth-log | File | 752 B | 0755 |
|
pppd-dns | File | 612 B | 0755 |
|
procps | File | 1.16 KB | 0755 |
|
rsync | File | 4.25 KB | 0755 |
|
rsyslog | File | 2.8 KB | 0755 |
|
screen-cleanup | File | 1.19 KB | 0755 |
|
ssh | File | 3.75 KB | 0755 |
|
tor | File | 5.92 KB | 0755 |
|
ubuntu-fan | File | 1.2 KB | 0755 |
|
udev | File | 5.83 KB | 0755 |
|
ufw | File | 2.03 KB | 0755 |
|
unattended-upgrades | File | 1.36 KB | 0755 |
|
uuidd | File | 1.28 KB | 0755 |
|
x11-common | File | 2.69 KB | 0755 |
|