diff options
Diffstat (limited to 'system/apk-tools')
-rw-r--r-- | system/apk-tools/0001-solver-allow-names-with-only-one-provider-to-be-auto.patch | 57 | ||||
-rw-r--r-- | system/apk-tools/APKBUILD | 89 | ||||
-rw-r--r-- | system/apk-tools/openssl-compat.patch | 11 |
3 files changed, 157 insertions, 0 deletions
diff --git a/system/apk-tools/0001-solver-allow-names-with-only-one-provider-to-be-auto.patch b/system/apk-tools/0001-solver-allow-names-with-only-one-provider-to-be-auto.patch new file mode 100644 index 000000000..107676e93 --- /dev/null +++ b/system/apk-tools/0001-solver-allow-names-with-only-one-provider-to-be-auto.patch @@ -0,0 +1,57 @@ +From 0dcbd933c8d3d305395a99b7b1690a187ce5ec8c Mon Sep 17 00:00:00 2001 +From: William Pitcock <nenolod@dereferenced.org> +Date: Wed, 21 Feb 2018 15:35:53 +0000 +Subject: [PATCH] solver: allow names with only one provider to be autoselected + regardless of priority + +--- + src/solver.c | 5 +++-- + test/provides.repo | 9 ++++++++- + 2 files changed, 11 insertions(+), 3 deletions(-) + +diff --git a/src/solver.c b/src/solver.c +index 91e5958..d27a7a3 100644 +--- a/src/solver.c ++++ b/src/solver.c +@@ -671,11 +671,12 @@ static void select_package(struct apk_solver_state *ss, struct apk_name *name) + (!p->pkg->ss.iif_triggered || + !p->pkg->ss.tag_ok)) + continue; +- /* Virtual packages without provider_priority cannot be autoselected */ ++ /* Virtual packages without provider_priority cannot be autoselected, ++ * unless there is only one provider */ + if (p->version == &apk_null_blob && + p->pkg->name->auto_select_virtual == 0 && + p->pkg->name->ss.requirers == 0 && +- p->pkg->provider_priority == 0) ++ (p->pkg->provider_priority == 0 && name->providers->num > 1)) + continue; + if (compare_providers(ss, p, &chosen) > 0) + chosen = *p; +diff --git a/test/provides.repo b/test/provides.repo +index 58bd416..358151e 100644 +--- a/test/provides.repo ++++ b/test/provides.repo +@@ -82,7 +82,7 @@ P:conflicted-provider-b + V:0.1 + S:1 + I:1 +-p:conflicted-provider ++p:conflicted-provider conflicted-provider-2 + + C:Q1EyN5AdpAOBJWKMR89ppC66ccccj= + P:conflicted-dep +@@ -104,3 +104,10 @@ V:0.1 + S:1 + I:1 + p:self-provide ++ ++C:Q1EyN5AdpAOBJWKMR89ppC66eeeej= ++P:conflicted-dep-2 ++V:0.1 ++S:1 ++I:1 ++D:conflicted-provider-2 +-- +2.16.1 + diff --git a/system/apk-tools/APKBUILD b/system/apk-tools/APKBUILD new file mode 100644 index 000000000..225d4c2f9 --- /dev/null +++ b/system/apk-tools/APKBUILD @@ -0,0 +1,89 @@ +# Maintainer: Natanael Copa <ncopa@alpinelinux.org> +pkgname=apk-tools +pkgver=2.9.1 +pkgrel=1 +pkgdesc="Alpine Package Keeper - package manager for alpine" +subpackages="$pkgname-static" +depends= +makedepends_build="" +makedepends_host="zlib-dev libressl libressl-dev linux-headers" +makedepends="$makedepends_build $makedepends_host" +if [ "$CBUILD" = "$CHOST" ]; then + subpackages="$subpackages lua5.2-apk:luaapk" + makedepends="$makedepends lua5.2-dev" +fi +source="http://dev.alpinelinux.org/archive/$pkgname/$pkgname-$pkgver.tar.xz + 0001-solver-allow-names-with-only-one-provider-to-be-auto.patch + openssl-compat.patch + " + +url="https://git.alpinelinux.org/cgit/apk-tools/" +arch="all" +license=GPL2 + +builddir="$srcdir/$pkgname-$pkgver" +prepare() { + default_prepare || return 1 + cd "$builddir" + sed -i -e 's:-Werror::' Make.rules + echo "FULL_VERSION=$pkgver-r$pkgrel" > config.mk || return 1 + if [ "$CBUILD" = "$CHOST" ]; then + echo "LUAAPK=YesPlease" >> config.mk + else + echo "LUAAPK=" >> config.mk + fi + echo "export LUAAPK" >> config.mk +} + +build() { + cd "$builddir" + make || return 1 + make static || return 1 +} + +check() { + cd "$builddir" + make check +} + +package() { + cd "$builddir" + make DESTDIR="$pkgdir" install + install -d "$pkgdir"/var/lib/apk \ + "$pkgdir"/var/cache/misc \ + "$pkgdir"/etc/apk/keys \ + "$pkgdir"/etc/apk/protected_paths.d \ + || return 1 + # the shipped README is empty + rm -r "$pkgdir"/usr/share/ +} + +static() { + pkgdesc="Alpine Package Keeper - static binary" + install -Dm755 "$srcdir"/$pkgname-$pkgver/src/apk.static \ + "$subpkgdir"/sbin/apk.static + + # lets sign the static binary so it can be vefified from distros + # that does not have apk-tools + local abuild_conf=${ABUILD_CONF:-"/etc/abuild.conf"} + local abuild_home=${ABUILD_USERDIR:-"$HOME/.abuild"} + local abuild_userconf=${ABUILD_USERCONF:-"$abuild_home/abuild.conf"} + [ -f "$abuild_userconf" ] && . "$abuild_userconf" + local privkey="$PACKAGER_PRIVKEY" + local pubkey=${PACKAGER_PUBKEY:-"${privkey}.pub"} + local keyname=${pubkey##*/} + ${CROSS_COMPILE}strip "$subpkgdir"/sbin/apk.static + openssl dgst -sha1 -sign "$privkey" \ + -out "$subpkgdir"/sbin/apk.static.SIGN.RSA.$keyname \ + "$subpkgdir"/sbin/apk.static || return 1 +} + +luaapk() { + pkgdesc="Lua module for apk-tools" + mkdir -p "$subpkgdir"/usr/ + mv "$pkgdir"/usr/lib "$subpkgdir"/usr/lib/ +} + +sha512sums="4ffb8d1716bbb94421b1cc4277beb47d369c429f4c3bf597d08949abb7586d30c4504edf2f775bea3b93614a280c12391b956ca8f914fb0ec27799a4a005a145 apk-tools-2.9.1.tar.xz +5ca2d2f2646032ed8f9f86357e986b054045a80ddb944be6a540566ff7092f38591ec8dfc7ac06b9daededa95e86c0e892ead55f9e8907eb318aed76644f7f97 0001-solver-allow-names-with-only-one-provider-to-be-auto.patch +5640b746cd3c6d966d5f778ffe2307902503b1fc966bedb35b50dedee34ec3d5fe2c7f200dfd3893d6640150ff6dd4efd2df9aa110b4a7fd162b84904dacb493 openssl-compat.patch" diff --git a/system/apk-tools/openssl-compat.patch b/system/apk-tools/openssl-compat.patch new file mode 100644 index 000000000..cdafefd05 --- /dev/null +++ b/system/apk-tools/openssl-compat.patch @@ -0,0 +1,11 @@ +--- apk-tools-2.8.1/libfetch/common.c.old 2017-10-27 08:12:05.000000000 -0500 ++++ apk-tools-2.8.1/libfetch/common.c 2017-11-11 22:37:18.661697875 -0600 +@@ -504,7 +504,7 @@ + + SSL_load_error_strings(); + +- conn->ssl_meth = TLS_client_method(); ++ conn->ssl_meth = SSLv23_client_method(); + conn->ssl_ctx = SSL_CTX_new(conn->ssl_meth); + SSL_CTX_set_mode(conn->ssl_ctx, SSL_MODE_AUTO_RETRY); + |