commit:     bf5eac4aac7fa7aa1a81598a9b4468e498355b0d
Author:     Andrew Savchenko <bircoph <AT> gentoo <DOT> org>
AuthorDate: Fri Jan 15 21:32:17 2021 +0000
Commit:     Andrew Savchenko <bircoph <AT> gentoo <DOT> org>
CommitDate: Fri Jan 15 21:37:42 2021 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=bf5eac4a

net-fs/openafs: 1.8.7 version bump

This update fixes critical bug in the generation of Rx connection IDs
that prevent Rx clients started after 14 Jan 2021 08:25:36 AM UTC
from being able to successfully make connections.

Bug: https://bugs.gentoo.org/765463
Package-Manager: Portage-3.0.12, Repoman-3.0.2
Signed-off-by: Andrew Savchenko <bircoph <AT> gentoo.org>

 net-fs/openafs/Manifest             |   3 +
 net-fs/openafs/openafs-1.8.7.ebuild | 343 ++++++++++++++++++++++++++++++++++++
 2 files changed, 346 insertions(+)

diff --git a/net-fs/openafs/Manifest b/net-fs/openafs/Manifest
index d37d811001a..af422ef675c 100644
--- a/net-fs/openafs/Manifest
+++ b/net-fs/openafs/Manifest
@@ -1,3 +1,6 @@
 DIST openafs-1.8.6-doc.tar.bz2 3769160 BLAKE2B 
c5fe08fbb2cdab48dd691a7e228cc590644e05b22c87afef24a5fb35aa12e379d8d49d4b920cb84dd23b4e1f1a04512078f3018808531cdc7180778885bdc466
 SHA512 
7525325a5ef6e1ceada7075f489a03e1d250d3cbd8b8e83a25c8e40d506d50cbf10c2b28b682f2f9663a8cd450cb70891a04e6dbc296347945ee2454b138d971
 DIST openafs-1.8.6-src.tar.bz2 14874336 BLAKE2B 
a83f5bfe543b3797fa6d80ebc96cacb1a15f58cf5495d1c693593bc6d24a9f08678693080b3920a97afebe937689dd0ad08bbca95c996af0d2c83935974d3613
 SHA512 
0800c3825d4e0384b43cb801fc898e9255a0fa0d0baf1f231fbf383317919cc30f68526eeec803d2dc21fc7a6b55155ea4cb23197604c70e89ecf4d520b85ec1
+DIST openafs-1.8.7-doc.tar.bz2 3808045 BLAKE2B 
8ded75239dd59633297ee4208a0f3f018486b5b5b71fda91229583fd2d6a7743bbbeba280e61ff91d602617fc47944105b06a5c0610b0c89c808ecba38af7f9c
 SHA512 
6d087320ab6681686b6afb78621b21eaec26b91dbd03a13df447ad9f0ce897332ac378b38bf1abc590575d82d8cb22757249e60a2407e4ad498d46c083632e0d
+DIST openafs-1.8.7-src.tar.bz2 15059909 BLAKE2B 
89aacc48100d3eabbec45acca3911fbd823c029a30e79ad16564dcc3646b9bbadb60a528f142fc907de0d4eb2831d922d8146cdba72c02f4e8db9ab806c84d86
 SHA512 
12d5aa9177dde10e504f71b4b1ae19be0b0c52e8031e0f5afacce4a2c3f2321970af65591edab6145f7400f6276acd7e8624aa66e816d2394324e2ef5c403c01
 DIST openafs-patches-20200913.tar.xz 28392 BLAKE2B 
5e8b8f2554453abdb0a84dd45d8e719cc60127224ee6ebeaca4fcddba3d38309d7e5070c43659d10301ab9eaf371ba7dcbcf12950166626a7d359d2a39c922c6
 SHA512 
ec0aa800b945de2fe70d949259c89a97660bdbfee3c3e43d886a5c2f6b7c530252a53ff8f196f6e80a9a657bb81f26a6937a1bec3fafbd2c70322b313a712820
+DIST openafs-patches-20210116.tar.xz 67300 BLAKE2B 
aaafa197d1be1e9d89685fe5193a4682ea9e5e5c1c3227963a97ca7a98e6ab5e855ee65d615a31162559b30ae5867fde6ceeec1055af1a375e73b9fa25654de5
 SHA512 
