1 Summary: PowerDNS is a Versatile Database Driven Nameserver
2 Summary(pl): PowerDNS to wielofunkcyjny serwer nazw korzystaj±cy z relacyjnych baz danych
7 Group: Networking/Daemons
8 Source0: http://downloads.powerdns.com/releases/%{name}-%{version}.tar.gz
9 # Source0-md5: 7e9a859a5a21996dbf7b31cd61731dbc
10 Source1: http://downloads.powerdns.com/documentation/%{name}.pdf
11 # Source1-md5: 72cce8fb180c3a70437187ff0912c2a3
12 Source2: http://downloads.powerdns.com/documentation/%{name}.txt
15 Source5: %{name}.sysconfig
16 Patch0: %{name}-configure.patch
17 URL: http://www.powerdns.com/
20 BuildRequires: libstdc++-devel
21 BuildRequires: libpq++-devel
22 BuildRequires: mysql-devel
23 BuildRequires: zlib-devel
24 BuildRequires: openldap-devel
26 Requires(pre): /bin/id
27 Requires(pre): /usr/sbin/useradd
28 Requires(pre): /usr/sbin/groupadd
29 Requires(post,preun): /sbin/chkconfig
30 Requires(postun): /usr/sbin/userdel
31 BuildRoot: %{tmpdir}/%{name}-%{version}-root-%(id -u -n)
36 PowerDNS is a versatile nameserver which supports a large number of
37 different backends ranging from simple zonefiles to relational
38 databases and load balancing/failover algorithms.
41 PowerDNS to wielofunkcyjny serwer nazw posiadaj±cy du¿± liczbê wtyczek
42 od prostych stref (a'la BIND) pocz±wszy, a na relacyjnych bazach
43 danych skoñczywszy oraz zawieraj±cy algorytmy zrównowa¿enia obci±¿enia
44 i prze³±czania w wypadku awarii.
47 Summary: PowerDNS support for custom pipe backend
48 Summary(pl): Wsparcie PowerDNS dla w³asnego mechanizmu przechowywania stref
49 Group: Development/Libraries
51 %description backend-pipe
52 This package allows creation of own backend using simple STDIN/STDOUT
53 API. Example backend script in perl is provided in package
56 %description backend-pipe -l pl
57 Ten pakiet pozwala na utworzenie w³asnego mechanizmu przechowywania
58 stref za pomoc¹ prostego interfejsu STDIN/STDOUT. Przyk³adowy skrypt w
59 perlu zosta³ do³±czony do dokumentacji pakietu.
61 %package backend-gpgsql
62 Summary: PowerDNS support for PostgreSQL
63 Summary(pl): Wsparcie PowerDNS dla baz PostgresQL
64 Group: Development/Libraries
67 %description backend-gpgsql
68 This package allows zone storage in PostgreSQL relational db tables.
70 %description backend-gpgsql -l pl
71 Ten pakiet pozwala na przechowywanie danych o strefach w tabelach
72 relacyjnej bazy danych PostgreSQL.
74 %package backend-gmysql
75 Summary: PowerDNS support for MySQL
76 Summary(pl): Wsparcie PowerDNS dla baz MySQL
77 Group: Development/Libraries
80 %description backend-gmysql
81 This package allows zone storage in MySQL relational db tables.
83 %description backend-gmysql -l pl
84 Ten pakiet pozwala na przechowywanie danych o strefach w tabelach
85 relacyjnej bazy danych MySQL.
88 Summary: PowerDNS support for LDAP
89 Summary(pl): Wsparcie PowerDNS dla baz LDAP
90 Group: Development/Libraries
93 %description backend-ldap
94 This package allows zone storage in LDAP directory.
96 %description backend-ldap -l pl
97 Ten pakiet pozwala na przechowywanie danych o strefach w katalogu LDAP.
106 CPPFLAGS="-DHAVE_NAMESPACE_STD -DHAVE_CXX_STRING_HEADER -DDLLIMPORT=\"\""
108 --libdir=%{_libdir}/%{name} \
109 --sysconfdir=%{_sysconfdir}/%{name} \
110 --with-socketdir=/var/run \
111 --with-dynmodules="gmysql gpgsql pipe ldap" \
115 --with-pgsql-lib=/usr/lib \
116 --with-pgsql-includes=%{_includedir} \
123 rm -rf $RPM_BUILD_ROOT
124 install -d $RPM_BUILD_ROOT{%{_initrddir},%{_sysconfdir}/%{name},/etc/sysconfig}
127 DESTDIR=$RPM_BUILD_ROOT
129 install %{SOURCE3} $RPM_BUILD_ROOT%{_initrddir}/%{name}
130 install %{SOURCE4} $RPM_BUILD_ROOT%{_sysconfdir}/%{name}/%{name}.conf
131 install %{SOURCE5} $RPM_BUILD_ROOT/etc/sysconfig/pdns
133 # useless - modules are dlopened by *.so
134 rm -f $RPM_BUILD_ROOT%{_libdir}/%{name}/*.la
137 rm -rf $RPM_BUILD_ROOT
140 if [ -n "`getgid djbdns`" ]; then
141 if [ "`getgid djbdns`" != "32" ]; then
142 echo "Error: group djbdns doesn't have gid=32. Correct this before installing pdns." 1>&2
146 /usr/sbin/groupadd -g 32 -r -f djbdns
148 if [ -n "`id -u pdns 2>/dev/null`" ]; then
149 if [ "`id -u pdns`" != "30" ]; then
150 echo "Error: user pdns doesn't have uid=30. Correct this before installing pdns." 1>&2
154 /usr/sbin/useradd -u 30 -r -d /var/lib/pdns -s /bin/false -c "pdns User" -g djbdns pdns 1>&2
158 # dirty hack so the config file is processed correctly, and server does not respawn
159 TMP=`mktemp /tmp/pdns.install-tmp.XXXXXX`
160 sed 's/^ *//g' /etc/pdns/pdns.conf > $TMP
161 cp /etc/pdns/pdns.conf /etc/pdns/pdns.conf.rpmsave
162 mv $TMP /etc/pdns/pdns.conf
164 /sbin/chkconfig --add pdns
165 if [ -f /var/lock/subsys/pdns ]; then
166 /etc/rc.d/init.d/pdns restart >&2
168 echo "Run \"/etc/rc.d/init.d/pdns start\" to start pdns." >&2
172 if [ "$1" = "0" ]; then
173 if [ -f /var/lock/subsys/pdns ]; then
174 /etc/rc.d/init.d/pdns stop
176 /sbin/chkconfig --del pdns
180 if [ "$1" = "0" ]; then
181 /usr/sbin/userdel pdns
185 %defattr(644,root,root,755)
186 %doc ChangeLog HACKING INSTALL README TODO WARNING pdns.pdf pdns.txt
187 %config(noreplace) %attr(0600,root,root) %{_sysconfdir}/%{name}/%{name}.conf
188 %config(noreplace) %attr(0754,root,root) %{_initrddir}/%{name}
189 %attr(640,root,root) %config(noreplace) %verify(not size mtime md5) /etc/sysconfig/pdns
190 %dir %{_sysconfdir}/%{name}
191 %attr(755,root,root) %{_sbindir}/*
192 %attr(755,root,root) %{_bindir}/*
195 %files backend-gmysql
196 %defattr(644,root,root,755)
197 %attr(755,root,root) %{_libdir}/%{name}/*mysql*.so*
199 %files backend-gpgsql
200 %defattr(644,root,root,755)
201 %attr(755,root,root) %{_libdir}/%{name}/*pgsql*.so*
204 %defattr(644,root,root,755)
205 %attr(755,root,root) %{_libdir}/%{name}/*pipe*.so*
208 %defattr(644,root,root,755)
209 %attr(755,root,root) %{_libdir}/%{name}/*ldap*.so*