mirror of
https://github.com/daylinmorgan/oizys.git
synced 2025-01-10 07:07:33 -06:00
99 lines
2.6 KiB
Nix
99 lines
2.6 KiB
Nix
|
# pkg: https://github.com/NixOS/nixpkgs/blob/master/pkgs/tools/security/fail3ban/default.nix
|
||
|
# module: https://github.com/NixOS/nixpkgs/blob/master/nixos/modules/services/security/fail2ban.nix
|
||
|
|
||
|
{
|
||
|
lib,
|
||
|
stdenv,
|
||
|
fetchFromGitHub,
|
||
|
python3,
|
||
|
installShellFiles,
|
||
|
}:
|
||
|
let
|
||
|
|
||
|
rev = "8170e9fe75fd2c2c4c51a1d9972b683401cddccb";
|
||
|
in
|
||
|
|
||
|
python3.pkgs.buildPythonApplication {
|
||
|
pname = "fail2ban";
|
||
|
# version = "1.0.2";
|
||
|
version = "1.1.0-${builtins.substring 0 8 rev}";
|
||
|
|
||
|
src = fetchFromGitHub {
|
||
|
owner = "fail2ban";
|
||
|
repo = "fail2ban";
|
||
|
hash = "sha256-cOHpUPEEp3FoRjywun205ugbV+I51EWVTGwZS0jNRwE=";
|
||
|
# rev = version;
|
||
|
inherit rev;
|
||
|
};
|
||
|
|
||
|
outputs = [
|
||
|
"out"
|
||
|
"man"
|
||
|
];
|
||
|
|
||
|
nativeBuildInputs = [ installShellFiles ];
|
||
|
|
||
|
pythonPath = lib.optionals stdenv.isLinux (
|
||
|
with python3.pkgs;
|
||
|
[
|
||
|
systemd
|
||
|
pyinotify
|
||
|
]
|
||
|
);
|
||
|
|
||
|
preConfigure = ''
|
||
|
for i in config/action.d/sendmail*.conf; do
|
||
|
substituteInPlace $i \
|
||
|
--replace /usr/sbin/sendmail sendmail
|
||
|
done
|
||
|
|
||
|
substituteInPlace config/filter.d/dovecot.conf \
|
||
|
--replace dovecot.service dovecot2.service
|
||
|
'';
|
||
|
|
||
|
doCheck = false;
|
||
|
|
||
|
preInstall = ''
|
||
|
substituteInPlace setup.py --replace /usr/share/doc/ share/doc/
|
||
|
|
||
|
# see https://github.com/NixOS/nixpkgs/issues/4968
|
||
|
${python3.pythonOnBuildForHost.interpreter} setup.py install_data --install-dir=$out --root=$out
|
||
|
'';
|
||
|
|
||
|
postInstall =
|
||
|
let
|
||
|
sitePackages = "$out/${python3.sitePackages}";
|
||
|
in
|
||
|
''
|
||
|
install -m 644 -D -t "$out/lib/systemd/system" build/fail2ban.service
|
||
|
# Replace binary paths
|
||
|
sed -i "s#build/bdist.*/wheel/fail2ban.*/scripts/#$out/bin/#g" $out/lib/systemd/system/fail2ban.service
|
||
|
# Delete creating the runtime directory, systemd does that
|
||
|
sed -i "/ExecStartPre/d" $out/lib/systemd/system/fail2ban.service
|
||
|
|
||
|
# see https://github.com/NixOS/nixpkgs/issues/4968
|
||
|
rm -r "${sitePackages}/etc"
|
||
|
|
||
|
installManPage man/*.[1-9]
|
||
|
|
||
|
# This is a symlink to the build python version created by `updatePyExec`, seemingly to assure the same python version is used?
|
||
|
rm $out/bin/fail2ban-python
|
||
|
ln -s ${python3.interpreter} $out/bin/fail2ban-python
|
||
|
|
||
|
''
|
||
|
+ lib.optionalString stdenv.isLinux ''
|
||
|
# see https://github.com/NixOS/nixpkgs/issues/4968
|
||
|
rm -r "${sitePackages}/usr"
|
||
|
'';
|
||
|
|
||
|
meta = with lib; {
|
||
|
homepage = "https://www.fail2ban.org/";
|
||
|
description = "Program that scans log files for repeated failing login attempts and bans IP addresses";
|
||
|
license = licenses.gpl2Plus;
|
||
|
maintainers = with maintainers; [
|
||
|
eelco
|
||
|
lovek323
|
||
|
];
|
||
|
};
|
||
|
}
|