06e9e1b65fceda34a197556aba1a05eabb630723fc17c5060d5e2a054e60ab8c5195d5c80eff3d3444bcdca40b7115da9143f5b8100659061446038ad4a79007

diff --git a/net-fs/openafs/openafs-1.8.7.ebuild 
b/net-fs/openafs/openafs-1.8.7.ebuild
new file mode 100644
index 00000000000..afee31697da
--- /dev/null
+++ b/net-fs/openafs/openafs-1.8.7.ebuild
@@ -0,0 +1,343 @@
+# Copyright 1999-2021 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=7
+
+inherit autotools linux-mod flag-o-matic pam systemd tmpfiles toolchain-funcs
+
+MY_PV=${PV/_/}
+MY_P="${PN}-${MY_PV}"
+PVER=20210116
+KERNEL_LIMIT=5.10
+
+DESCRIPTION="The OpenAFS distributed file system"
+HOMEPAGE="https://www.openafs.org/";
+# We always d/l the doc tarball as man pages are not USE=doc material
+[[ ${PV} == *_pre* ]] && MY_PRE="candidate/" || MY_PRE=""
+SRC_URI="
+       https://openafs.org/dl/openafs/${MY_PRE}${MY_PV}/${MY_P}-src.tar.bz2
+       https://openafs.org/dl/openafs/${MY_PRE}${MY_PV}/${MY_P}-doc.tar.bz2
+       https://dev.gentoo.org/~bircoph/afs/${PN}-patches-${PVER}.tar.xz
+"
+
+LICENSE="IBM BSD openafs-krb5-a APSL-2"
+SLOT="0"
+KEYWORDS="~amd64 ~sparc ~x86 ~amd64-linux ~x86-linux"
+
+IUSE="apidoc bitmap-later debug doc fuse kauth kerberos +modules +namei
+ncurses perl +pthreaded-ubik +supergroups tsm ubik-read-while-write"
+
+BDEPEND="
+       dev-lang/perl
+       sys-devel/flex
+       virtual/yacc
+       apidoc? (
+               app-doc/doxygen[dot]
+               media-gfx/graphviz
+       )
+       doc? (
+               dev-libs/libxslt
+               || (
+                       dev-java/fop
+                       app-text/dblatex
+                       app-text/docbook-sgml-utils[jadetex]
+               )
+       )
+       perl? ( dev-lang/swig )"
+DEPEND="
+       !net-fs/openafs-kernel
+       virtual/libintl
+       amd64? ( tsm? ( app-backup/tsm ) )
+       doc? (
+               app-text/docbook-xsl-stylesheets
+               app-text/docbook-xml-dtd:4.3
+       )
+       fuse? ( sys-fs/fuse:0= )
+       kauth? ( sys-libs/pam )
+       kerberos? ( virtual/krb5 )
+       ncurses? ( sys-libs/ncurses:0= )"
+RDEPEND="${DEPEND}"
+
+S="${WORKDIR}/${MY_P}"
+
+PATCHES=( "${WORKDIR}/gentoo/patches" )
+
+CONFIG_CHECK="~!AFS_FS KEYS"
+ERROR_AFS_FS="OpenAFS conflicts with the in-kernel AFS-support. Make sure not 
to load both at the same time!"
+ERROR_KEYS="OpenAFS needs CONFIG_KEYS option enabled"
+MODULES_OPTIONAL_USE="modules"
+
+QA_TEXTRELS_x86_fbsd="/boot/modules/libafs.ko"
+QA_TEXTRELS_amd64_fbsd="/boot/modules/libafs.ko"
+
+pkg_pretend() {
+       if use modules && use kernel_linux && kernel_is -ge ${KERNEL_LIMIT/\./ 
} ; then
+               ewarn "Gentoo supports kernels which are supported by OpenAFS"
+               ewarn "which are limited to the kernel versions: < 
${KERNEL_LIMIT}"
+               ewarn ""
+               ewarn "You are free to utilize epatch_user to provide whatever"
+               ewarn "support you feel is appropriate, but will not receive"
+               ewarn "support as a result of those changes."
+               ewarn ""
+               ewarn "Please do not file a bug report about this."
+               ewarn ""
+               ewarn "Alternatively, you may:"
+               ewarn "1. Use OpenAFS FUSE client, build OpenAFS with USE=fuse 
to enable it."
+               ewarn "2. Use native kernel AFS client: configure your kernel 
with CONFIG_AFS_FS."
+               ewarn "net-fs/openafs is not required in this case, but 
client's functionality will be limited."
+       fi
+}
+
+pkg_setup() {
+       use kernel_linux && linux-mod_pkg_setup
+}
+
+src_prepare() {
+       default
+
+       # fixing 2-nd level makefiles to honor flags
+       sed -i -r 's/\<CFLAGS[[:space:]]*=/CFLAGS+=/; 
s/\<LDFLAGS[[:space:]]*=/LDFLAGS+=/' \
+               src/*/Makefile.in || die '*/Makefile.in sed failed'
+       # fix xml docs to use local dtd files
+       sed -i 
's|http://www.oasis-open.org/docbook/xml/4.3|/usr/share/sgml/docbook/xml-dtd-4.3|'
 \
+               doc/xml/*/*000.xml || die
+
+       # packaging is f-ed up, so we can't run eautoreconf
+       # run autotools commands based on what is listed in regen.sh
+       eaclocal -I src/cf -I src/external/rra-c-util/m4
+       eautoconf
+       eautoconf -o configure-libafs configure-libafs.ac
+       eautoheader
+       einfo "Deleting autom4te.cache directory"
+       rm -rf autom4te.cache || die
+}
+
+src_configure() {
+       local -a myconf
+
+       if use debug; then
+               use kauth && myconf+=( --enable-debug-pam )
+               use modules && myconf+=( --enable-debug-kernel )
+       fi
+
+       if use modules; then
+               if use kernel_linux; then
+                       if kernel_is -ge 3 17 && kernel_is -le 3 17 2; then
+                               myconf+=( 
--enable-linux-d_splice_alias-extra-iput )
+                       fi
+                       myconf+=( --with-linux-kernel-headers="${KV_DIR}" \
+                                         
--with-linux-kernel-build="${KV_OUT_DIR}" )
+               elif use kernel_FreeBSD; then
+                       myconf+=( --with-bsd-kernel-build="${BSD_BUILD_DIR}" )
+               fi
+       fi
+
+       use amd64 && use tsm && myconf+=( --enable-tivoli-tsm )
+
+       local ARCH="$(tc-arch-kernel)"
+       local MY_ARCH="$(tc-arch)"
+       local BSD_BUILD_DIR="/usr/src/sys/${MY_ARCH}/compile/GENERIC"
+
+       AFS_SYSKVERS=26 \
+       econf \
+               --disable-strip-binaries \
+               $(use_enable bitmap-later) \
+               $(use_enable debug) \
+               $(use_enable debug debug-locks) \
+               $(use_enable debug debug-lwp) \
+               $(use_enable fuse fuse-client) \
+               $(use_enable kauth) \
+               $(use_enable modules kernel-module) \
+               $(use_enable namei namei-fileserver) \
+               $(use_enable ncurses gtx) \
+               $(use_enable pthreaded-ubik) \
+               $(use_enable supergroups) \
+               $(use_enable ubik-read-while-write) \
+               $(use_with apidoc dot) \
+               $(use_with doc docbook-stylesheets 
/usr/share/sgml/docbook/xsl-stylesheets) \
+               $(use_with kerberos krb5) \
+               $(use_with kerberos gssapi) \
+               $(use_with perl swig) \
+               "${myconf[@]}"
+}
+
+src_compile() {
+       ARCH="$(tc-arch-kernel)" AR="$(tc-getAR)" emake V=1
+       local d
+       if use doc; then
+               emake -C doc/xml/AdminGuide auagd000.pdf
+               emake -C doc/xml/AdminRef auarf000.pdf
+               emake -C doc/xml/QuickStartUnix auqbg000.pdf
+               emake -C doc/xml/UserGuide auusg000.pdf
+       fi
+       use apidoc && doxygen doc/doxygen/Doxyfile
+}
+
+src_install() {
+       local OPENRCDIR="${WORKDIR}/gentoo/openrc"
+       local SYSTEMDDIR="${WORKDIR}/gentoo/systemd"
+
+       emake DESTDIR="${ED}" install_nolibafs
+
+       if use modules; then
+               if use kernel_linux; then
+                       local srcdir=$(expr "${S}"/src/libafs/MODLOAD-*)
+                       [[ -f ${srcdir}/libafs.${KV_OBJ} ]] || die "Couldn't 
find compiled kernel module"
+
+                       MODULE_NAMES="libafs(fs/openafs:${srcdir})"
+
+                       linux-mod_src_install
+               elif use kernel_FreeBSD; then
+                       insinto /boot/modules
+                       doins "${S}"/src/libafs/MODLOAD/libafs.ko
+               fi
+       fi
+
+       insinto /etc/openafs
+       doins src/afsd/CellServDB
+       echo "/afs:/var/cache/openafs:200000" > "${ED}"/etc/openafs/cacheinfo
+       echo "openafs.org" > "${ED}"/etc/openafs/ThisCell
+
+       # pam_afs and pam_afs.krb have been installed in irregular locations, 
fix
+       if use kauth; then
+               dopammod "${ED}"/usr/$(get_libdir)/pam_afs*
+       fi
+       rm -f "${ED}"/usr/$(get_libdir)/pam_afs* || die
+
+       # remove kdump stuff provided by kexec-tools #222455
+       rm -rf "${ED}"/usr/sbin/kdump* || die
+
+       # avoid collision with mit_krb5's version of kpasswd
+       if use kauth; then
+               mv "${ED}"/usr/bin/kpasswd{,_afs} || die
+               mv "${ED}"/usr/share/man/man1/kpasswd{,_afs}.1 || die
+       fi
+
+       # avoid collision with heimdal's pagsh
+       if has_version app-crypt/heimdal; then
+               mv "${ED}"/usr/bin/pagsh{,_afs} || die
+               mv "${ED}"/usr/share/man/man1/pagsh{,_afs}.1 || die
+       fi
+
+       # move lwp stuff around #200674 #330061
+       mv "${ED}"/usr/include/{lwp,lock,timer}.h "${ED}"/usr/include/afs/ || 
die
+       mv "${ED}"/usr/$(get_libdir)/liblwp* "${ED}"/usr/$(get_libdir)/afs/ || 
die
+       # update paths to the relocated lwp headers
+       sed -ri \
+               -e '/^#include <(lwp|lock|timer).h>/s:<([^>]*)>:<afs/\1>:' \
+               "${ED}"/usr/include/*.h \
+               "${ED}"/usr/include/*/*.h \
+               || die
+
+       # minimal documentation
+       use kauth && doman src/pam/pam_afs.5
+       DOCS=( "${WORKDIR}/gentoo/README.Gentoo"
+                       src/afsd/CellServDB NEWS README )
+
+       # documentation package
+       rm -rf doc/txt/winnotes || die # unneeded docs
+       if use doc; then
+               DOCS+=( doc/{pdf,protocol,txt} CODING CONTRIBUTING )
+               newdoc doc/xml/AdminGuide/auagd000.pdf AdminGuide.pdf
+               newdoc doc/xml/AdminRef/auarf000.pdf AdminRef.pdf
+               newdoc doc/xml/QuickStartUnix/auqbg000.pdf QuickStartUnix.pdf
+               newdoc doc/xml/UserGuide/auusg000.pdf UserGuide.pdf
+       fi
+       use apidoc && DOCS+=( doc/doxygen/output/html )
+       einstalldocs
+
+       # Gentoo related scripts
+       newinitd "${OPENRCDIR}"/openafs-client.initd openafs-client
+       newconfd "${OPENRCDIR}"/openafs-client.confd openafs-client
+       newinitd "${OPENRCDIR}"/openafs-server.initd openafs-server
+       newconfd "${OPENRCDIR}"/openafs-server.confd openafs-server
+       dotmpfiles "${SYSTEMDDIR}"/tmpfiles.d/openafs-client.conf
+       systemd_dounit "${SYSTEMDDIR}"/openafs-client.service
+       systemd_dounit "${SYSTEMDDIR}"/openafs-server.service
+       systemd_install_serviced "${SYSTEMDDIR}"/openafs-client.service.conf
+       systemd_install_serviced "${SYSTEMDDIR}"/openafs-server.service.conf
+
+       # used directories: client
+       keepdir /etc/openafs
+
+       # used directories: server
+       keepdir /etc/openafs/server
+       diropts -m0700
+       keepdir /var/lib/openafs
+       keepdir /var/lib/openafs/db
+       diropts -m0755
+       keepdir /var/lib/openafs/logs
+
+       # link logfiles to /var/log
+       dosym ../lib/openafs/logs /var/log/openafs
+}
+
+pkg_preinst() {
+       ## Somewhat intelligently install default configuration files
+       ## (when they are not present)
+       local x
+       for x in cacheinfo CellServDB ThisCell ; do
+               if [ -e "${EROOT}"/etc/openafs/${x} ] ; then
+                       cp "${EROOT}"/etc/openafs/${x} "${ED}"/etc/openafs/
+               fi
+       done
+}
+
+pkg_postinst() {
+       if use modules; then
+               # Update linker.hints file
+               use kernel_FreeBSD && /usr/sbin/kldxref 
"${EPREFIX}/boot/modules"
+               use kernel_linux && linux-mod_pkg_postinst
+       fi
+
+       tmpfiles_process openafs-client.conf
+
+       elog "This installation should work out of the box (at least the"
+       elog "client part doing global afs-cell browsing, unless you had"
+       elog "a previous and different configuration).  If you want to"
+       elog "set up your own cell or modify the standard config,"
+       elog "please have a look at the Gentoo OpenAFS documentation"
+       elog "(warning: it is not yet up to date wrt the new file locations)"
+       elog
+       elog "The documentation can be found at:"
+       elog "  https://wiki.gentoo.org/wiki/OpenAFS";
+       elog
+       elog "Systemd users should run emerge --config ${CATEGORY}/${PN} before"
+       elog "first use and whenever ${EROOT}/etc/openafs/cacheinfo is edited."
+}
+
+pkg_postrm() {
+       if use modules; then
+               # Update linker.hints file
+               use kernel_FreeBSD && /usr/sbin/kldxref 
"${EPREFIX}/boot/modules"
+               use kernel_linux && linux-mod_pkg_postrm
+       fi
+}
+
+pkg_config() {
+       elog "Setting cache options for systemd."
+
+       
SERVICED_FILE="${EROOT}"/etc/systemd/system/openafs-client.service.d/00gentoo.conf
+       [ ! -e "${SERVICED_FILE}" ] && die "Systemd service.d file 
${SERVICED_FILE} not found."
+
+       CACHESIZE=$(cut -d ':' -f 3 "${EROOT}"/etc/openafs/cacheinfo)
+       [ -z ${CACHESIZE} ] && die "Failed to parse 
${EROOT}/etc/openafs/cacheinfo."
+
+       if [ ${CACHESIZE} -lt 131070 ]; then
+               AFSD_CACHE_ARGS="-stat 300 -dcache 100 -daemons 2 -volumes 50"
+       elif [ ${CACHESIZE} -lt 524288 ]; then
+               AFSD_CACHE_ARGS="-stat 2000 -dcache 800 -daemons 3 -volumes 70"
+       elif [ ${CACHESIZE} -lt 1048576 ]; then
+               AFSD_CACHE_ARGS="-stat 2800 -dcache 2400 -daemons 5 -volumes 
128"
+       elif [ ${CACHESIZE} -lt 2209715 ]; then
+               AFSD_CACHE_ARGS="-stat 3600 -dcache 3600 -daemons 5 -volumes 
196 -files 50000"
+       else
+               AFSD_CACHE_ARGS="-stat 4000 -dcache 4000 -daemons 6 -volumes 
256 -files 50000"
+       fi
+
+       # Replace existing env var if exists, else append line
+       grep -q "^Environment=\"AFSD_CACHE_ARGS=" "${SERVICED_FILE}" && \
+               sed -i 
"s/^Environment=\"AFSD_CACHE_ARGS=.*/Environment=\"AFSD_CACHE_ARGS=${AFSD_CACHE_ARGS}\"/"
 "${SERVICED_FILE}" || \
+               sed -i "$ a\Environment=\"AFSD_CACHE_ARGS=${AFSD_CACHE_ARGS}\"" 
"${SERVICED_FILE}" || \
+               die "Updating ${SERVICED_FILE} failed."
+}

Reply via email to