Adam Majer
728df9c9df
OBS-URL: https://build.opensuse.org/package/show/server:dns/nsd?expand=0&rev=106
153 lines
4.9 KiB
RPMSpec
153 lines
4.9 KiB
RPMSpec
#
|
|
# spec file for package nsd
|
|
#
|
|
# Copyright (c) 2023 SUSE LLC
|
|
#
|
|
# 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 home %{_localstatedir}/lib/%{name}
|
|
%define configdir %{_sysconfdir}/%{name}
|
|
%define configfile %{configdir}/nsdc.conf
|
|
%define zonesfile %{configdir}/nsd.zones
|
|
%define zonesdir %{configdir}/zones
|
|
%define pidfile %{_rundir}/nsd/nsd.pid
|
|
Name: nsd
|
|
Version: 4.7.0
|
|
Release: 0
|
|
#
|
|
Summary: An authoritative-only domain name server
|
|
#
|
|
License: BSD-3-Clause
|
|
Group: Productivity/Networking/DNS/Servers
|
|
URL: https://open.nlnetlabs.nl/nsd/
|
|
Source: https://open.nlnetlabs.nl/downloads/nsd/nsd-%{version}.tar.gz
|
|
Source1: nsd.service
|
|
Source2: tmpfiles-nsd.conf
|
|
# Generated with from https://nlnetlabs.nl/people/
|
|
#
|
|
# curl -Ss https://nlnetlabs.nl/people/ | \
|
|
# grep 'PGP Key ID' | \
|
|
# sed 's,.*PGP Key ID: \([A-Z0-9 ]\+\).*,\1,' | \
|
|
# perl -e 'while($_=<>){chop; s, ,,g;print; print(" ");}' | \
|
|
# xargs gpg --export-options export-minimal --export > nsd.keyring
|
|
#
|
|
Source4: nsd.keyring
|
|
Source5: https://www.nlnetlabs.nl/downloads/nsd/nsd-%{version}.tar.gz.asc
|
|
#
|
|
BuildRequires: libevent-devel
|
|
BuildRequires: openssl-devel
|
|
BuildRequires: pkgconfig
|
|
BuildRequires: pwdutils
|
|
BuildRequires: tcpd-devel
|
|
Requires: shadow
|
|
Requires(post): coreutils
|
|
Requires(post): findutils
|
|
Requires(post): shadow
|
|
Requires(pre): coreutils
|
|
Requires(pre): shadow
|
|
%{?systemd_ordering}
|
|
|
|
%description
|
|
NSD is a complete implementation of an authoritative domain name server, developed
|
|
by NLnet Labs, with the purpose of creating more diversity in the DNS landscape.
|
|
|
|
%prep
|
|
%setup -q
|
|
|
|
%build
|
|
%configure \
|
|
--with-configdir=%{configdir} \
|
|
--with-zonesdir=%{zonesdir} \
|
|
--with-dbfile=%{home}/nsd.db \
|
|
--with-xfrdfile=%{home}/xfrd.state \
|
|
--with-pidfile=%{_rundir}/nsd/nsd.pid \
|
|
--with-logfile=/%{_localstatedir}/log/nsd/nsd.log \
|
|
--enable-root-server \
|
|
--enable-bind8-stats \
|
|
--enable-zone-stats \
|
|
--enable-mmap \
|
|
--with-user=_nsd \
|
|
--enable-ratelimit
|
|
make -O V=1 VERBOSE=1 %{?_smp_mflags}
|
|
iconv -f iso8859-1 -t utf-8 doc/RELNOTES > doc/RELNOTES.utf8
|
|
iconv -f iso8859-1 -t utf-8 doc/CREDITS > doc/CREDITS.utf8
|
|
mv -f doc/RELNOTES.utf8 doc/RELNOTES
|
|
mv -f doc/CREDITS.utf8 doc/CREDITS
|
|
|
|
%install
|
|
%make_install
|
|
chmod -Rv o= %{buildroot}%{configdir}/
|
|
#
|
|
install -d -m 0700 %{buildroot}%{home} \
|
|
%{buildroot}%{_rundir}/%{name}
|
|
#
|
|
install -d -m 0755 %{buildroot}/%{_localstatedir}/log/nsd/
|
|
touch %{buildroot}%{home}/{nsd.db,ixfr.db,xfrd.state} %{buildroot}/%{_localstatedir}/log/nsd/nsd.log
|
|
mkdir -m 0750 %{buildroot}%{zonesdir}
|
|
|
|
install -D -m 0644 %{SOURCE1} %{buildroot}%{_unitdir}/nsd.service
|
|
install -D -m 0644 %{SOURCE2} %{buildroot}%{_tmpfilesdir}/nsd.conf
|
|
ln -s -f %{_sbindir}/service %{buildroot}%{_sbindir}/rc%{name}
|
|
|
|
%pre
|
|
getent group _nsd >/dev/null || groupadd -r _nsd
|
|
getent passwd _nsd >/dev/null || \
|
|
useradd -r -g _nsd -s /bin/false -c "user for %{name}" \
|
|
-d %{home} _nsd
|
|
%service_add_pre %{name}.service
|
|
|
|
%post
|
|
systemd-tmpfiles --create %{_tmpfilesdir}/%{name}.conf || :
|
|
%service_add_post %{name}.service
|
|
|
|
%preun
|
|
%service_del_preun %{name}.service
|
|
|
|
%postun
|
|
%service_del_postun %{name}.service
|
|
|
|
%files
|
|
%doc doc/*
|
|
%{configdir}/nsd.conf.sample
|
|
%doc contrib/
|
|
%{_unitdir}/nsd.service
|
|
%dir %{_tmpfilesdir}
|
|
%{_tmpfilesdir}/nsd.conf
|
|
%{_sbindir}/rcnsd
|
|
%{_sbindir}/nsd
|
|
%{_sbindir}/nsd-control
|
|
%{_sbindir}/nsd-control-setup
|
|
%{_sbindir}/nsd-checkconf
|
|
%{_sbindir}/nsd-checkzone
|
|
%{_mandir}/man5/nsd.conf.5%{?ext_man}
|
|
%{_mandir}/man8/nsd-checkconf.8%{?ext_man}
|
|
%{_mandir}/man8/nsd-checkzone.8%{?ext_man}
|
|
%{_mandir}/man8/nsd.8%{?ext_man}
|
|
%{_mandir}/man8/nsd-control.8%{?ext_man}
|
|
#
|
|
%config(noreplace) %attr(-,root,_nsd) %{configdir}
|
|
%ghost %config %attr(640,_nsd,_nsd) %{configdir}/nsd.conf
|
|
%dir %attr(750,root,_nsd) %{zonesdir}
|
|
#
|
|
%dir %attr(750,_nsd,_nsd) %{home}
|
|
%ghost %config %attr(640,_nsd,_nsd) %{home}/nsd.db
|
|
%ghost %config %attr(640,_nsd,_nsd) %{home}/ixfr.db
|
|
%ghost %config %attr(640,_nsd,_nsd) %{home}/xfrd.state
|
|
#
|
|
%dir %attr(750,_nsd,_nsd) /%{_localstatedir}/log/nsd
|
|
%ghost %attr(640,_nsd,_nsd) /%{_localstatedir}/log/nsd/nsd.log
|
|
%ghost %attr(750,_nsd,_nsd) %{_rundir}/%{name}
|
|
|
|
%changelog
|