mail-filter/pypolicyd-spf: remove python2 support to avoid ipaddress conflict.
authorMichael Orlitzky <mjo@gentoo.org>
Tue, 15 Sep 2015 15:18:04 +0000 (11:18 -0400)
committerMichael Orlitzky <mjo@gentoo.org>
Tue, 15 Sep 2015 15:18:23 +0000 (11:18 -0400)
Current versions of pypolicyd-spf support both python2 and
python3. With python2, the dev-python/ipaddr library provides support
for IP address parsing. And with python3 (>= 3.3), the built-in
ipaddress module is used. In fact, this determination is made based on
the presence (or absence) of the ipaddress module.

So far this has been fine. But recently, dev-python/ipaddress was
introduced to backport the python3 ipaddress module to python2. Now,
when dev-python/ipaddress is detected, pypolicyd-spf (incorrectly)
assumes the python3 implementation. This is bug #559364 by Robert
Trace.

Upstream will be python3-only in the next release. They have suggested
that we drop support for python2, and that's what this revision
does. Since this can cause mail to be rejected or delayed, the new
revision replaces the original.

Bug: 559364

Package-Manager: portage-2.2.20.1

mail-filter/pypolicyd-spf/pypolicyd-spf-1.3.2-r1.ebuild [moved from mail-filter/pypolicyd-spf/pypolicyd-spf-1.3.2.ebuild with 53% similarity]

similarity index 53%
rename from mail-filter/pypolicyd-spf/pypolicyd-spf-1.3.2.ebuild
rename to mail-filter/pypolicyd-spf/pypolicyd-spf-1.3.2-r1.ebuild
index 080046136cb283fbd3be953ceb4a24284734bb34..cf6af6ad89085d88c5cba428a5e67fc6abb5a4b4 100644 (file)
@@ -4,16 +4,13 @@
 
 EAPI=5
 
-PYTHON_COMPAT=( python{2_7,3_3,3_4} )
-
-# With >=python-3.3, the built-in ipaddress module handles the parsing
-# of IP addresses. If python is built without ipv6 support, then
-# ipaddress can't parse ipv6 addresses, and the daemon will crash if it
-# sees an ipv6 SPF record. In other words, it's completely broken.
-#
-# Ideally this would remain optional for python-2.x, but until there's
-# an easy way to do that, "maybe annoying" seems a better option than
-# "maybe broken."
+# See bug #559364 before getting clever with this.
+PYTHON_COMPAT=( python{3_3,3_4} )
+
+# The built-in ipaddress module handles the parsing of IP addresses. If
+# python is built without ipv6 support, then ipaddress can't parse ipv6
+# addresses, and the daemon will crash if it sees an ipv6 SPF record. In
+# other words, it's completely broken.
 PYTHON_REQ_USE="ipv6"
 
 inherit distutils-r1
@@ -27,15 +24,7 @@ SLOT="0"
 KEYWORDS="~amd64 ~x86"
 IUSE=""
 
-# ipaddr is only needed with <python-3.3.
-#
-# The lower bound on pyspf is not strictly necessary, but some features
-# are silently disabled with older versions of pyspf.
-#
-DEPEND="$(python_gen_cond_dep \
-                       '>=dev-python/ipaddr-2.1.10[${PYTHON_USEDEP}]' \
-                       'python2*')
-       >=dev-python/pyspf-2.0.9[${PYTHON_USEDEP}]"
+DEPEND=">=dev-python/pyspf-2.0.9[${PYTHON_USEDEP}]"
 
 RDEPEND="${DEPEND}
        dev-python/authres[${PYTHON_USEDEP}]"