File owasp-modsecurity-crs.spec of Package owasp-modsecurity-crs

#
# spec file for package owasp-modsecurity-crs
#
# Copyright (c) 2023 SUSE LLC
# Copyright (c) 2023 Alessandro de Oliveira Faria (A.K.A CABELO) <cabelo@opensuse.org>
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.

# Please submit bugfixes or comments via https://bugs.opensuse.org/
#


%define apxs2 %{_bindir}/apxs
%define apache2 apache2
%define apache2_mm %(MMN=$(%{apxs2} -q LIBEXECDIR)_MMN; test -x $MMN && $MMN)
%define apache2_libexecdir %(%{apxs2} -q LIBEXECDIR)
%define apache2_sysconfdir %(%{apxs2} -q SYSCONFDIR)
%define apache2_includedir %(%{apxs2} -q INCLUDEDIR)
%define apache2_serverroot %(%{apxs2} -q PREFIX)
%define apache2_localstatedir %(%{apxs2} -q LOCALSTATEDIR)
Name:           owasp-modsecurity-crs
Version:        3.3.5
Release:        0
Summary:        OWASP ModSecurity Common Rule Set (CRS)
License:        Apache-2.0
Group:          Productivity/Networking/Security
URL:            https://coreruleset.org
Source0:        https://github.com/coreruleset/coreruleset/archive/v%{version}.tar.gz#/%{name}-%{version}.tar.xz
Source99:       README.SUSE
Source100:      %{name}-rpmlintrc
BuildRequires:  apache2-devel
BuildRequires:  gcc-c++
BuildRequires:  rpm-devel
BuildRequires:  zlib-devel
Provides:       %{name} = %{version}
BuildArch:      noarch

%description
The OWASP ModSecurity Core Rule Set (CRS) is a set of generic attack detection rules for use with ModSecurity
or compatible web application firewalls. The CRS aims to protect web applications from a wide range of attacks,
including the OWASP Top Ten, with a minimum of false alerts.

%package apache2
Summary:        OWASP ModSecurity Common Rule Set (CRS)
Group:          Productivity/Networking/Security
Requires:       %{name} = %{version}
Requires:       apache2-mod_security2

%description apache2
The OWASP ModSecurity Core Rule Set (CRS) is a set of generic attack detection rules for use with ModSecurity
or compatible web application firewalls. The CRS aims to protect web applications from a wide range of attacks,
including the OWASP Top Ten, with a minimum of false alerts.

Includes Apache httpd 2.x rules

%prep
%setup -q -n coreruleset-%{version}
sed -i -e '/^#!/c#!%{_bindir}/perl' util/*/*.pl
cp %{SOURCE99} .

%build
# Build configuration files
mkdir -p .%{_sysconfdir}/%{name}/rules.d
mkdir -p .%{_sysconfdir}/%{name}/rules

for rule in rules/*.conf
do
  RULE=$(basename ${rule})
  echo "Include \"%{_datadir}/%{name}/rules/$RULE\"" > .%{_sysconfdir}/%{name}/rules/$RULE
  echo "Include \"%{_sysconfdir}/%{name}/rules/$RULE\"" >> .%{_sysconfdir}/%{name}/rules.conf
done
ln -s ../rules.conf .%{_sysconfdir}/%{name}/rules.d/rules.conf

echo "Include \"%{_datadir}/%{name}/crs-setup.conf.example\"" > .%{_sysconfdir}/%{name}/crs-setup.conf
# Create Apache2 include
mkdir -p .%{apache2_sysconfdir}/conf.d
echo "<IfModule mod_security2.c>" > .%{apache2_sysconfdir}/conf.d/%{name}.conf
echo -e "\tInclude \"%{_sysconfdir}/%{name}/crs-setup.conf\"" >> .%{apache2_sysconfdir}/conf.d/%{name}.conf
echo -e "\tInclude \"%{_sysconfdir}/%{name}/rules.d/*\"" >> .%{apache2_sysconfdir}/conf.d/%{name}.conf
echo "</IfModule>" >> .%{apache2_sysconfdir}/conf.d/%{name}.conf

%install
# CRS data
mkdir -p %{buildroot}%{_datadir}/%{name}
cp -dr {util,*.conf*} %{buildroot}%{_datadir}/%{name}/
for rule_set in %{rule_sets}
do
cp -r rules %{buildroot}%{_datadir}/%{name}/
done
# Configuration files
mkdir -p %{buildroot}/%{_sysconfdir}
cp -dr .%{_sysconfdir}/* %{buildroot}%{_sysconfdir}/

%files
%defattr(644,root,root,755)
%doc CHANGES.md README.md README.SUSE
%license LICENSE
%dir %{_datadir}/%{name}
%{_datadir}/%{name}/util
%attr(0754, root, root) %{_datadir}/%{name}/util/av-scanning/runav.pl
%attr(0754, root, root) %{_datadir}/%{name}/util/crs2-renumbering/update.py
%attr(0754, root, root) %{_datadir}/%{name}/util/join-multiline-rules/join.py
%attr(0754, root, root) %{_datadir}/%{name}/util/regexp-assemble/regexp-assemble-v2.pl
%attr(0754, root, root) %{_datadir}/%{name}/util/regexp-assemble/regexp-assemble.pl
%attr(0754, root, root) %{_datadir}/%{name}/util/regexp-assemble/regexp-cmdline.py
%attr(0754, root, root) %{_datadir}/%{name}/util/send-payload-pls.sh
%attr(0754, root, root) %{_datadir}/%{name}/util/verify.rb
%attr(0754, root, root) %{_datadir}/%{name}/util/virtual-patching/arachni2modsec.pl
%attr(0754, root, root) %{_datadir}/%{name}/util/virtual-patching/zap2modsec.pl
%{_datadir}/%{name}/*.conf*
%{_datadir}/%{name}/rules

%files apache2
%config(noreplace) %{apache2_sysconfdir}/conf.d/%{name}.conf
%dir %{_sysconfdir}/%{name}
%dir %{_sysconfdir}/%{name}/rules.d
%config(noreplace) %{_sysconfdir}/%{name}/crs-setup.conf
%config(noreplace) %{_sysconfdir}/%{name}/rules
%config(noreplace) %{_sysconfdir}/%{name}/rules.conf
%config(noreplace) %{_sysconfdir}/%{name}/rules.d/rules.conf

%changelog
openSUSE Build Service is sponsored by