Merge pull request #287047 from superherointj/etcd-3_5_update-script

etcd_3_5: add update script

Sandro b98abd8c bcb6ebe8

Changed files
+79 -6
pkgs
servers
top-level
+10 -5
pkgs/servers/etcd/3.5.nix pkgs/servers/etcd/3.5/default.nix
···
let
version = "3.5.12";
+
etcdSrcHash = "sha256-Z2WXNzFJYfRQCldUspQjUR5NyUzCCINycuEXWaTn4vU=";
+
etcdServerVendorHash = "sha256-S5cEIV4hKRjn9JFEKWBiSEPytHtVacsSnG6T8dofgyk=";
+
etcdUtlVendorHash = "sha256-Vgp44Kg6zUDYVJU6SiYd8ZEcAWqKPPTsqYafcfk89Cc=";
+
etcdCtlVendorHash = "sha256-PZLsekZzwlGzccCirNk9uUj70Ue5LMDs6LMWBI9yivs=";
src = fetchFromGitHub {
owner = "etcd-io";
repo = "etcd";
rev = "v${version}";
-
hash = "sha256-Z2WXNzFJYfRQCldUspQjUR5NyUzCCINycuEXWaTn4vU=";
+
hash = etcdSrcHash;
};
CGO_ENABLED = 0;
···
description = "Distributed reliable key-value store for the most critical data of a distributed system";
license = licenses.asl20;
homepage = "https://etcd.io/";
-
maintainers = with maintainers; [ offline endocrimes ];
+
maintainers = with maintainers; [ endocrimes offline superherointj ];
platforms = platforms.darwin ++ platforms.linux;
};
···
inherit CGO_ENABLED meta src version;
-
vendorHash = "sha256-S5cEIV4hKRjn9JFEKWBiSEPytHtVacsSnG6T8dofgyk=";
+
vendorHash = etcdServerVendorHash;
modRoot = "./server";
···
inherit CGO_ENABLED meta src version;
-
vendorHash = "sha256-Vgp44Kg6zUDYVJU6SiYd8ZEcAWqKPPTsqYafcfk89Cc=";
+
vendorHash = etcdUtlVendorHash;
modRoot = "./etcdutl";
};
···
inherit CGO_ENABLED meta src version;
-
vendorHash = "sha256-PZLsekZzwlGzccCirNk9uUj70Ue5LMDs6LMWBI9yivs=";
+
vendorHash = etcdCtlVendorHash;
modRoot = "./etcdctl";
};
···
inherit (nixosTests) etcd etcd-cluster;
k3s = k3s.passthru.tests.etcd;
};
+
updateScript = ./update.sh;
};
paths = [
+68
pkgs/servers/etcd/3.5/update.sh
···
+
#!/usr/bin/env nix-shell
+
#!nix-shell -i bash -p curl gnugrep gnused jq nix-prefetch
+
+
set -x -eu -o pipefail
+
+
ETCD_VERSION_MAJOR_MINOR=`basename "$PWD"`
+
+
ETCD_PKG_NAME=etcd_$(echo $ETCD_VERSION_MAJOR_MINOR | sed 's/[.]/_/g')
+
NIXPKGS_PATH="$(git rev-parse --show-toplevel)"
+
ETCD_PATH="$(dirname "$0")"
+
+
OLD_VERSION="$(nix-instantiate --eval -E "with import $NIXPKGS_PATH {}; \
+
$ETCD_PKG_NAME.version or (builtins.parseDrvName $ETCD_PKG_NAME.name).version" | tr -d '"')"
+
+
LATEST_TAG=$(curl ${GITHUB_TOKEN:+" -u \":$GITHUB_TOKEN\""} --silent https://api.github.com/repos/etcd-io/etcd/releases \
+
| jq -r 'map(.tag_name)' | grep $ETCD_VERSION_MAJOR_MINOR | sed 's|[", ]||g' | sort -rV | head -n1)
+
+
LATEST_VERSION=$(echo ${LATEST_TAG} | sed 's/^v//')
+
+
if [ ! "$OLD_VERSION" = "$LATEST_VERSION" ]; then
+
echo "Attempting to update etcd from $OLD_VERSION to $LATEST_VERSION"
+
ETCD_SRC_HASH=$(nix-prefetch-url --quiet --unpack https://github.com/etcd-io/etcd/archive/refs/tags/${LATEST_TAG}.tar.gz)
+
ETCD_SRC_HASH=$(nix hash to-sri --type sha256 $ETCD_SRC_HASH)
+
+
setKV () {
+
sed -i "s|$1 = \".*\"|$1 = \"${2:-}\"|" "$ETCD_PATH/default.nix"
+
}
+
+
setKV version $LATEST_VERSION
+
setKV etcdSrcHash $ETCD_SRC_HASH
+
+
getAndSetVendorHash () {
+
local EMPTY_HASH="sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=" # Hash from lib.fakeHash
+
local VENDOR_HASH=$EMPTY_HASH
+
local PKG_KEY=$1
+
local INNER_PKG=$2
+
+
setKV $PKG_KEY $EMPTY_HASH
+
+
set +e
+
VENDOR_HASH=$(nix-prefetch -I nixpkgs=$NIXPKGS_PATH "{ sha256 }: \
+
(import $NIXPKGS_PATH/. {}).$ETCD_PKG_NAME.passthru.$INNER_PKG.goModules.overrideAttrs (_: { vendorHash = sha256; })")
+
set -e
+
+
if [ -n "${VENDOR_HASH:-}" ]; then
+
setKV $PKG_KEY $VENDOR_HASH
+
else
+
echo "Update failed. $PKG_KEY is empty."
+
exit 1
+
fi
+
}
+
+
getAndSetVendorHash etcdServerVendorHash etcdserver
+
getAndSetVendorHash etcdUtlVendorHash etcdutl
+
getAndSetVendorHash etcdCtlVendorHash etcdctl
+
+
# `git` flag here is to be used by local maintainers to speed up the bump process
+
if [ $# -eq 1 ] && [ "$1" = "git" ]; then
+
git switch -c "package-$ETCD_PKG_NAME-$LATEST_VERSION"
+
git add "$ETCD_PATH"/default.nix
+
git commit -m "$ETCD_PKG_NAME: $OLD_VERSION -> $LATEST_VERSION
+
+
Release: https://github.com/etcd-io/etcd/releases/tag/v$LATEST_VERSION"
+
fi
+
+
else
+
echo "etcd is already up-to-date at $OLD_VERSION"
+
fi
+1 -1
pkgs/top-level/all-packages.nix
···
etcd = etcd_3_5;
etcd_3_4 = callPackage ../servers/etcd/3.4.nix { };
-
etcd_3_5 = callPackage ../servers/etcd/3.5.nix { };
+
etcd_3_5 = callPackage ../servers/etcd/3.5 { };
ejabberd = callPackage ../servers/xmpp/ejabberd { erlang = erlang_24; };