-%define mod_name dosevasive
-%define apxs /usr/sbin/apxs
-Summary: Apache module: DoS Evasive Maneuvers Module
-Summary(pl): Modu³ do apache: -
+# TODO: cp spec name to apache-mod_evasive.spec as it is now official name
+# see http://www.nuclearelephant.com/projects/dosevasive/
+%define mod_name evasive
+%define apxs /usr/sbin/apxs
+Summary: Apache DoS Evasive Maneuvers Module
+Summary(pl.UTF-8): Moduł manewrów omijających ataki DoS dla Apache
Name: apache-mod_%{mod_name}
-Version: 1.5.1
-Release: 0.1
-License: GPL
-Group: Networking/Daemons
-Source0: http://www.networkdweebs.com/stuff/mod_%{mod_name}.tar.gz
-URL: http://www.networkdweebs.com/stuff/security.html
+Version: 1.10.1
+Release: 1
+License: GPL v2+
+Group: Networking/Daemons/HTTP
+Source0: http://www.zdziarski.com/projects/mod_evasive/mod_%{mod_name}_%{version}.tar.gz
+# Source0-md5: 784fca4a124f25ccff5b48c7a69a65e5
+Source1: %{name}.conf
+URL: http://www.zdziarski.com/projects/mod_evasive/
BuildRequires: %{apxs}
-BuildRequires: apache-devel
-Requires(post,preun): %{apxs}
-Requires: apache
+BuildRequires: apache-devel >= 2.0
+BuildRequires: rpmbuild(macros) >= 1.268
+BuildRequires: zlib-devel
+Requires: apache(modules-api) = %apache_modules_api
+Provides: apache-mod_dosevasive
+Obsoletes: apache-mod_dosevasive
BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
-%define _pkglibdir %(%{apxs} -q LIBEXECDIR)
+%define _pkglibdir %(%{apxs} -q LIBEXECDIR 2>/dev/null)
+%define _sysconfdir %(%{apxs} -q SYSCONFDIR 2>/dev/null)
%description
-Apache module: DoS Evasive Maneuvers Module
+mod_(dos)evasive is an evasive maneuvers module for Apache to provide
+evasive action in the event of an HTTP DoS or DDoS attack or brute
+force attack. It is also designed to be a detection and network
+management tool, and can be easily configured to talk to ipchains,
+firewalls, routers, and etcetera. mod_dosevasive presently reports
+abuses via email and syslog facilities.
-%description -l pl
-Modu³ do apache: -
+%description -l pl.UTF-8
+mod_(dos)evasive to moduł manewrów omijających dla Apache, zapewniający
+akcje omijające w przypadku ataków DoS, DDoS lub brute force na usługę
+HTTP. Został zaprojektowany także jako narzędzie do wykrywania i
+zarządzania siecią, może być łatwo skonfigurowany do współpracy z
+ipchains, firewallami, routerami itp. mod_dosevasive obecnie raportuje
+nadużycia pocztą elektroniczną i poprzez sysloga.
%prep
-%setup -q -n %{mod_name}
+%setup -q -n mod_%{mod_name}
%build
-%{apxs} -c mod_%{mod_name}.c -o mod_%{mod_name}.so -lz
+%{apxs} -c mod_%{mod_name}20.c -lz
%install
rm -rf $RPM_BUILD_ROOT
install -d $RPM_BUILD_ROOT%{_pkglibdir}
+install -d $RPM_BUILD_ROOT%{_sysconfdir}/httpd.conf
-install mod_%{mod_name}.so $RPM_BUILD_ROOT%{_pkglibdir}
+install .libs/mod_%{mod_name}20.so $RPM_BUILD_ROOT%{_pkglibdir}/mod_%{mod_name}.so
+install %{SOURCE1} $RPM_BUILD_ROOT%{_sysconfdir}/httpd.conf/80_mod_%{mod_name}.conf
%clean
rm -rf $RPM_BUILD_ROOT
%post
-%{apxs} -e -a -n %{mod_name} %{_pkglibdir}/mod_%{mod_name}.so 1>&2
-if [ -f /var/lock/subsys/httpd ]; then
- /etc/rc.d/init.d/httpd restart 1>&2
-fi
+%service -q httpd restart
-%preun
+%postun
if [ "$1" = "0" ]; then
- %{apxs} -e -A -n %{mod_name} %{_pkglibdir}/mod_%{mod_name}.so 1>&2
- if [ -f /var/lock/subsys/httpd ]; then
- /etc/rc.d/init.d/httpd restart 1>&2
- fi
+ %service -q httpd restart
fi
%files
%defattr(644,root,root,755)
%doc README
-%attr(755,root,root) %{_pkglibdir}/*
+%attr(640,root,root) %config(noreplace) %verify(not md5 mtime size) %{_sysconfdir}/httpd.conf/*_mod_%{mod_name}.conf
+%attr(755,root,root) %{_pkglibdir}/*.so