2022-03-30 09:31:56 +00:00
|
|
|
#!/usr/bin/env nix-shell
|
2023-08-22 20:05:09 +00:00
|
|
|
#!nix-shell -i bash -p curl crystal crystal2nix jq git moreutils nix nix-prefetch pkg-config pcre
|
2022-03-30 09:31:56 +00:00
|
|
|
git_url='https://github.com/iv-org/invidious.git'
|
|
|
|
git_branch='master'
|
|
|
|
git_dir='/var/tmp/invidious.git'
|
|
|
|
pkg='invidious'
|
|
|
|
|
|
|
|
set -euo pipefail
|
|
|
|
|
|
|
|
cd "$(dirname "${BASH_SOURCE[0]}")"
|
|
|
|
|
|
|
|
info() {
|
|
|
|
if [ -t 2 ]; then
|
|
|
|
set -- '\033[32m%s\033[39m\n' "$@"
|
|
|
|
else
|
|
|
|
set -- '%s\n' "$@"
|
|
|
|
fi
|
|
|
|
printf "$@" >&2
|
|
|
|
}
|
|
|
|
|
|
|
|
json_get() {
|
|
|
|
jq -r "$1" < 'versions.json'
|
|
|
|
}
|
|
|
|
|
|
|
|
json_set() {
|
|
|
|
jq --arg x "$2" "$1 = \$x" < 'versions.json' | sponge 'versions.json'
|
|
|
|
}
|
|
|
|
|
|
|
|
old_rev=$(json_get '.invidious.rev')
|
|
|
|
old_version=$(json_get '.invidious.version')
|
|
|
|
today=$(LANG=C date -u +'%Y-%m-%d')
|
|
|
|
|
|
|
|
info "fetching $git_url..."
|
|
|
|
if [ ! -d "$git_dir" ]; then
|
|
|
|
git init --initial-branch="$git_branch" "$git_dir"
|
|
|
|
git -C "$git_dir" remote add origin "$git_url"
|
|
|
|
fi
|
|
|
|
git -C "$git_dir" fetch origin "$git_branch"
|
|
|
|
|
|
|
|
# use latest commit before today, we should not call the version *today*
|
|
|
|
# because there might still be commits coming
|
|
|
|
# use the day of the latest commit we picked as version
|
|
|
|
new_rev=$(git -C "$git_dir" log -n 1 --format='format:%H' --before="${today}T00:00:00Z" "origin/$git_branch")
|
2022-05-18 14:49:53 +00:00
|
|
|
new_version="unstable-$(TZ=UTC git -C "$git_dir" log -n 1 --date='format-local:%Y-%m-%d' --format='%cd' "$new_rev")"
|
2022-03-30 09:31:56 +00:00
|
|
|
info "latest commit before $today: $new_rev"
|
|
|
|
|
|
|
|
if [ "$new_rev" = "$old_rev" ]; then
|
|
|
|
info "$pkg is up-to-date."
|
|
|
|
exit
|
|
|
|
fi
|
|
|
|
|
|
|
|
json_set '.invidious.version' "$new_version"
|
|
|
|
json_set '.invidious.rev' "$new_rev"
|
|
|
|
new_sha256=$(nix-prefetch -I 'nixpkgs=../../..' "$pkg")
|
|
|
|
json_set '.invidious.sha256' "$new_sha256"
|
|
|
|
commit_msg="$pkg: $old_version -> $new_version"
|
|
|
|
|
|
|
|
# fetch video.js dependencies
|
|
|
|
info "Running scripts/fetch-player-dependencies.cr..."
|
|
|
|
git -C "$git_dir" reset --hard "$new_rev"
|
|
|
|
(cd "$git_dir" && crystal run scripts/fetch-player-dependencies.cr -- --minified)
|
|
|
|
rm -f "$git_dir/assets/videojs/.gitignore"
|
2022-07-14 12:49:19 +00:00
|
|
|
videojs_new_sha256=$(nix-hash --type sha256 --base32 "$git_dir/assets/videojs")
|
2022-03-30 09:31:56 +00:00
|
|
|
json_set '.videojs.sha256' "$videojs_new_sha256"
|
|
|
|
|
|
|
|
if git -C "$git_dir" diff-tree --quiet "${old_rev}..${new_rev}" -- 'shard.lock'; then
|
|
|
|
info "shard.lock did not change since $old_rev."
|
|
|
|
else
|
|
|
|
info "Updating shards.nix..."
|
|
|
|
crystal2nix -- "$git_dir/shard.lock" # argv's index seems broken
|
|
|
|
|
|
|
|
lsquic_old_version=$(json_get '.lsquic.version')
|
|
|
|
# lsquic.cr's version tracks lsquic's, so lsquic must be updated to the
|
|
|
|
# version in the shards file
|
|
|
|
lsquic_new_version=$(nix eval --raw -f 'shards.nix' lsquic.rev \
|
|
|
|
| sed -e 's/^v//' -e 's/-[0-9]*$//')
|
|
|
|
if [ "$lsquic_old_version" != "$lsquic_new_version" ]; then
|
|
|
|
info "Updating lsquic to $lsquic_new_version..."
|
|
|
|
json_set '.lsquic.version' "$lsquic_new_version"
|
|
|
|
lsquic_new_sha256=$(nix-prefetch -I 'nixpkgs=../../..' "${pkg}.lsquic")
|
|
|
|
json_set '.lsquic.sha256' "$lsquic_new_sha256"
|
|
|
|
|
|
|
|
info "Updating boringssl..."
|
|
|
|
# lsquic specifies the boringssl commit it requires in its README
|
|
|
|
boringssl_new_rev=$(curl -LSsf "https://github.com/litespeedtech/lsquic/raw/v${lsquic_new_version}/README.md" \
|
|
|
|
| grep -Pom1 '(?<=^git checkout ).*')
|
|
|
|
json_set '.boringssl.rev' "$boringssl_new_rev"
|
|
|
|
boringssl_new_sha256=$(nix-prefetch -I 'nixpkgs=../../..' "${pkg}.lsquic.boringssl")
|
|
|
|
json_set '.boringssl.sha256' "$boringssl_new_sha256"
|
|
|
|
commit_msg="$commit_msg
|
|
|
|
|
|
|
|
lsquic: $lsquic_old_version -> $lsquic_new_version"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
|
|
|
|
git commit --verbose --message "$commit_msg" -- versions.json shards.nix
|