commit: 0b418c3c3b57b1fd784f408d564d8f50bc9f2055 Author: David Roman <droman <AT> ifae <DOT> es> AuthorDate: Mon Oct 21 10:48:03 2024 +0000 Commit: Sam James <sam <AT> gentoo <DOT> org> CommitDate: Sun Dec 1 12:39:42 2024 +0000 URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=0b418c3c
net-p2p/kubo: add 0.31.0 Signed-off-by: David Roman <droman <AT> ifae.es> Closes: https://github.com/gentoo/gentoo/pull/39067 Signed-off-by: Sam James <sam <AT> gentoo.org> net-p2p/kubo/Manifest | 3 ++ net-p2p/kubo/files/ipfs.init | 7 +-- net-p2p/kubo/kubo-0.31.0.ebuild | 96 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 103 insertions(+), 3 deletions(-) diff --git a/net-p2p/kubo/Manifest b/net-p2p/kubo/Manifest index f834e166bdc3..79eaed1b794a 100644 --- a/net-p2p/kubo/Manifest +++ b/net-p2p/kubo/Manifest @@ -5,3 +5,6 @@ DIST kubo-0.29.0.tar.gz 16229764 BLAKE2B 91a6d322987bf7316f4acaf984ea57ea6961792 DIST kubo-0.30.0-fs-repo-15-to-16-v1.0.1-vendor.tar.xz 1643384 BLAKE2B 6c51d34ab06e662213075cdc73fce0d3dad8c9acbfd2af6cd68ee50e90c33b91f06a68bbe40f4f3de867dd2862fb3cc0a09cb377f4d1ae70750906236059de5d SHA512 f3d9fbfc93fa714491eb7b8c995b686b8af86a65c56e7f14034b0dedb36b2b9a4d489852d7988acce30dcfd53f1637e1dca42ffdaa785bc6104864fc19c45a0c DIST kubo-0.30.0-fs-repo-15-to-16-v1.0.1.tar.gz 25942003 BLAKE2B 48eb3f50c8d0064561a99dd834cfc73482003bed70be93342bb30e993b509cca6aea0d44658ea981bb1063c458ce98e796293172b01109265e431f7a6ae279ae SHA512 bf631d402ecbee75e5a49e19e31c40172aeef81a13325bbf557841ba9e765caf39df42370a20d6e4039e7bd98e27dc5bd7a42f4490f30928a5614aca2214aea1 DIST kubo-0.30.0.tar.gz 16532306 BLAKE2B 9241e8d463dfe0fd407fc6e2a30174ff67a63360a3dbef93d6f1b70fbe42ea9ce873e74109569964b8894adf95555c12b1ed66c50743b8eda591bf48b79fe8e7 SHA512 f49b53a51a07675d02d0c4457ca1a166a3db5565fc2a1659b88861c6a9ec1e94243a86115399df31069ad1f8e93b1acf14fe8b40dea63bfd3109105ad262cccc +DIST kubo-0.31.0-fs-repo-15-to-16-v1.0.1-vendor.tar.xz 1643384 BLAKE2B 6c51d34ab06e662213075cdc73fce0d3dad8c9acbfd2af6cd68ee50e90c33b91f06a68bbe40f4f3de867dd2862fb3cc0a09cb377f4d1ae70750906236059de5d SHA512 f3d9fbfc93fa714491eb7b8c995b686b8af86a65c56e7f14034b0dedb36b2b9a4d489852d7988acce30dcfd53f1637e1dca42ffdaa785bc6104864fc19c45a0c +DIST kubo-0.31.0-fs-repo-15-to-16-v1.0.1.tar.gz 25942003 BLAKE2B 48eb3f50c8d0064561a99dd834cfc73482003bed70be93342bb30e993b509cca6aea0d44658ea981bb1063c458ce98e796293172b01109265e431f7a6ae279ae SHA512 bf631d402ecbee75e5a49e19e31c40172aeef81a13325bbf557841ba9e765caf39df42370a20d6e4039e7bd98e27dc5bd7a42f4490f30928a5614aca2214aea1 +DIST kubo-0.31.0.tar.gz 18131293 BLAKE2B a34e9cf1849a14e42e3799437127a06434484f1ce8ef36730c1b8daf66f8ee33abe783866d22f1573de056c24855bc16efc60c67ed47ccdc1c08d7cf263e0097 SHA512 8e5782905c190eea81d25d8bb477f5027cf38721e5b66868c3b81de90c9b013b9e1205869f640d163355efda778b32c7b94739fd3ef46fff7819309c82e9066c diff --git a/net-p2p/kubo/files/ipfs.init b/net-p2p/kubo/files/ipfs.init index b3798b2175a5..91dac12f4810 100644 --- a/net-p2p/kubo/files/ipfs.init +++ b/net-p2p/kubo/files/ipfs.init @@ -7,10 +7,11 @@ export IPFS_PATH=${IPFS_PATH:-/var/lib/ipfs/.ipfs} pidfile="/run/ipfs.pid" command="/usr/bin/ipfs" command_args="daemon --enable-gc --migrate" +command_background=yes +output_log="/var/log/ipfs/ipfs.log" +error_log="/var/log/ipfs/ipfs.err" command_user="ipfs:ipfs" -start_stop_daemon_args="--wait 1000 -b -m \ - -1 /var/log/ipfs/ipfs.log \ - -2 /var/log/ipfs/ipfs.log" +start_stop_daemon_args="--wait 1000" depend() { need net diff --git a/net-p2p/kubo/kubo-0.31.0.ebuild b/net-p2p/kubo/kubo-0.31.0.ebuild new file mode 100644 index 000000000000..acf8c23bc11d --- /dev/null +++ b/net-p2p/kubo/kubo-0.31.0.ebuild @@ -0,0 +1,96 @@ +# Copyright 1999-2024 Gentoo Authors +# Distributed under the terms of the GNU General Public License v2 + +EAPI=8 + +inherit go-module shell-completion systemd + +# Upstreams has a directory for each migration, for example fs-repo-15-to-16, +# each directory is a program by itself. When an upstream tag is created, +# they use they the name of the last migration program + version, for example +# fs-repo-15-to-16/v1.0.1. Accordingly, we have a variable for the name and +# another for the version. Even though the tag uses the name of the last migration, +# the repository contains source code for all migrations, not only the tagged one. +FS_MIG_V="1.0.1" +FS_MIG_N="fs-repo-15-to-16" +MY_FS_MIG="${FS_MIG_N}-v${FS_MIG_V}" +FS_MIG_DIR="fs-repo-migrations-${MY_FS_MIG}" + +DESCRIPTION="Main implementation of IPFS" +HOMEPAGE="https://ipfs.tech https://github.com/ipfs/kubo/" +SRC_URI="https://github.com/ipfs/${PN}/releases/download/v${PV}/kubo-source.tar.gz -> ${P}.tar.gz" +SRC_URI+=" https://github.com/ipfs/fs-repo-migrations/archive/refs/tags/${FS_MIG_N}/v${FS_MIG_V}.tar.gz -> ${P}-${MY_FS_MIG}.tar.gz" +SRC_URI+=" https://gentoo.kropotkin.rocks/go-pkgs/${MY_FS_MIG}-vendor.tar.xz -> ${P}-${MY_FS_MIG}-vendor.tar.xz" + +S="${WORKDIR}" + +LICENSE="Apache-2.0 BSD BSD-2 CC0-1.0 ISC MIT MPL-2.0" +SLOT="0" +KEYWORDS="~amd64 ~x86" + +DEPEND=" + acct-group/ipfs + acct-user/ipfs + sys-fs/fuse:0 +" +RDEPEND="${DEPEND}" + +DOCS=( CHANGELOG.md CONTRIBUTING.md README.md docs/ ) + +src_prepare() { + default + + sed -i '/fs-repo-1[0-9]-to-*/d' "${FS_MIG_DIR}/ignored-migrations" || die +} + +src_compile() { + local mygoargs + mygoargs=( + -tags release + ) + + ego build "${mygoargs[@]}" -o ipfs ./cmd/ipfs + ego build "${mygoargs[@]}" -o ipfswatch ./cmd/ipfswatch + + IPFS_PATH="" ./ipfs commands completion bash > ipfs-completion.bash || die + IPFS_PATH="" ./ipfs commands completion fish > ipfs-completion.fish || die + IPFS_PATH="" ./ipfs commands completion zsh > ipfs-completion.zsh || die + + cd "${FS_MIG_DIR}" || die + emake +} + +src_test() { + ego test ./cmd/ipfs/... ./cmd/ipfswatch/... +} + +src_install() { + dobin ipfs + dobin ipfswatch + newbashcomp ipfs-completion.bash ipfs + newfishcomp ipfs-completion.fish ipfs + newzshcomp ipfs-completion.zsh _ipfs + einstalldocs + + systemd_dounit "${FILESDIR}/ipfs.service" + systemd_newunit "${FILESDIR}/ipfs-at.service" "[email protected]" + + newinitd "${FILESDIR}/ipfs.init" ipfs + newconfd "${FILESDIR}/ipfs.confd" ipfs + + keepdir /var/log/ipfs + fowners -R ipfs:ipfs /var/log/ipfs + + find "${FS_MIG_DIR}" -executable -type f -name "fs-repo-*" -exec dobin {} \; || die +} + +pkg_postinst() { + elog 'To be able to use the ipfs service you will need to create the ipfs repository' + elog '(eg: su -s /bin/sh -c "ipfs init -e" ipfs)' + elog 'or change IPFS_PATH of /etc/conf.d/ipfs with another with proper permissions.' + + # See https://bugs.gentoo.org/838238 + ewarn 'In case kubo CPU usage is too high run the next workaround' + ewarn 'su -s /bin/sh -c "ipfs config profile apply lowpower" ipfs' + ewarn 'Be aware that this will make your node less visible to other peers' +}
