-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathinstall.sh
More file actions
executable file
·100 lines (83 loc) · 3.61 KB
/
install.sh
File metadata and controls
executable file
·100 lines (83 loc) · 3.61 KB
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
87
88
89
90
91
92
93
94
95
96
97
98
99
100
#!/bin/sh
set -e
REPO="electather/seerr-cli"
BIN="seerr-cli"
INSTALL_DIR="/usr/local/bin"
# ── Detect OS ────────────────────────────────────────────────────────────────
OS=$(uname -s | tr '[:upper:]' '[:lower:]')
case "$OS" in
linux) OS="linux" ;;
darwin) OS="darwin" ;;
*)
echo "Unsupported OS: $OS"
exit 1
;;
esac
# ── Detect architecture ───────────────────────────────────────────────────────
ARCH=$(uname -m)
case "$ARCH" in
x86_64) ARCH="amd64" ;;
aarch64|arm64) ARCH="arm64" ;;
*)
echo "Unsupported architecture: $ARCH"
exit 1
;;
esac
# ── Resolve latest stable release version ────────────────────────────────────
# /releases/latest returns the newest non-prerelease, non-draft release only.
API="https://api.github.com/repos/${REPO}/releases/latest"
if command -v curl > /dev/null 2>&1; then
RESPONSE=$(curl -fsSL "$API")
elif command -v wget > /dev/null 2>&1; then
RESPONSE=$(wget -qO- "$API")
else
echo "curl or wget is required"
exit 1
fi
VERSION=$(echo "$RESPONSE" | grep '"tag_name"' | sed 's/.*"tag_name": *"\([^"]*\)".*/\1/')
if [ -z "$VERSION" ]; then
echo "Failed to fetch latest release version"
exit 1
fi
# GoReleaser strips the leading 'v' from archive filenames
VERSION_BARE="${VERSION#v}"
# ── Download and install ──────────────────────────────────────────────────────
ARCHIVE="${BIN}_${VERSION_BARE}_${OS}_${ARCH}.tar.gz"
URL="https://github.com/${REPO}/releases/download/${VERSION}/${ARCHIVE}"
echo "Installing ${BIN} ${VERSION} (${OS}/${ARCH})..."
TMP=$(mktemp -d)
trap 'rm -rf "$TMP"' EXIT
CHECKSUMS_FILE="${BIN}_${VERSION_BARE}_checksums.txt"
CHECKSUMS_URL="https://github.com/${REPO}/releases/download/${VERSION}/${CHECKSUMS_FILE}"
if command -v curl > /dev/null 2>&1; then
curl -fsSL "$URL" -o "${TMP}/${ARCHIVE}"
curl -fsSL "$CHECKSUMS_URL" -o "${TMP}/${CHECKSUMS_FILE}"
else
wget -qO "${TMP}/${ARCHIVE}" "$URL"
wget -qO "${TMP}/${CHECKSUMS_FILE}" "$CHECKSUMS_URL"
fi
# ── Verify checksum ───────────────────────────────────────────────────────────
echo "Verifying checksum..."
if command -v sha256sum > /dev/null 2>&1; then
(cd "$TMP" && grep "${ARCHIVE}" "${CHECKSUMS_FILE}" | sha256sum -c -)
elif command -v shasum > /dev/null 2>&1; then
(cd "$TMP" && grep "${ARCHIVE}" "${CHECKSUMS_FILE}" | shasum -a 256 -c -)
else
echo "Warning: sha256sum/shasum not found — skipping checksum verification"
fi
tar -xzf "${TMP}/${ARCHIVE}" -C "$TMP"
# ── Place binary ──────────────────────────────────────────────────────────────
if [ -w "$INSTALL_DIR" ]; then
mv "${TMP}/${BIN}" "${INSTALL_DIR}/${BIN}"
elif command -v sudo > /dev/null 2>&1; then
sudo mv "${TMP}/${BIN}" "${INSTALL_DIR}/${BIN}"
else
# Fall back to user-local bin
INSTALL_DIR="$HOME/.local/bin"
mkdir -p "$INSTALL_DIR"
mv "${TMP}/${BIN}" "${INSTALL_DIR}/${BIN}"
echo "Installed to ${INSTALL_DIR}/${BIN}"
echo "Make sure ${INSTALL_DIR} is in your PATH."
fi
chmod +x "${INSTALL_DIR}/${BIN}"
echo "Done. Run: ${BIN} --help"