commit: a2cb8c69a7f234bf485399106ec2f565a3d402a0 Author: Craig Andrews <candrews <AT> gentoo <DOT> org> AuthorDate: Thu Jul 9 16:38:35 2020 +0000 Commit: Craig Andrews <candrews <AT> gentoo <DOT> org> CommitDate: Thu Jul 9 16:39:09 2020 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=a2cb8c69
net-p2p/deluge: Fix fails to load state saved by version 1.3.15-r3 Closes: https://bugs.gentoo.org/731664 Package-Manager: Portage-2.3.103, Repoman-2.3.23 Signed-off-by: Craig Andrews <candrews <AT> gentoo.org> net-p2p/deluge/deluge-2.0.3-r8.ebuild | 142 ++++++++++++++++++++ net-p2p/deluge/files/deluge-2.0.3-fix-pickle.patch | 143 +++++++++++++++++++++ 2 files changed, 285 insertions(+) diff --git a/net-p2p/deluge/deluge-2.0.3-r8.ebuild b/net-p2p/deluge/deluge-2.0.3-r8.ebuild new file mode 100644 index 00000000000..8c09d112b65 --- /dev/null +++ b/net-p2p/deluge/deluge-2.0.3-r8.ebuild @@ -0,0 +1,142 @@ +# Copyright 1999-2020 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI="7" + +PYTHON_COMPAT=( python3_{6,7,8} ) +DISTUTILS_SINGLE_IMPL=1 +inherit distutils-r1 systemd + +DESCRIPTION="BitTorrent client with a client/server model" +HOMEPAGE="https://deluge-torrent.org/" + +if [[ ${PV} == 9999 ]]; then + inherit git-r3 + EGIT_REPO_URI="https://git.deluge-torrent.org/${PN}" +else + SRC_URI="http://download.deluge-torrent.org/source/2.0/${P}.tar.xz" + KEYWORDS="~amd64 ~arm ~sparc ~x86" +fi + +LICENSE="GPL-2" +SLOT="0" +IUSE="console geoip gtk libnotify sound webinterface" +REQUIRED_USE=" + ${PYTHON_REQUIRED_USE} + libnotify? ( gtk ) + sound? ( gtk ) +" + +DEPEND=" + $(python_gen_cond_dep ' + net-libs/libtorrent-rasterbar[python,${PYTHON_MULTI_USEDEP}] + dev-python/wheel[${PYTHON_MULTI_USEDEP}] + ') + dev-util/intltool + acct-group/deluge + acct-user/deluge" +RDEPEND=" + $(python_gen_cond_dep ' + dev-python/chardet[${PYTHON_MULTI_USEDEP}] + dev-python/distro[${PYTHON_MULTI_USEDEP}] + dev-python/pillow[${PYTHON_MULTI_USEDEP}] + dev-python/pyopenssl[${PYTHON_MULTI_USEDEP}] + dev-python/pyxdg[${PYTHON_MULTI_USEDEP}] + dev-python/rencode[${PYTHON_MULTI_USEDEP}] + dev-python/setproctitle[${PYTHON_MULTI_USEDEP}] + dev-python/six[${PYTHON_MULTI_USEDEP}] + >=dev-python/twisted-17.1.0[crypt,${PYTHON_MULTI_USEDEP}] + >=dev-python/zope-interface-4.4.2[${PYTHON_MULTI_USEDEP}] + geoip? ( dev-python/geoip-python[${PYTHON_MULTI_USEDEP}] ) + gtk? ( + sound? ( dev-python/pygame[${PYTHON_MULTI_USEDEP}] ) + dev-python/pygobject:3[${PYTHON_MULTI_USEDEP}] + gnome-base/librsvg + libnotify? ( x11-libs/libnotify ) + ) + net-libs/libtorrent-rasterbar[python,${PYTHON_MULTI_USEDEP}] + dev-python/mako[${PYTHON_MULTI_USEDEP}] + ')" + +PATCHES=( + "${FILESDIR}/${PN}-2.0.3-setup.py.patch" + "${FILESDIR}/${PN}-2.0.3-UI-status.patch" + "${FILESDIR}/${PN}-2.0.3-gettext.patch" + "${FILESDIR}/${P}-fix-pickle.patch" +) + +python_prepare_all() { + local args=( + -e "/Compiling po file/a \\\tuptoDate = False" + ) + sed -i "${args[@]}" -- 'setup.py' || die + args=( + -e 's|"new_release_check": True|"new_release_check": False|' + -e 's|"check_new_releases": True|"check_new_releases": False|' + -e 's|"show_new_releases": True|"show_new_releases": False|' + ) + sed -i "${args[@]}" -- 'deluge/core/preferencesmanager.py' || die + + distutils-r1_python_prepare_all +} + +esetup.py() { + # bug 531370: deluge has its own plugin system. No need to relocate its egg info files. + # Override this call from the distutils-r1 eclass. + # This does not respect the distutils-r1 API. DONOT copy this example. + set -- "${PYTHON}" setup.py "$@" + echo "$@" + "$@" || die +} + +python_install_all() { + distutils-r1_python_install_all + if ! use console ; then + rm -r "${D}/$(python_get_sitedir)/deluge/ui/console/" || die + rm "${ED}/usr/bin/deluge-console" || die + rm "${ED}/usr/share/man/man1/deluge-console.1" ||die + fi + if ! use gtk ; then + rm -r "${D}/$(python_get_sitedir)/deluge/ui/gtk3/" || die + rm -r "${ED}/usr/share/icons/" || die + rm "${ED}/usr/bin/deluge-gtk" || die + rm "${ED}/usr/share/man/man1/deluge-gtk.1" || die + rm "${ED}/usr/share/applications/deluge.desktop" || die + fi + if use webinterface; then + newinitd "${FILESDIR}/deluge-web.init-2" deluge-web + newconfd "${FILESDIR}/deluge-web.conf" deluge-web + systemd_newunit "${FILESDIR}/deluge-web.service-3" deluge-web.service + systemd_install_serviced "${FILESDIR}/deluge-web.service.conf" + else + rm -r "${D}/$(python_get_sitedir)/deluge/ui/web/" || die + rm "${ED}/usr/bin/deluge-web" || die + rm "${ED}/usr/share/man/man1/deluge-web.1" || die + fi + newinitd "${FILESDIR}"/deluged.init-2 deluged + newconfd "${FILESDIR}"/deluged.conf-2 deluged + systemd_newunit "${FILESDIR}"/deluged.service-2 deluged.service + systemd_install_serviced "${FILESDIR}"/deluged.service.conf + + python_optimize +} + +pkg_postinst() { + elog + elog "If, after upgrading, deluge doesn't work, please remove the" + elog "'~/.config/deluge' directory and try again, but make a backup" + elog "first!" + elog + elog "To start the daemon either run 'deluged' as user" + elog "or modify /etc/conf.d/deluged and run" + elog "/etc/init.d/deluged start as root" + elog "You can still use deluge the old way" + elog + elog "Systemd unit files for deluged and deluge-web no longer source" + elog "/etc/conf.d/deluge* files. Environment variable customization now" + elog "happens in /etc/systemd/system/deluged.service.d/00gentoo.conf" + elog "and /etc/systemd/system/deluge-web.service.d/00gentoo.conf" + elog + elog "For more information look at https://dev.deluge-torrent.org/wiki/Faq" + elog +} diff --git a/net-p2p/deluge/files/deluge-2.0.3-fix-pickle.patch b/net-p2p/deluge/files/deluge-2.0.3-fix-pickle.patch new file mode 100644 index 00000000000..446ae2e9a0e --- /dev/null +++ b/net-p2p/deluge/files/deluge-2.0.3-fix-pickle.patch @@ -0,0 +1,143 @@ +https://dev.deluge-torrent.org/changeset/23b3f144fce3424ae + +Index: deluge/core/torrentmanager.py +=================================================================== +--- deluge-2.0.3/deluge/core/torrentmanager.py (revision 8b62e50eb8bf81a177c4d62484a44b766c6f54a6) ++++ deluge-2.0.3/deluge/core/torrentmanager.py (revision 23b3f144fce3424ae874d54a659cb7b8dd624ade) +@@ -26,5 +26,5 @@ + import deluge.component as component + from deluge._libtorrent import lt +-from deluge.common import archive_files, decode_bytes, get_magnet_info, is_magnet ++from deluge.common import PY2, archive_files, decode_bytes, get_magnet_info, is_magnet + from deluge.configmanager import ConfigManager, get_config_dir + from deluge.core.authmanager import AUTH_LEVEL_ADMIN +@@ -810,5 +810,8 @@ + try: + with open(filepath, 'rb') as _file: +- state = pickle.load(_file) ++ if PY2: ++ state = pickle.load(_file) ++ else: ++ state = pickle.load(_file, encoding='utf8') + except (IOError, EOFError, pickle.UnpicklingError) as ex: + message = 'Unable to load {}: {}'.format(filepath, ex) +Index: deluge/tests/data/utf8_filename_torrents.state +=================================================================== +--- deluge-2.0.3/deluge/tests/data/utf8_filename_torrents.state (revision 23b3f144fce3424ae874d54a659cb7b8dd624ade) ++++ deluge-2.0.3/deluge/tests/data/utf8_filename_torrents.state (revision 23b3f144fce3424ae874d54a659cb7b8dd624ade) +@@ -0,0 +1,85 @@ ++(ideluge.core.torrentmanager ++TorrentManagerState ++p1 ++(dp2 ++S'torrents' ++p3 ++(lp4 ++(ideluge.core.torrentmanager ++TorrentState ++p5 ++(dp6 ++S'max_download_speed' ++p7 ++I-1 ++sS'move_completed_path' ++p8 ++S'/home/calum/Downloads' ++p9 ++sS'paused' ++p10 ++I00 ++sS'max_upload_slots' ++p11 ++I-1 ++sS'prioritize_first_last' ++p12 ++I00 ++sS'max_connections' ++p13 ++I-1 ++sS'compact' ++p14 ++I00 ++sS'queue' ++p15 ++I0 ++sS'file_priorities' ++p16 ++(lp17 ++I4 ++asS'filename' ++p18 ++S'\xc2\xa2.torrent' ++p19 ++sS'max_upload_speed' ++p20 ++I-1 ++sS'save_path' ++p21 ++S'/home/calum/Downloads' ++p22 ++sS'time_added' ++p23 ++F1573563097.749759 ++sS'total_uploaded' ++p24 ++I0 ++sS'torrent_id' ++p25 ++S'80d81d55ef3b85f3c1b634c362e014b35594dc71' ++p26 ++sS'auto_managed' ++p27 ++I01 ++sS'stop_at_ratio' ++p28 ++I00 ++sS'move_completed' ++p29 ++I00 ++sS'trackers' ++p30 ++(lp31 ++sS'magnet' ++p32 ++NsS'remove_at_ratio' ++p33 ++I00 ++sS'stop_ratio' ++p34 ++F2 ++sS'is_finished' ++p35 ++I00 ++sbasb. +Index: deluge/tests/test_torrentmanager.py +=================================================================== +--- deluge-2.0.3/deluge/tests/test_torrentmanager.py (revision c6b6902e9f3e37f5b15184eb509b48b43817a331) ++++ deluge-2.0.3/deluge/tests/test_torrentmanager.py (revision 23b3f144fce3424ae874d54a659cb7b8dd624ade) +@@ -8,4 +8,6 @@ + from __future__ import unicode_literals + ++import os ++import shutil + import warnings + from base64 import b64encode +@@ -29,5 +31,5 @@ + class TorrentmanagerTestCase(BaseTestCase): + def set_up(self): +- common.set_tmp_config_dir() ++ self.config_dir = common.set_tmp_config_dir() + self.rpcserver = RPCServer(listen=False) + self.core = Core() +@@ -119,2 +121,11 @@ + InvalidTorrentError, self.tm.remove, 'torrentidthatdoesntexist' + ) ++ ++ def test_open_state_from_python2(self): ++ """Open a Python2 state with a UTF-8 encoded torrent filename.""" ++ shutil.copy( ++ common.get_test_data_file('utf8_filename_torrents.state'), ++ os.path.join(self.config_dir, 'state', 'torrents.state'), ++ ) ++ state = self.tm.open_state() ++ self.assertEqual(len(state.torrents), 1)
