diff options
author | Michał Górny <mgorny@gentoo.org> | 2020-03-08 07:47:55 +0100 |
---|---|---|
committer | Michał Górny <mgorny@gentoo.org> | 2020-03-08 09:25:01 +0100 |
commit | cdd296785dd4ea84ee1e7be6e6c57c3ec26bb590 (patch) | |
tree | 417e4e9d52affa62cc98e67a58504e8dceb8f56f /mail-filter/pyzor | |
parent | package.mask: Unmask dev-python/pyzor, it's a program (diff) | |
download | gentoo-cdd296785dd4ea84ee1e7be6e6c57c3ec26bb590.tar.gz gentoo-cdd296785dd4ea84ee1e7be6e6c57c3ec26bb590.tar.bz2 gentoo-cdd296785dd4ea84ee1e7be6e6c57c3ec26bb590.zip |
Move {dev-python → mail-filter}/pyzor
Signed-off-by: Michał Górny <mgorny@gentoo.org>
Diffstat (limited to 'mail-filter/pyzor')
-rw-r--r-- | mail-filter/pyzor/Manifest | 1 | ||||
-rw-r--r-- | mail-filter/pyzor/files/read-stdin-as-binary-in-get_input_msg.patch | 85 | ||||
-rw-r--r-- | mail-filter/pyzor/files/unfix-configparser-compat-for-2to3.patch | 41 | ||||
-rw-r--r-- | mail-filter/pyzor/metadata.xml | 28 | ||||
-rw-r--r-- | mail-filter/pyzor/pyzor-1.0.0-r1.ebuild | 71 |
5 files changed, 226 insertions, 0 deletions
diff --git a/mail-filter/pyzor/Manifest b/mail-filter/pyzor/Manifest new file mode 100644 index 000000000000..4cfe0abd497e --- /dev/null +++ b/mail-filter/pyzor/Manifest @@ -0,0 +1 @@ +DIST pyzor-1.0.0.tar.gz 126276 BLAKE2B c60f26c53bf118c88dacbc49ddd414473748af1868b383a9c937ecf3cfe426ecdd60f64388fe7e555bd4641ef445769600e40879279dd544ef9ea32bd0dab6b9 SHA512 b3fb8b2c5261e187a2ab3a5a3b12d221df7de08766c6bb2ad9990c0f23517534871ecc9d5ad529e79b0d0aef8b2b800728320c57435a8c0d8c3f80a4ba0f7e4a diff --git a/mail-filter/pyzor/files/read-stdin-as-binary-in-get_input_msg.patch b/mail-filter/pyzor/files/read-stdin-as-binary-in-get_input_msg.patch new file mode 100644 index 000000000000..03031a976690 --- /dev/null +++ b/mail-filter/pyzor/files/read-stdin-as-binary-in-get_input_msg.patch @@ -0,0 +1,85 @@ +From 66225b32d2774cf37fa7f702f7eb26cd94094482 Mon Sep 17 00:00:00 2001 +From: Michael Orlitzky <michael@orlitzky.com> +Date: Sun, 4 Mar 2018 17:27:01 -0500 +Subject: [PATCH 1/1] scripts/pyzor: replace the client with the git (+ issue + 64 fix) version. + +--- + scripts/pyzor | 33 +++++++++++++++++++++++++++------ + 1 file changed, 27 insertions(+), 6 deletions(-) + +diff --git a/scripts/pyzor b/scripts/pyzor +index 19b1d21..86c6f7d 100755 +--- a/scripts/pyzor ++++ b/scripts/pyzor +@@ -17,9 +17,9 @@ import tempfile + import threading + + try: +- import ConfigParser +-except ImportError: + import configparser as ConfigParser ++except ImportError: ++ import ConfigParser + + import pyzor.digest + import pyzor.client +@@ -110,7 +110,7 @@ def load_configuration(): + config = ConfigParser.ConfigParser() + # Set the defaults. + config.add_section("client") +- for key, value in defaults.iteritems(): ++ for key, value in defaults.items(): + config.set("client", key, value) + # Override with the configuration. + config.read(os.path.join(options.homedir, "config")) +@@ -171,14 +171,35 @@ def _get_input_digests(dummy): + + + def _get_input_msg(digester): +- msg = email.message_from_file(sys.stdin) ++ msg = email.message_from_bytes(get_binary_stdin().read()) + digested = digester(msg).value + yield digested + + ++def _is_binary_reader(stream, default=False): ++ try: ++ return isinstance(stream.read(0), bytes) ++ except Exception: ++ return default ++ ++ ++def get_binary_stdin(): ++ # sys.stdin might or might not be binary in some extra cases. By ++ # default it's obviously non binary which is the core of the ++ # problem but the docs recommend changing it to binary for such ++ # cases so we need to deal with it. ++ is_binary = _is_binary_reader(sys.stdin, False) ++ if is_binary: ++ return sys.stdin ++ buf = getattr(sys.stdin, 'buffer', None) ++ if buf is not None and _is_binary_reader(buf, True): ++ return buf ++ raise RuntimeError('Did not manage to get binary stdin') ++ ++ + def _get_input_mbox(digester): + tfile = tempfile.NamedTemporaryFile() +- tfile.write(sys.stdin.read().encode("utf8")) ++ tfile.write(get_binary_stdin().read()) + tfile.seek(0) + mbox = mailbox.mbox(tfile.name) + for msg in mbox: +@@ -372,7 +393,7 @@ def genkey(client, servers, config, hash_func=hashlib.sha1): + return False + # pylint: disable-msg=W0612 + salt = "".join([chr(random.randint(0, 255)) +- for unused in xrange(hash_func(b"").digest_size)]) ++ for unused in range(hash_func(b"").digest_size)]) + if sys.version_info >= (3, 0): + salt = salt.encode("utf8") + salt_digest = hash_func(salt) +-- +2.13.6 + diff --git a/mail-filter/pyzor/files/unfix-configparser-compat-for-2to3.patch b/mail-filter/pyzor/files/unfix-configparser-compat-for-2to3.patch new file mode 100644 index 000000000000..93d0f07a2579 --- /dev/null +++ b/mail-filter/pyzor/files/unfix-configparser-compat-for-2to3.patch @@ -0,0 +1,41 @@ +From e4f06e21f697b863fa45a50e535ff0c6e3621a60 Mon Sep 17 00:00:00 2001 +From: Michael Orlitzky <michael@orlitzky.com> +Date: Sun, 25 Mar 2018 10:14:21 -0400 +Subject: [PATCH 1/1] scripts/pyzor: undo ConfigParser python-3.x + compatibility. + +The build system for pyzor-1.0.0 still runs the 2to3 utility on the +scripts to be installed. As an unintended side-effect, the python-3.x +"try... import... except" compatibility block for the ConfigParser <-> +configparser module gets modified (the module name gets mistakenly +lowercased). + +This commit puts back the python-2.x "import ConfigParser" line +unconditionally, and we'll have to rely on 2to3 to fix it when run +under python-3.x. In newer versions of pyzor, the automatic 2to3 will +not happen. + +Bug: https://bugs.gentoo.org/643692 +--- + scripts/pyzor | 5 +---- + 1 file changed, 1 insertion(+), 4 deletions(-) + +diff --git a/scripts/pyzor b/scripts/pyzor +index 86c6f7d..2750d92 100755 +--- a/scripts/pyzor ++++ b/scripts/pyzor +@@ -16,10 +16,7 @@ import optparse + import tempfile + import threading + +-try: +- import configparser as ConfigParser +-except ImportError: +- import ConfigParser ++import ConfigParser + + import pyzor.digest + import pyzor.client +-- +2.16.1 + diff --git a/mail-filter/pyzor/metadata.xml b/mail-filter/pyzor/metadata.xml new file mode 100644 index 000000000000..77b1c62d6729 --- /dev/null +++ b/mail-filter/pyzor/metadata.xml @@ -0,0 +1,28 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!DOCTYPE pkgmetadata SYSTEM "http://www.gentoo.org/dtd/metadata.dtd"> +<pkgmetadata> + <maintainer type="person"> + <email>mjo@gentoo.org</email> + </maintainer> + <maintainer type="project"> + <email>python@gentoo.org</email> + <name>Python</name> + </maintainer> + <use> + <flag name="pyzord">Enable the pyzord server daemon</flag> + <flag name="gdbm"> + Enables the Gdbm back-end database engine for pyzord + </flag> + <flag name="redis"> + Enables the redis back-end database engine for pyzord through + <pkg>dev-python/redis-py</pkg> + </flag> + <flag name="gevent"> + Use <pkg>dev-python/gevent</pkg> to enable asynchronous operation + </flag> + </use> + <upstream> + <remote-id type="github">SpamExperts/pyzor</remote-id> + <remote-id type="sourceforge">pyzor</remote-id> + </upstream> +</pkgmetadata> diff --git a/mail-filter/pyzor/pyzor-1.0.0-r1.ebuild b/mail-filter/pyzor/pyzor-1.0.0-r1.ebuild new file mode 100644 index 000000000000..1cf021784362 --- /dev/null +++ b/mail-filter/pyzor/pyzor-1.0.0-r1.ebuild @@ -0,0 +1,71 @@ +# Copyright 1999-2020 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=6 + +PYTHON_COMPAT=( python3_6 ) +inherit distutils-r1 + +MY_PV="1-0-0" +DESCRIPTION="A distributed, collaborative spam detection and filtering network" +HOMEPAGE="https://github.com/SpamExperts/pyzor" +SRC_URI="https://github.com/SpamExperts/pyzor/archive/release-${MY_PV}.tar.gz -> ${P}.tar.gz" + +LICENSE="GPL-2" +SLOT="0" +KEYWORDS="~alpha amd64 hppa ~ia64 ppc ppc64 ~sparc x86 ~amd64-linux ~x86-linux" + +IUSE="doc gdbm gevent pyzord redis test" +# The test suite is py2-only +RESTRICT="test" + +# The mysql-python library is always required for the MySQL engine. We +# depend on it conditionally here because otherwise repoman will balk at +# the potential conflict between PYTHON_TARGETS and USE=mysql. But as a +# result, if you try to use the MySQL engine with python-3.x, it just +# won't work because you'll be missing the library. +RDEPEND=" + pyzord? ( + gdbm? ( $(python_gen_impl_dep 'gdbm') ) + redis? ( dev-python/redis-py[${PYTHON_USEDEP}] ) + gevent? ( dev-python/gevent[${PYTHON_USEDEP}] ) + )" +DEPEND="dev-python/setuptools[${PYTHON_USEDEP}] + doc? ( dev-python/sphinx[${PYTHON_USEDEP}] ) + test? ( ${RDEPEND} )" + +# TODO: maybe upstream would support skipping tests for which the +# dependencies are missing? +REQUIRED_USE="pyzord? ( || ( gdbm redis ) ) + test? ( gdbm redis )" +S="${WORKDIR}/${PN}-release-${MY_PV}" + +PATCHES=( + "${FILESDIR}/read-stdin-as-binary-in-get_input_msg.patch" + "${FILESDIR}/unfix-configparser-compat-for-2to3.patch" +) + +python_test() { + PYTHONPATH=. "${PYTHON}" ./tests/unit/__init__.py +} + +python_compile_all() { + use doc && emake -C docs html +} + +python_install_all() { + use doc && HTML_DOCS=( docs/.build/html/. ) + distutils-r1_python_install_all +} + +src_install() { + distutils-r1_src_install + + if use pyzord; then + dodir /usr/sbin + mv "${D}"usr/bin/pyzord* "${ED}usr/sbin" \ + || die "failed to relocate pyzord" + else + rm "${D}"usr/bin/pyzord* || die "failed to remove pyzord" + fi +} |