pkgs/nixos-firewall-tool: add script to interactively manipulate the NixOS firewall
This commit is contained in:
parent
5fc75da28c
commit
111ebefd1d
@ -10,6 +10,7 @@
|
|||||||
colmena
|
colmena
|
||||||
vim
|
vim
|
||||||
agenix
|
agenix
|
||||||
|
nixos-firewall-tool
|
||||||
];
|
];
|
||||||
|
|
||||||
programs.mtr.enable = true;
|
programs.mtr.enable = true;
|
||||||
|
@ -111,6 +111,7 @@
|
|||||||
nixfiles-generate-config
|
nixfiles-generate-config
|
||||||
nixfiles-updated-inputs
|
nixfiles-updated-inputs
|
||||||
nixfiles-update-ssh-host-keys
|
nixfiles-update-ssh-host-keys
|
||||||
|
nixos-firewall-tool
|
||||||
pyexcel-xlsx
|
pyexcel-xlsx
|
||||||
pyexcel-webio
|
pyexcel-webio
|
||||||
update-from-hydra
|
update-from-hydra
|
||||||
|
10
pkgs/nixos-firewall-tool/default.nix
Normal file
10
pkgs/nixos-firewall-tool/default.nix
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
{ pkgs, ... }:
|
||||||
|
|
||||||
|
pkgs.writeShellApplication {
|
||||||
|
name = "nixos-firewall-tool";
|
||||||
|
text = builtins.readFile ./nixos-firewall-tool.sh;
|
||||||
|
runtimeInputs = with pkgs; [
|
||||||
|
iptables
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
55
pkgs/nixos-firewall-tool/nixos-firewall-tool.sh
Executable file
55
pkgs/nixos-firewall-tool/nixos-firewall-tool.sh
Executable file
@ -0,0 +1,55 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
|
||||||
|
ip46tables() {
|
||||||
|
iptables -w "$@"
|
||||||
|
ip6tables -w "$@"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
show_help() {
|
||||||
|
echo "nixos-firewall-tool"
|
||||||
|
echo ""
|
||||||
|
echo "Can temporarily manipulate the NixOS firewall"
|
||||||
|
echo ""
|
||||||
|
echo "Open TCP port:"
|
||||||
|
echo " nixos-firewall-tool open tcp 8888"
|
||||||
|
echo ""
|
||||||
|
echo "Show all firewall rules:"
|
||||||
|
echo " nixos-firewall-tool show"
|
||||||
|
echo ""
|
||||||
|
echo "Open UDP port:"
|
||||||
|
echo " nixos-firewall-tool open udp 51820"
|
||||||
|
echo ""
|
||||||
|
echo "Reset firewall configuration to system settings:"
|
||||||
|
echo " nixos-firewall-tool reset"
|
||||||
|
}
|
||||||
|
|
||||||
|
if [[ -z ${1+x} ]]; then
|
||||||
|
show_help
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
case $1 in
|
||||||
|
"open")
|
||||||
|
protocol="$2"
|
||||||
|
port="$3"
|
||||||
|
|
||||||
|
ip46tables -I nixos-fw -p "$protocol" --dport "$port" -j nixos-fw-accept
|
||||||
|
;;
|
||||||
|
"show")
|
||||||
|
ip46tables --numeric --list nixos-fw
|
||||||
|
;;
|
||||||
|
"reset")
|
||||||
|
systemctl restart firewall.service
|
||||||
|
;;
|
||||||
|
-h|--help|help)
|
||||||
|
show_help
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
show_help
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
@ -8,6 +8,7 @@ self: super: {
|
|||||||
nixfiles-generate-config = self.callPackage ./nixfiles/nixfiles-generate-config.nix {};
|
nixfiles-generate-config = self.callPackage ./nixfiles/nixfiles-generate-config.nix {};
|
||||||
nixfiles-updated-inputs = self.callPackage ./nixfiles/nixfiles-updated-inputs.nix {};
|
nixfiles-updated-inputs = self.callPackage ./nixfiles/nixfiles-updated-inputs.nix {};
|
||||||
nixfiles-update-ssh-host-keys = self.callPackage ./nixfiles/nixfiles-update-ssh-host-keys.nix {};
|
nixfiles-update-ssh-host-keys = self.callPackage ./nixfiles/nixfiles-update-ssh-host-keys.nix {};
|
||||||
|
nixos-firewall-tool = self.callPackage ./nixos-firewall-tool {};
|
||||||
pyexcel-xlsx = self.python3.pkgs.callPackage ./pyexcel-xlsx {};
|
pyexcel-xlsx = self.python3.pkgs.callPackage ./pyexcel-xlsx {};
|
||||||
pyexcel-webio = self.python3.pkgs.callPackage ./pyexcel-webio {};
|
pyexcel-webio = self.python3.pkgs.callPackage ./pyexcel-webio {};
|
||||||
update-from-hydra = self.callPackage ./update-from-hydra {};
|
update-from-hydra = self.callPackage ./update-from-hydra {};
|
||||||
|
Loading…
Reference in New Issue
Block a user