1 |
# $Id: qpsmtpd.spec,v 1.11 2015/02/15 16:25:13 vip-ire Exp $ |
# $Id: qpsmtpd.spec,v 1.28 2016/06/15 20:22:07 vip-ire Exp $ |
2 |
|
|
3 |
Name: qpsmtpd |
Name: qpsmtpd |
4 |
Version: 0.84 |
Version: 0.96 |
5 |
Release: 12%{?dist} |
Release: 7%{?dist} |
6 |
Summary: qpsmtpd + qpsmtpd-apache + qpsmtpd-async |
Summary: qpsmtpd + qpsmtpd-apache |
7 |
License: MIT |
License: MIT |
8 |
Group: System Environment/Daemons |
Group: System Environment/Daemons |
9 |
URL: http://smtpd.develooper.com/ |
URL: http://smtpd.develooper.com/ |
17 |
Source0: %{name}-%{version}.tar.gz |
Source0: %{name}-%{version}.tar.gz |
18 |
Source1: qpsmtpd-forkserver.rc |
Source1: qpsmtpd-forkserver.rc |
19 |
Source2: qpsmtpd-forkserver.sysconfig |
Source2: qpsmtpd-forkserver.sysconfig |
20 |
Source3: qpsmtpd-plugin-file_connection |
Source3: qpsmtpd-xinetd |
21 |
Source4: qpsmtpd-xinetd |
Source4: in.qpsmtpd |
22 |
Source5: in.qpsmtpd |
Source5: qpsmtpd.conf |
23 |
Source6: qpsmtpd.conf |
Source6: README.selinux |
24 |
Source7: README.selinux |
|
25 |
|
Patch1: qpsmtpd-0.95-spamassassin_size_limit.patch |
26 |
Patch1: 0001-Misc-documentation-updates.patch |
Patch2: qpsmtpd-0.95-qpsmtpd_forserver_keepalive.patch |
27 |
Patch2: 0002-added-ClamAV-version-to-the-X-Virus-Checked-header.patch |
Patch3: qpsmtpd-0.95-notls_conf.patch |
28 |
Patch3: 0003-new-plugin-check_bogus_bounce.patch |
Patch4: qpsmtpd-0.95-allow_tls_proto_from_conf.patch |
29 |
Patch4: 0004-microoptimizations-replace-regex-with-lc-eq.patch |
Patch5: qpsmtpd-0.96-set_hooks.patch |
30 |
Patch5: 0005-remove-vestiges-of-a-bygone-RCS.patch |
Patch6: qpsmtpd-0.96-warn_implicit_split.patch |
31 |
Patch6: 0006-added-definedness-test-to-local_port-as-it-was-emitt.patch |
Patch7: qpsmtpd-0.96-dont_log_credentials_except_in_debug.patch |
32 |
Patch7: 0007-Add-guidelines-for-commit-messages.patch |
Patch8: qpsmtpd-0.96-uribl_data_post.patch |
33 |
Patch8: 0008-added-auth_checkpassword-plugin.patch |
Patch9: qpsmtpd-0.96-karma_strikes.patch |
34 |
Patch9: 0009-updates-to-auth_vpopmail_sql-module.patch |
Patch10: qpsmtpd-0.96-karma_tlds_conf.patch |
35 |
Patch10: 0010-new-plugin-auth_vpopmaild.patch |
Patch11: qpsmtpd-0.96-more_badrcptto.patch |
36 |
Patch11: 0011-start-working-on-Changes-file-for-0.84-next.patch |
Patch12: qpsmtpd-0.96-store_original_plugin_name.patch |
37 |
Patch12: 0012-fix-copy-paste-error-in-auth_flat_file.patch |
Patch13: qpsmtpd-0.96-dkim_no_sign_for_others_on_symlinks.patch |
38 |
Patch13: 0013-added-auth_vpopmail-plugin.patch |
Patch14: qpsmtpd-0.96-fix_dmarc_reject.patch |
39 |
Patch14: 0014-rewrote-sender_permitted_from.patch |
Patch15: qpsmtpd-0.96-add_dmarc_result_notes.patch |
40 |
Patch15: 0015-add-TCPLOCAL-variables-to-qp-connection.patch |
Patch16: qpsmtpd-0.96-spf_on_no_dmarc_policy.patch |
41 |
Patch16: 0016-added-local_ip-option-to-p0f-plugin.patch |
Patch17: qpsmtpd-0.96-find_karma_db_dir.patch |
42 |
Patch17: 0017-added-p0f-support-to-greylist-plugin.patch |
Patch18: qpsmtpd-0.96-check_negative_karma_strikes.patch |
43 |
Patch18: 0018-packaging-updates.patch |
Patch19: qpsmtpd-0.96-addr_defined_before_use.patch |
44 |
Patch19: 0019-Check-for-the-exact-string-resonses-from-vpopmaild-r.patch |
Patch20: qpsmtpd-0.96-check_rua_is_defined.patch |
45 |
Patch20: 0020-new-plugin-check_badmailfrom_patterns.patch |
Patch21: qpsmtpd-0.96-remove_karma_rcpt_handler.patch |
46 |
Patch21: 0021-ignore-search-path-in-DNS-lookups.patch |
Patch22: qpsmtpd-0.96-eval_dkim_policies.patch |
|
Patch22: 0022-don-t-create-homedir-in-RPM.patch |
|
|
Patch23: 0023-corrected-email-address.patch |
|
|
Patch24: 0024-increased-default-TLS-security-setting.patch |
|
|
Patch25: 0025-give-badrcptto-a-reasonable-name.patch |
|
|
Patch26: 0026-add-test-name-to-test-output.patch |
|
|
Patch27: 0027-renamed-test-from-foo-to-rcpt_ok.patch |
|
|
Patch28: 0028-Shorten-clarify-Connection-and-Transaction-notes.patch |
|
|
Patch29: 0029-Run-hook_reset_transaction-after-all-connections.patch |
|
|
Patch30: 0030-Add-support-for-multiple-postfix-cleanup-sockets.patch |
|
|
Patch31: 0031-Adds-the-ability-to-have-multiple-instances-each-wit.patch |
|
|
Patch32: 0032-I-forgot-to-sync-the-code-that-calls-the-original-co.patch |
|
|
Patch33: 0033-new-plugin-rcpt_map.patch |
|
|
Patch34: 0034-plugins-rcpt_map-cleanup.patch |
|
|
Patch35: 0035-Fix-for-plugins-returning-DONE-from-HELO-EHLO.patch |
|
|
Patch36: 0036-prefork-use-new-instance-instead-of-cloning.patch |
|
|
Patch37: 0037-Revert-Spool-body-when-transaction-body_fh-is-called.patch |
|
|
Patch38: 0038-Patch-FATAL-PLUGIN-ERROR-check_basicheaders.patch |
|
|
Patch39: 0039-qpsmtpd-0.84-spamassassin_size_limit.patch |
|
|
Patch40: 0040-qpsmtpd-forkserver_fix_Net_DNS_update_breaks_qpsmtpd.patch |
|
|
|
|
|
Patch100: qpsmtpd-0.40-badrcptto_allowrelay.patch |
|
|
Patch101: qpsmtpd-0.83-peer_hooks.patch |
|
|
Patch102: qpsmtpd-0.83-loginit.patch |
|
|
Patch103: qpsmtpd-forkserver-keepalive.patch |
|
|
Patch104: qpsmtpd-0.84-accept-empty-email.patch |
|
|
Patch105: qpsmtpd-0.84-fix_eq_operator.patch |
|
|
Patch106: qpsmtpd-0.84-remove_denysoft_on_spf_softfail.patch |
|
47 |
|
|
48 |
%description |
%description |
49 |
qpsmtpd is a flexible smtpd daemon written in Perl. Apart from the core |
qpsmtpd is a flexible smtpd daemon written in Perl. Apart from the core |
58 |
Summary: mod_perl-2 connection handler for qpsmtpd |
Summary: mod_perl-2 connection handler for qpsmtpd |
59 |
Group: System Environment/Daemons |
Group: System Environment/Daemons |
60 |
|
|
|
%package async |
|
|
Summary: qpsmtpd using async I/O in a single process |
|
|
Group: System Environment/Daemons |
|
|
|
|
61 |
%description apache |
%description apache |
62 |
|
|
63 |
This module implements a mod_perl/apache 2.0 connection handler |
This module implements a mod_perl/apache 2.0 connection handler |
64 |
that turns Apache into an SMTP server using Qpsmtpd. |
that turns Apache into an SMTP server using Qpsmtpd. |
65 |
|
|
|
%description async |
|
|
This package contains the Qpsmtpd::PollServer module, which allows |
|
|
qpsmtd to handle many connections in a single process and the |
|
|
qpsmpd-async which uses it. |
|
66 |
|
|
67 |
%prep |
%prep |
68 |
%setup -q |
%setup -q |
87 |
%patch19 -p1 |
%patch19 -p1 |
88 |
%patch20 -p1 |
%patch20 -p1 |
89 |
%patch21 -p1 |
%patch21 -p1 |
90 |
#%patch22 -p1 |
%patch22 -p1 |
|
%patch23 -p1 |
|
|
%patch24 -p1 |
|
|
%patch25 -p1 |
|
|
%patch26 -p1 |
|
|
%patch27 -p1 |
|
|
%patch28 -p1 |
|
|
%patch29 -p1 |
|
|
%patch30 -p1 |
|
|
%patch31 -p1 |
|
|
%patch32 -p1 |
|
|
%patch33 -p1 |
|
|
%patch34 -p1 |
|
|
%patch35 -p1 |
|
|
%patch36 -p1 |
|
|
%patch37 -p1 |
|
|
%patch38 -p1 |
|
|
%patch39 -p1 |
|
|
%patch40 -p1 |
|
|
|
|
|
%patch100 -p1 |
|
|
%patch101 -p1 |
|
|
%patch102 -p1 |
|
|
%patch103 -p0 |
|
|
%patch104 -p1 |
|
|
%patch105 -p1 |
|
|
%patch106 -p1 |
|
91 |
|
|
92 |
%build |
%build |
93 |
CFLAGS="$RPM_OPT_FLAGS" perl Makefile.PL INSTALLDIRS="vendor" PREFIX="%{buildroot}%{_prefix}" |
CFLAGS="$RPM_OPT_FLAGS" perl Makefile.PL INSTALLDIRS="vendor" PREFIX="%{buildroot}%{_prefix}" |
114 |
cp %{SOURCE1} %{buildroot}%{_initrddir}/qpsmtpd-forkserver |
cp %{SOURCE1} %{buildroot}%{_initrddir}/qpsmtpd-forkserver |
115 |
mkdir -p %{buildroot}%{_sysconfdir}/sysconfig |
mkdir -p %{buildroot}%{_sysconfdir}/sysconfig |
116 |
cp %{SOURCE2} %{buildroot}%{_sysconfdir}/sysconfig/qpsmtpd-forkserver |
cp %{SOURCE2} %{buildroot}%{_sysconfdir}/sysconfig/qpsmtpd-forkserver |
|
cp %{SOURCE3} %{buildroot}%{_datadir}/%{name}/plugins/logging/file_connection |
|
117 |
mkdir -p %{buildroot}%{_localstatedir}/spool/qpsmtpd |
mkdir -p %{buildroot}%{_localstatedir}/spool/qpsmtpd |
118 |
mkdir -p %{buildroot}%{_localstatedir}/log/qpsmtpd |
mkdir -p %{buildroot}%{_localstatedir}/log/qpsmtpd |
119 |
mkdir -p %{buildroot}%{_sysconfdir}/xinetd.d |
mkdir -p %{buildroot}%{_sysconfdir}/xinetd.d |
120 |
cp %{SOURCE4} %{buildroot}%{_sysconfdir}/xinetd.d/smtp |
cp %{SOURCE3} %{buildroot}%{_sysconfdir}/xinetd.d/smtp |
121 |
mkdir -p %{buildroot}%{_sbindir} |
mkdir -p %{buildroot}%{_sbindir} |
122 |
cp %{SOURCE5} %{buildroot}%{_sbindir}/in.smtp |
cp %{SOURCE4} %{buildroot}%{_sbindir}/in.smtp |
123 |
mkdir -p %{buildroot}%{_sysconfdir}/httpd/conf.d |
mkdir -p %{buildroot}%{_sysconfdir}/httpd/conf.d |
124 |
cp %{SOURCE6} %{buildroot}%{_sysconfdir}/httpd/conf.d |
cp %{SOURCE5} %{buildroot}%{_sysconfdir}/httpd/conf.d |
125 |
mkdir -p %{buildroot}%{_docdir}/%{name}-apache-%{version} |
mkdir -p %{buildroot}%{_docdir}/%{name}-apache-%{version} |
126 |
cp %{SOURCE7} %{buildroot}%{_docdir}/%{name}-apache-%{version} |
cp %{SOURCE6} %{buildroot}%{_docdir}/%{name}-apache-%{version} |
127 |
|
|
128 |
[ -x /usr/lib/rpm/brp-compress ] && /usr/lib/rpm/brp-compress |
[ -x /usr/lib/rpm/brp-compress ] && /usr/lib/rpm/brp-compress |
129 |
|
|
135 |
grep -v README.selinux | \ |
grep -v README.selinux | \ |
136 |
grep -v /Apache | \ |
grep -v /Apache | \ |
137 |
grep -v /Danga | \ |
grep -v /Danga | \ |
|
grep -v Qpsmtpd/ConfigServer.pm | \ |
|
138 |
grep -v Qpsmtpd/PollServer.pm > %{name}-%{version}-%{release}-filelist |
grep -v Qpsmtpd/PollServer.pm > %{name}-%{version}-%{release}-filelist |
139 |
if [ "$(cat %{name}-%{version}-%{release}-filelist)X" = "X" ] ; then |
if [ "$(cat %{name}-%{version}-%{release}-filelist)X" = "X" ] ; then |
140 |
echo "ERROR: EMPTY FILE LIST" |
echo "ERROR: EMPTY FILE LIST" |
143 |
|
|
144 |
%files -f %{name}-%{version}-%{release}-filelist |
%files -f %{name}-%{version}-%{release}-filelist |
145 |
%defattr(-,root,root) |
%defattr(-,root,root) |
146 |
%doc CREDITS Changes LICENSE README README.plugins STATUS |
%doc CREDITS Changes LICENSE README.md README.plugins.md STATUS |
147 |
%{_initrddir}/qpsmtpd-forkserver |
%{_initrddir}/qpsmtpd-forkserver |
148 |
%config(noreplace) %{_sysconfdir}/qpsmtpd/* |
%config(noreplace) %{_sysconfdir}/qpsmtpd/* |
149 |
%config(noreplace) %{_sysconfdir}/xinetd.d/smtp |
%config(noreplace) %{_sysconfdir}/xinetd.d/smtp |
156 |
%config(noreplace) %{_sysconfdir}/httpd/conf.d/* |
%config(noreplace) %{_sysconfdir}/httpd/conf.d/* |
157 |
%doc %{_docdir}/%{name}-apache-%{version}/README.selinux |
%doc %{_docdir}/%{name}-apache-%{version}/README.selinux |
158 |
|
|
|
%files async |
|
|
%defattr(-,root,root) |
|
|
%{_bindir}/qpsmtpd-async |
|
|
%{_prefix}/share/perl5/vendor_perl/Danga/Client.pm |
|
|
%{_prefix}/share/perl5/vendor_perl/Danga/TimeoutSocket.pm |
|
|
%{_prefix}/share/perl5/vendor_perl/Qpsmtpd/ConfigServer.pm |
|
|
%{_prefix}/share/perl5/vendor_perl/Qpsmtpd/Plugin/Async/DNSBLBase.pm |
|
|
%{_prefix}/share/perl5/vendor_perl/Qpsmtpd/PollServer.pm |
|
|
%{_mandir}/man1/qpsmtpd-async.1.gz |
|
|
%{_datadir}/%{name}/plugins/async/* |
|
|
|
|
159 |
%pre |
%pre |
160 |
|
if ! id smtpd >/dev/null 2>&1 |
161 |
|
then |
162 |
|
# need to create smtpd user. |
163 |
|
if perl -e 'exit ! defined(getgrnam("postdrop"))' |
164 |
|
then |
165 |
|
# if postfix is installed, we will probably use |
166 |
|
# queue/postfix, which will need this: |
167 |
|
supp="-G postdrop" |
168 |
|
fi |
169 |
|
useradd -r -M -s /bin/false $supp smtpd |
170 |
|
fi |
171 |
|
|
172 |
%changelog |
%changelog |
173 |
|
* Tue Jul 5 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-7.sme |
174 |
|
- Use eval to fetch dkim policies, prevent fatal errors in case of DNS |
175 |
|
timeout [SME: 9504] |
176 |
|
|
177 |
|
* Wed Jun 15 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-6.sme |
178 |
|
- Remove karma rcpt handling (buggy and doesn't make a lot of sense) |
179 |
|
[SME: 9502] |
180 |
|
|
181 |
|
* Sat May 28 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-5.sme |
182 |
|
- Check rua is defined before trying to parse it to prevent an error |
183 |
|
if a domain has a DMARC entry published with no rua [SME: 9507] |
184 |
|
|
185 |
|
* Mon May 16 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-4.sme |
186 |
|
- Fix error when RCPT TO is not valid [SME: 8861] |
187 |
|
|
188 |
|
* Mon May 9 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-3.sme |
189 |
|
- Fix karma logic by checking negative strikes [SME: 9502] |
190 |
|
|
191 |
|
* Sun May 8 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-2.sme |
192 |
|
- Backport a fix for karma_tool so it can find its database [SME: 9502] |
193 |
|
|
194 |
|
* Fri May 6 2016 Daniel Berteaud <daniel@firewall-services.com> 0.96-1.sme |
195 |
|
- Update to 0.96 (with some backports from GIT head) [SME: 8861] |
196 |
|
|
197 |
|
* Thu Jan 7 2016 Daniel Berteaud <daniel@firewall-services.com> 0.84-18.sme |
198 |
|
- Allow reading SSL_version from the tls_protocols config file (and turn |
199 |
|
TLSv1 back on by default) [SME: 9162] |
200 |
|
|
201 |
|
* Wed Jan 6 2016 Daniel Berteaud <daniel@firewall-services.com> 0.84-17.sme |
202 |
|
- Correctly log login attempts with nulls in login name [SME: 9167] |
203 |
|
|
204 |
|
* Wed Jan 6 2016 Daniel Berteaud <daniel@firewall-services.com> 0.84-16.sme |
205 |
|
- Disable TLSv1 [SME: 9162] |
206 |
|
|
207 |
|
* Fri Sep 11 2015 stephane de Labrusse <stephdl@de-labrusse.fr> 0.84-15.sme |
208 |
|
- Modify whitelist_soft transaction to interact with dnsbl filter [SME: 8747] |
209 |
|
- by John Crisp <jcrisp@safeandsoundit.co.uk> |
210 |
|
- Added qpsmtpd-0.84-make-dnsbl-more-whitelist_soft-aware.patch |
211 |
|
|
212 |
|
* Tue May 19 2015 Daniel Berteaud <daniel@firewall-services.com> 0.84-14.sme |
213 |
|
- Disable SSLv3 [SME: 8926] |
214 |
|
|
215 |
|
* Fri May 15 2015 Daniel Berteaud <daniel@firewall-services.com> 0.84-13.sme |
216 |
|
- New notls conf to set hosts you dont want to advertize STARTTLS to [SME: 8863] |
217 |
|
|
218 |
* Sun Feb 15 2015 Daniel Berteaud <daniel@firewall-services.com> 0.84-12.sme |
* Sun Feb 15 2015 Daniel Berteaud <daniel@firewall-services.com> 0.84-12.sme |
219 |
- Revert forcing TLSv1 patch as it breaks some inbound delivery [SME: 8851] |
- Revert forcing TLSv1 patch as it breaks some inbound delivery [SME: 8851] |
220 |
- Revert whitelist_soft dnsbl as it hasn't been verified yet and we need to |
- Revert whitelist_soft dnsbl as it hasn't been verified yet and we need to |