about summary refs log tree commit diff
path: root/pkgs/applications/networking/cluster/rke2/update-script.sh
blob: 608f49bb64903a9148070e1b8f939e33b08ab38f (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#!/usr/bin/env nix-shell
#!nix-shell -i bash -p curl git gnugrep gnused yq-go nix-prefetch

set -x -eu -o pipefail

CHANNEL_NAME="${1:?Must provide a release channel, like 'stable', as the only argument}"

mkdir --parents --verbose ./${CHANNEL_NAME}

LATEST_TAG_NAME=$(curl --silent --fail https://update.rke2.io/v1-release/channels | \
    yq eval ".data[] | select(.id == \"${CHANNEL_NAME}\").latest" - | \
    sort -rV | grep --extended-regexp "^v[0-9]+\.[0-9]+\.[0-9]+" | head -n1)

RKE2_VERSION=$(echo ${LATEST_TAG_NAME} | sed 's/^v//')

RKE2_REPO_SHA256=$(nix-prefetch-url --quiet --unpack \
        https://github.com/rancher/rke2/archive/refs/tags/${LATEST_TAG_NAME}.tar.gz)

RKE2_COMMIT=$(curl --silent --fail ${GITHUB_TOKEN:+-u ":${GITHUB_TOKEN}"} \
        https://api.github.com/repos/rancher/rke2/git/refs/tags | \
    yq eval ".[] | select(.ref == \"refs/tags/${LATEST_TAG_NAME}\").object.sha" -)

VERSIONS_SCRIPT=$(mktemp --suffix ".${RKE2_COMMIT:0:6}.sh")
trap "rm --force ${VERSIONS_SCRIPT}" EXIT

curl --silent --fail --output ${VERSIONS_SCRIPT} \
        https://raw.githubusercontent.com/rancher/rke2/${RKE2_COMMIT}/scripts/version.sh

set +eu
DRONE_TAG=${LATEST_TAG_NAME} source ${VERSIONS_SCRIPT}
set -eu

KUBERNETES_CYCLES=$(echo ${KUBERNETES_VERSION} | grep -Eo "[0-9]+\.[0-9]+")
KUBERNETES_EOL=$(curl --silent --fail \
        https://endoflife.date/api/kubernetes/${KUBERNETES_CYCLES}.json | \
    yq eval ".eol" -)

FAKE_HASH="sha256-AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA=";

cat > ./${CHANNEL_NAME}/versions.nix << EOF
{
  rke2Version = "${RKE2_VERSION}";
  rke2RepoSha256 = "${RKE2_REPO_SHA256}";
  rke2Commit = "${RKE2_COMMIT}";
  rke2VendorHash = "${FAKE_HASH}";
  k8sVersion = "${KUBERNETES_VERSION}";
  k8sImageTag = "${KUBERNETES_IMAGE_TAG}";
  etcdVersion = "${ETCD_VERSION}";
  pauseVersion = "${PAUSE_VERSION}";
  ccmVersion = "${CCM_VERSION}";
  dockerizedVersion = "${DOCKERIZED_VERSION}";
  golangVersion = "${VERSION_GOLANG}";
  eol = "${KUBERNETES_EOL}";
}
EOF

NIXPKGS_ROOT=$(git rev-parse --show-toplevel)

set +e
RKE2_VENDOR_HASH=$(nix-prefetch -I nixpkgs=${NIXPKGS_ROOT} \
        "{ sha256 }: (import ${NIXPKGS_ROOT}/. {}).rke2_${CHANNEL_NAME}.goModules.overrideAttrs (_: { vendorHash = sha256; })")
set -e

if [ -n "${RKE2_VENDOR_HASH:-}" ]; then
    sed -i "s#${FAKE_HASH}#${RKE2_VENDOR_HASH}#g" ./${CHANNEL_NAME}/versions.nix
else
    echo "Update failed. 'RKE2_VENDOR_HASH' is empty."
    exit 1
fi

# Implement commit
# See: https://nixos.org/manual/nixpkgs/stable/#var-passthru-updateScript-commit
OLD_VERSION=$(nix-instantiate --eval -E \
        "with import ${NIXPKGS_ROOT}/. {}; rke2.version or (builtins.parseDrvName rke2.name).version" | \
    tr -d '"')

cat << EOF
[{
  "attrPath": "rke2_${CHANNEL_NAME}",
  "oldVersion": "${OLD_VERSION}",
  "newVersion": "${RKE2_VERSION}",
  "files": [
    "${PWD}/${CHANNEL_NAME}/versions.nix"
  ]
}]
EOF