homarr
This commit is contained in:
parent
b7c10fa2f8
commit
668df09450
97
ct/homarr.sh
Normal file
97
ct/homarr.sh
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func)
|
||||||
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
|
# Author: CrazyWolf13
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://homarr.dev/
|
||||||
|
|
||||||
|
APP="homarr"
|
||||||
|
var_tags="${var_tags:-arr;dashboard}"
|
||||||
|
var_cpu="${var_cpu:-3}"
|
||||||
|
var_ram="${var_ram:-6144}"
|
||||||
|
var_disk="${var_disk:-8}"
|
||||||
|
var_os="${var_os:-debian}"
|
||||||
|
var_version="${var_version:-13}"
|
||||||
|
var_unprivileged="${var_unprivileged:-1}"
|
||||||
|
|
||||||
|
header_info "$APP"
|
||||||
|
|
||||||
|
variables
|
||||||
|
color
|
||||||
|
catch_errors
|
||||||
|
|
||||||
|
function update_script() {
|
||||||
|
header_info
|
||||||
|
check_container_storage
|
||||||
|
check_container_resources
|
||||||
|
if [[ ! -d /opt/homarr ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if check_for_gh_release "homarr" "homarr-labs/homarr"; then
|
||||||
|
msg_info "Stopping Services (Patience)"
|
||||||
|
systemctl stop homarr
|
||||||
|
msg_ok "Services Stopped"
|
||||||
|
|
||||||
|
msg_info "Backup Data"
|
||||||
|
mkdir -p /opt/homarr-data-backup
|
||||||
|
cp /opt/homarr/.env /opt/homarr-data-backup/.env
|
||||||
|
msg_ok "Backup Data"
|
||||||
|
|
||||||
|
msg_info "Updating Nodejs"
|
||||||
|
$STD apt update
|
||||||
|
$STD apt upgrade nodejs -y
|
||||||
|
msg_ok "Updated Nodejs"
|
||||||
|
|
||||||
|
NODE_VERSION=$(curl -s https://raw.githubusercontent.com/homarr-labs/homarr/dev/package.json | jq -r '.engines.node | split(">=")[1] | split(".")[0]')
|
||||||
|
NODE_MODULE="pnpm@$(curl -s https://raw.githubusercontent.com/homarr-labs/homarr/dev/package.json | jq -r '.packageManager | split("@")[1]')"
|
||||||
|
setup_nodejs
|
||||||
|
|
||||||
|
rm -rf /opt/homarr
|
||||||
|
fetch_and_deploy_gh_release "homarr" "homarr-labs/homarr"
|
||||||
|
|
||||||
|
msg_info "Updating and rebuilding ${APP} (Patience)"
|
||||||
|
mv /opt/homarr-data-backup/.env /opt/homarr/.env
|
||||||
|
cd /opt/homarr
|
||||||
|
$STD pnpm install --recursive --frozen-lockfile --shamefully-hoist
|
||||||
|
$STD pnpm build
|
||||||
|
cp /opt/homarr/apps/nextjs/next.config.ts .
|
||||||
|
cp /opt/homarr/apps/nextjs/package.json .
|
||||||
|
cp -r /opt/homarr/packages/db/migrations /opt/homarr_db/migrations
|
||||||
|
cp -r /opt/homarr/apps/nextjs/.next/standalone/* /opt/homarr
|
||||||
|
mkdir -p /appdata/redis
|
||||||
|
cp /opt/homarr/packages/redis/redis.conf /opt/homarr/redis.conf
|
||||||
|
rm /etc/nginx/nginx.conf
|
||||||
|
mkdir -p /etc/nginx/templates
|
||||||
|
cp /opt/homarr/nginx.conf /etc/nginx/templates/nginx.conf
|
||||||
|
|
||||||
|
mkdir -p /opt/homarr/apps/cli
|
||||||
|
cp /opt/homarr/packages/cli/cli.cjs /opt/homarr/apps/cli/cli.cjs
|
||||||
|
echo $'#!/bin/bash\ncd /opt/homarr/apps/cli && node ./cli.cjs "$@"' >/usr/bin/homarr
|
||||||
|
chmod +x /usr/bin/homarr
|
||||||
|
|
||||||
|
mkdir /opt/homarr/build
|
||||||
|
cp ./node_modules/better-sqlite3/build/Release/better_sqlite3.node ./build/better_sqlite3.node
|
||||||
|
msg_ok "Updated ${APP}"
|
||||||
|
|
||||||
|
msg_info "Starting Services"
|
||||||
|
systemctl start homarr
|
||||||
|
msg_ok "Started Services"
|
||||||
|
msg_ok "Updated successfully!"
|
||||||
|
read -p "${TAB3}It's recommended to reboot the LXC after an update, would you like to reboot the LXC now ? (y/n): " choice
|
||||||
|
if [[ "$choice" =~ ^[Yy]$ ]]; then
|
||||||
|
reboot
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
start
|
||||||
|
build_container
|
||||||
|
description
|
||||||
|
|
||||||
|
msg_ok "Completed Successfully!\n"
|
||||||
|
echo -e "${CREATING}${GN}${APP} setup has been successfully initialized!${CL}"
|
||||||
|
echo -e "${INFO}${YW} Access it using the following URL:${CL}"
|
||||||
|
echo -e "${TAB}${GATEWAY}${BGN}http://${IP}:7575${CL}"
|
||||||
112
install/homarr-install.sh
Normal file
112
install/homarr-install.sh
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
|
# Author: MickLesk (Canbiz)
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/homarr-labs/homarr
|
||||||
|
|
||||||
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
||||||
|
color
|
||||||
|
verb_ip6
|
||||||
|
catch_errors
|
||||||
|
setting_up_container
|
||||||
|
network_check
|
||||||
|
update_os
|
||||||
|
|
||||||
|
msg_info "Installing Dependencies"
|
||||||
|
$STD apt install -y \
|
||||||
|
redis-server \
|
||||||
|
ca-certificates \
|
||||||
|
build-essential \
|
||||||
|
nginx \
|
||||||
|
gettext \
|
||||||
|
openssl
|
||||||
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
|
NODE_VERSION=$(curl -s https://raw.githubusercontent.com/homarr-labs/homarr/dev/package.json | jq -r '.engines.node | split(">=")[1] | split(".")[0]')
|
||||||
|
NODE_MODULE="pnpm@$(curl -s https://raw.githubusercontent.com/homarr-labs/homarr/dev/package.json | jq -r '.packageManager | split("@")[1]')"
|
||||||
|
setup_nodejs
|
||||||
|
fetch_and_deploy_gh_release "homarr" "homarr-labs/homarr"
|
||||||
|
|
||||||
|
msg_info "Installing Homarr (Patience)"
|
||||||
|
cd /opt
|
||||||
|
mkdir -p /opt/homarr_db
|
||||||
|
touch /opt/homarr_db/db.sqlite
|
||||||
|
SECRET_ENCRYPTION_KEY="$(openssl rand -hex 32)"
|
||||||
|
cd /opt/homarr
|
||||||
|
cat <<EOF >/opt/homarr/.env
|
||||||
|
DB_DRIVER='better-sqlite3'
|
||||||
|
DB_DIALECT='sqlite'
|
||||||
|
SECRET_ENCRYPTION_KEY='${SECRET_ENCRYPTION_KEY}'
|
||||||
|
DB_URL='/opt/homarr_db/db.sqlite'
|
||||||
|
TURBO_TELEMETRY_DISABLED=1
|
||||||
|
AUTH_PROVIDERS='credentials'
|
||||||
|
NODE_ENV='production'
|
||||||
|
EOF
|
||||||
|
$STD pnpm install --recursive --frozen-lockfile --shamefully-hoist
|
||||||
|
$STD pnpm build
|
||||||
|
msg_ok "Installed Homarr"
|
||||||
|
|
||||||
|
msg_info "Copying build and config files"
|
||||||
|
cp /opt/homarr/apps/nextjs/next.config.ts .
|
||||||
|
cp /opt/homarr/apps/nextjs/package.json .
|
||||||
|
cp -r /opt/homarr/packages/db/migrations /opt/homarr_db/migrations
|
||||||
|
cp -r /opt/homarr/apps/nextjs/.next/standalone/* /opt/homarr
|
||||||
|
mkdir -p /appdata/redis
|
||||||
|
cp /opt/homarr/packages/redis/redis.conf /opt/homarr/redis.conf
|
||||||
|
mkdir -p /etc/nginx/templates
|
||||||
|
rm /etc/nginx/nginx.conf
|
||||||
|
cp /opt/homarr/nginx.conf /etc/nginx/templates/nginx.conf
|
||||||
|
mkdir -p /opt/homarr/apps/cli
|
||||||
|
cp /opt/homarr/packages/cli/cli.cjs /opt/homarr/apps/cli/cli.cjs
|
||||||
|
echo $'#!/bin/bash\ncd /opt/homarr/apps/cli && node ./cli.cjs "$@"' >/usr/bin/homarr
|
||||||
|
chmod +x /usr/bin/homarr
|
||||||
|
mkdir /opt/homarr/build
|
||||||
|
cp ./node_modules/better-sqlite3/build/Release/better_sqlite3.node ./build/better_sqlite3.node
|
||||||
|
msg_ok "Finished copying"
|
||||||
|
|
||||||
|
msg_info "Creating Services"
|
||||||
|
cat <<'EOF' >/opt/run_homarr.sh
|
||||||
|
#!/bin/bash
|
||||||
|
set -a
|
||||||
|
source /opt/homarr/.env
|
||||||
|
set +a
|
||||||
|
export DB_DIALECT='sqlite'
|
||||||
|
export AUTH_SECRET=$(openssl rand -base64 32)
|
||||||
|
export CRON_JOB_API_KEY=$(openssl rand -base64 32)
|
||||||
|
node /opt/homarr_db/migrations/$DB_DIALECT/migrate.cjs /opt/homarr_db/migrations/$DB_DIALECT
|
||||||
|
for dir in $(find /opt/homarr_db/migrations/migrations -mindepth 1 -maxdepth 1 -type d); do
|
||||||
|
dirname=$(basename "$dir")
|
||||||
|
mkdir -p "/opt/homarr_db/migrations/$dirname"
|
||||||
|
cp -r "$dir"/* "/opt/homarr_db/migrations/$dirname/" 2>/dev/null || true
|
||||||
|
done
|
||||||
|
export HOSTNAME=$(ip route get 1.1.1.1 | grep -oP 'src \K[^ ]+')
|
||||||
|
envsubst '${HOSTNAME}' < /etc/nginx/templates/nginx.conf > /etc/nginx/nginx.conf
|
||||||
|
nginx -g 'daemon off;' &
|
||||||
|
redis-server /opt/homarr/packages/redis/redis.conf &
|
||||||
|
node apps/tasks/tasks.cjs &
|
||||||
|
node apps/websocket/wssServer.cjs &
|
||||||
|
node apps/nextjs/server.js & PID=$!
|
||||||
|
wait $PID
|
||||||
|
EOF
|
||||||
|
chmod +x /opt/run_homarr.sh
|
||||||
|
cat <<EOF >/etc/systemd/system/homarr.service
|
||||||
|
[Unit]
|
||||||
|
Description=Homarr Service
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=exec
|
||||||
|
WorkingDirectory=/opt/homarr
|
||||||
|
EnvironmentFile=-/opt/homarr/.env
|
||||||
|
ExecStart=/opt/run_homarr.sh
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
systemctl enable -q --now homarr
|
||||||
|
msg_ok "Created Service"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
cleanup_lxc
|
||||||
@ -70,25 +70,23 @@ if [[ -d "$INSTALL_PATH" ]]; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
echo -e "${YW}⚠️ pihole-exporter is not installed.${CL}"
|
echo -e "${YW}⚠️ pihole-exporter is not installed.${CL}"
|
||||||
echo -e "${YW}⚠️ Please provide the following information to connect to your Pi-Hole instance.${CL}"
|
echo -n "Enter the hostname of Pihole, example: (127.0.0.1): ${CL}"
|
||||||
echo -e "${YW}⚠️ It's possibly to add multiple Pi-Hole instances, by using a comma-separated list on all parameter, example: 127.0.0.1,192.168.1.100${CL}"
|
|
||||||
echo -n "Enter the hostname of Pihole, example: (127.0.0.1): "
|
|
||||||
read -er pihole_HOSTNAME
|
read -er pihole_HOSTNAME
|
||||||
|
|
||||||
echo -n "Enter the port of Pihole, default 443: "
|
echo -n "Enter the port of Pihole, default 443: ${CL}"
|
||||||
read -er pihole_PORT
|
read -er pihole_PORT
|
||||||
|
|
||||||
echo -n "Enter Pihole password: "
|
echo -n "Enter Pihole password: ${CL}"
|
||||||
read -rs pihole_PASSWORD
|
read -rs pihole_PASSWORD
|
||||||
echo
|
echo
|
||||||
|
|
||||||
echo -n "Do you want to skip TLS-Verification (if using a self-signed Certificate on Pi-Hole) [y/N]: "
|
echo -n "Do you want to skip TLS-Verification (if using a self-signed Certificate on Pi-Hole) [y/N]: ${CL}"
|
||||||
read -er SKIP_TLS
|
read -er SKIP_TLS
|
||||||
if [[ "${SKIP_TLS,,}" =~ ^(y|yes)$ ]]; then
|
if [[ "${SKIP_TLS,,}" =~ ^(y|yes)$ ]]; then
|
||||||
pihole_SKIP_TLS="true"
|
pihole_SKIP_TLS="true"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo -n "Install qbittorrent-exporter? (y/n): "
|
echo -n "Install qbittorrent-exporter? (y/n): ${CL}"
|
||||||
read -r install_prompt
|
read -r install_prompt
|
||||||
if ! [[ "${install_prompt,,}" =~ ^(y|yes)$ ]]; then
|
if ! [[ "${install_prompt,,}" =~ ^(y|yes)$ ]]; then
|
||||||
echo -e "${YW}⚠️ Installation skipped. Exiting.${CL}"
|
echo -e "${YW}⚠️ Installation skipped. Exiting.${CL}"
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user