mirror of
https://github.com/community-scripts/ProxmoxVE.git
synced 2025-11-05 02:42:50 +00:00
Compare commits
10 Commits
2025-10-29
...
core-add-f
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
d59c6ef8af | ||
|
|
e23d650f42 | ||
|
|
b500ec90eb | ||
|
|
851f0dc37c | ||
|
|
da6cff182c | ||
|
|
c8c23ca1cb | ||
|
|
f7ec037a38 | ||
|
|
8896e6c964 | ||
|
|
7c583c7aa0 | ||
|
|
6e3aeab72f |
@@ -12,6 +12,12 @@ Exercise vigilance regarding copycat or coat-tailing sites that seek to exploit
|
|||||||
|
|
||||||
## 2025-10-30
|
## 2025-10-30
|
||||||
|
|
||||||
|
### 🆕 New Scripts
|
||||||
|
|
||||||
|
- Livebook ([#8739](https://github.com/community-scripts/ProxmoxVE/pull/8739))
|
||||||
|
- Reitti ([#8736](https://github.com/community-scripts/ProxmoxVE/pull/8736))
|
||||||
|
- BentoPDF ([#8735](https://github.com/community-scripts/ProxmoxVE/pull/8735))
|
||||||
|
|
||||||
## 2025-10-29
|
## 2025-10-29
|
||||||
|
|
||||||
### 🚀 Updated Scripts
|
### 🚀 Updated Scripts
|
||||||
|
|||||||
62
ct/bentopdf.sh
Normal file
62
ct/bentopdf.sh
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
|
||||||
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
|
# Author: vhsdream
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/alam00000/bentopdf
|
||||||
|
|
||||||
|
APP="BentoPDF"
|
||||||
|
var_tags="${var_tags:-pdf-editor}"
|
||||||
|
var_cpu="${var_cpu:-1}"
|
||||||
|
var_ram="${var_ram:-2048}"
|
||||||
|
var_disk="${var_disk:-4}"
|
||||||
|
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/bentopdf ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
NODE_VERSION="24" setup_nodejs
|
||||||
|
|
||||||
|
if check_for_gh_release "bentopdf" "alam00000/bentopdf"; then
|
||||||
|
msg_info "Stopping Service"
|
||||||
|
systemctl stop bentopdf
|
||||||
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
|
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "bentopdf" "alam00000/bentopdf" "tarball" "latest" "/opt/bentopdf"
|
||||||
|
|
||||||
|
msg_info "Updating BentoPDF"
|
||||||
|
cd /opt/bentopdf
|
||||||
|
$STD npm ci --no-audit --no-fund
|
||||||
|
export SIMPLE_MODE=true
|
||||||
|
$STD npm run build -- --mode production
|
||||||
|
msg_ok "Updated BentoPDF"
|
||||||
|
|
||||||
|
msg_info "Starting Service"
|
||||||
|
systemctl start bentopdf
|
||||||
|
msg_ok "Started Service"
|
||||||
|
msg_ok "Updated Successfully!"
|
||||||
|
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}:8080${CL}"
|
||||||
6
ct/headers/bentopdf
Normal file
6
ct/headers/bentopdf
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
____ __ ____ ____ ______
|
||||||
|
/ __ )___ ____ / /_____ / __ \/ __ \/ ____/
|
||||||
|
/ __ / _ \/ __ \/ __/ __ \/ /_/ / / / / /_
|
||||||
|
/ /_/ / __/ / / / /_/ /_/ / ____/ /_/ / __/
|
||||||
|
/_____/\___/_/ /_/\__/\____/_/ /_____/_/
|
||||||
|
|
||||||
6
ct/headers/livebook
Normal file
6
ct/headers/livebook
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
__ _ __ __
|
||||||
|
/ / (_) _____ / /_ ____ ____ / /__
|
||||||
|
/ / / / | / / _ \/ __ \/ __ \/ __ \/ //_/
|
||||||
|
/ /___/ /| |/ / __/ /_/ / /_/ / /_/ / ,<
|
||||||
|
/_____/_/ |___/\___/_.___/\____/\____/_/|_|
|
||||||
|
|
||||||
6
ct/headers/reitti
Normal file
6
ct/headers/reitti
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
____ _ __ __ _
|
||||||
|
/ __ \___ (_) /_/ /_(_)
|
||||||
|
/ /_/ / _ \/ / __/ __/ /
|
||||||
|
/ _, _/ __/ / /_/ /_/ /
|
||||||
|
/_/ |_|\___/_/\__/\__/_/
|
||||||
|
|
||||||
64
ct/livebook.sh
Executable file
64
ct/livebook.sh
Executable file
@@ -0,0 +1,64 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/refs/heads/main/misc/build.func)
|
||||||
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
|
# Author: dkuku
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/livebook-dev/livebook
|
||||||
|
|
||||||
|
APP="Livebook"
|
||||||
|
var_tags="${var_tags:-development}"
|
||||||
|
var_disk="${var_disk:-4}"
|
||||||
|
var_cpu="${var_cpu:-2}"
|
||||||
|
var_ram="${var_ram:-1024}"
|
||||||
|
var_os="${var_os:-ubuntu}"
|
||||||
|
var_version="${var_version:-24.04}"
|
||||||
|
var_unprivileged="${var_unprivileged:-1}"
|
||||||
|
|
||||||
|
header_info "$APP"
|
||||||
|
variables
|
||||||
|
color
|
||||||
|
catch_errors
|
||||||
|
|
||||||
|
function update_script() {
|
||||||
|
header_info
|
||||||
|
check_container_storage
|
||||||
|
check_container_resources
|
||||||
|
|
||||||
|
if [[ ! -f /opt/livebook/.mix/escripts/livebook ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if check_for_gh_release "livebook" "livebook-dev/livebook"; then
|
||||||
|
msg_info "Stopping Service"
|
||||||
|
systemctl stop livebook
|
||||||
|
msg_info "Stopped Service"
|
||||||
|
|
||||||
|
msg_info "Updating Container"
|
||||||
|
$STD apt update
|
||||||
|
$STD apt upgrade -y
|
||||||
|
msg_ok "Updated Container"
|
||||||
|
|
||||||
|
msg_info "Updating Livebook"
|
||||||
|
source /opt/livebook/.env
|
||||||
|
cd /opt/livebook
|
||||||
|
$STD mix escript.install hex livebook --force
|
||||||
|
|
||||||
|
chown -R livebook:livebook /opt/livebook /data
|
||||||
|
|
||||||
|
msg_info "Starting Service"
|
||||||
|
systemctl start livebook
|
||||||
|
msg_info "Started Service"
|
||||||
|
|
||||||
|
msg_ok "Updated Successfully!"
|
||||||
|
fi
|
||||||
|
exit
|
||||||
|
}
|
||||||
|
|
||||||
|
start
|
||||||
|
build_container
|
||||||
|
description
|
||||||
|
|
||||||
|
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}:8080${CL}"
|
||||||
68
ct/reitti.sh
Normal file
68
ct/reitti.sh
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/misc/build.func)
|
||||||
|
# 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/dedicatedcode/reitti
|
||||||
|
|
||||||
|
APP="Reitti"
|
||||||
|
var_tags="${var_tags:-location-tracker}"
|
||||||
|
var_cpu="${var_cpu:-2}"
|
||||||
|
var_ram="${var_ram:-4096}"
|
||||||
|
var_disk="${var_disk:-15}"
|
||||||
|
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 [[ ! -f /opt/reitti/reitti.jar ]]; then
|
||||||
|
msg_error "No ${APP} Installation Found!"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
if check_for_gh_release "reitti" "dedicatedcode/reitti"; then
|
||||||
|
msg_info "Stopping Service"
|
||||||
|
systemctl stop reitti
|
||||||
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
|
rm -f /opt/reitti/reitti.jar
|
||||||
|
USE_ORIGINAL_FILENAME="true" fetch_and_deploy_gh_release "reitti" "dedicatedcode/reitti" "singlefile" "latest" "/opt/reitti" "reitti-app.jar"
|
||||||
|
mv /opt/reitti/reitti-*.jar /opt/reitti/reitti.jar
|
||||||
|
|
||||||
|
msg_info "Starting Service"
|
||||||
|
systemctl start reitti
|
||||||
|
msg_ok "Started Service"
|
||||||
|
msg_ok "Updated Successfully!"
|
||||||
|
fi
|
||||||
|
if check_for_gh_release "photon" "dedicatedcode/reitti"; then
|
||||||
|
msg_info "Stopping Service"
|
||||||
|
systemctl stop photon
|
||||||
|
msg_ok "Stopped Service"
|
||||||
|
|
||||||
|
rm -f /opt/photon/photon.jar
|
||||||
|
USE_ORIGINAL_FILENAME="true" fetch_and_deploy_gh_release "photon" "komoot/photon" "singlefile" "latest" "/opt/photon" "photon-0*.jar"
|
||||||
|
mv /opt/photon/photon-*.jar /opt/photon/photon.jar
|
||||||
|
|
||||||
|
msg_info "Starting Service"
|
||||||
|
systemctl start photon
|
||||||
|
msg_ok "Started Service"
|
||||||
|
msg_ok "Updated Successfully!"
|
||||||
|
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}:8080${CL}"
|
||||||
35
frontend/public/json/bentopdf.json
Normal file
35
frontend/public/json/bentopdf.json
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
{
|
||||||
|
"name": "BentoPDF",
|
||||||
|
"slug": "bentopdf",
|
||||||
|
"categories": [
|
||||||
|
12
|
||||||
|
],
|
||||||
|
"date_created": "2025-10-30",
|
||||||
|
"type": "ct",
|
||||||
|
"updateable": true,
|
||||||
|
"privileged": false,
|
||||||
|
"interface_port": 8080,
|
||||||
|
"documentation": "https://github.com/alam00000/bentopdf",
|
||||||
|
"website": "https://www.bentopdf.com",
|
||||||
|
"logo": "https://cdn.jsdelivr.net/gh/selfhst/icons/webp/bentopdf.webp",
|
||||||
|
"config_path": "",
|
||||||
|
"description": "A privacy-first, 100% client-side PDF Toolkit. No signups/accounts, works in the browser, online or offline.",
|
||||||
|
"install_methods": [
|
||||||
|
{
|
||||||
|
"type": "default",
|
||||||
|
"script": "ct/bentopdf.sh",
|
||||||
|
"resources": {
|
||||||
|
"cpu": 1,
|
||||||
|
"ram": 2048,
|
||||||
|
"hdd": 4,
|
||||||
|
"os": "debian",
|
||||||
|
"version": "13"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"default_credentials": {
|
||||||
|
"username": null,
|
||||||
|
"password": null
|
||||||
|
},
|
||||||
|
"notes": []
|
||||||
|
}
|
||||||
40
frontend/public/json/livebook.json
Normal file
40
frontend/public/json/livebook.json
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
{
|
||||||
|
"name": "Livebook",
|
||||||
|
"slug": "livebook",
|
||||||
|
"categories": [
|
||||||
|
20
|
||||||
|
],
|
||||||
|
"date_created": "2025-10-30",
|
||||||
|
"type": "ct",
|
||||||
|
"updateable": true,
|
||||||
|
"privileged": false,
|
||||||
|
"interface_port": 8080,
|
||||||
|
"documentation": "https://hexdocs.pm/livebook/readme.html",
|
||||||
|
"config_path": null,
|
||||||
|
"website": "https://livebook.dev",
|
||||||
|
"logo": "https://cdn.jsdelivr.net/gh/selfhst/icons/webp/livebook.webp",
|
||||||
|
"description": "Elixir Livebook is an interactive, web-based notebook platform for Elixir that combines code, documentation, and visualizations in a single document. Similar to Jupyter notebooks, it allows developers to write and execute Elixir code in real-time, making it ideal for data exploration, prototyping, learning, and collaborative development. Livebook features rich markdown support, built-in charting capabilities, and seamless integration with the Elixir ecosystem.",
|
||||||
|
"install_methods": [
|
||||||
|
{
|
||||||
|
"type": "default",
|
||||||
|
"script": "ct/livebook.sh",
|
||||||
|
"resources": {
|
||||||
|
"cpu": 1,
|
||||||
|
"ram": 1024,
|
||||||
|
"hdd": 4,
|
||||||
|
"os": "Ubuntu",
|
||||||
|
"version": "24.04"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"default_credentials": {
|
||||||
|
"username": null,
|
||||||
|
"password": null
|
||||||
|
},
|
||||||
|
"notes": [
|
||||||
|
{
|
||||||
|
"text": "Show initial Livebook password: `cat ~/livebook.creds`",
|
||||||
|
"type": "info"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
40
frontend/public/json/reitti.json
Normal file
40
frontend/public/json/reitti.json
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
{
|
||||||
|
"name": "Reitti",
|
||||||
|
"slug": "reitti",
|
||||||
|
"categories": [
|
||||||
|
21
|
||||||
|
],
|
||||||
|
"date_created": "2025-10-30",
|
||||||
|
"type": "ct",
|
||||||
|
"updateable": true,
|
||||||
|
"privileged": false,
|
||||||
|
"interface_port": 8080,
|
||||||
|
"documentation": "https://www.dedicatedcode.com/projects/reitti/",
|
||||||
|
"config_path": "/opt/reitti/.env",
|
||||||
|
"website": "https://www.dedicatedcode.com/projects/reitti/",
|
||||||
|
"logo": "https://cdn.jsdelivr.net/gh/selfhst/icons/webp/reitti.webp",
|
||||||
|
"description": "Reitti is a self-hosted location tracking and analysis platform that detects significant places, trip patterns, and integrates with OwnTracks, GPSLogger, and Immich. It uses PostgreSQL + PostGIS, RabbitMQ, Redis, and an optional Photon geocoder.",
|
||||||
|
"install_methods": [
|
||||||
|
{
|
||||||
|
"type": "default",
|
||||||
|
"script": "ct/reitti.sh",
|
||||||
|
"resources": {
|
||||||
|
"cpu": 2,
|
||||||
|
"ram": 4096,
|
||||||
|
"hdd": 15,
|
||||||
|
"os": "debian",
|
||||||
|
"version": "13"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"default_credentials": {
|
||||||
|
"username": "admin",
|
||||||
|
"password": "admin"
|
||||||
|
},
|
||||||
|
"notes": [
|
||||||
|
{
|
||||||
|
"text": "Photon Geocoder running at http://127.0.0.1:2322. Photon is fully setup, but without sample data. (filesize is big) -> checkout our guide: `https://github.com/community-scripts/ProxmoxVE/discussions/8737`.",
|
||||||
|
"type": "info"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
53
install/bentopdf-install.sh
Normal file
53
install/bentopdf-install.sh
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
|
# Author: vhsdream
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/alam00000/bentopdf
|
||||||
|
|
||||||
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
||||||
|
color
|
||||||
|
verb_ip6
|
||||||
|
catch_errors
|
||||||
|
setting_up_container
|
||||||
|
network_check
|
||||||
|
update_os
|
||||||
|
|
||||||
|
NODE_VERSION="24" setup_nodejs
|
||||||
|
fetch_and_deploy_gh_release "bentopdf" "alam00000/bentopdf" "tarball" "latest" "/opt/bentopdf"
|
||||||
|
|
||||||
|
msg_info "Setup BentoPDF"
|
||||||
|
cd /opt/bentopdf
|
||||||
|
$STD npm ci --no-audit --no-fund
|
||||||
|
export SIMPLE_MODE=true
|
||||||
|
$STD npm run build -- --mode production
|
||||||
|
msg_ok "Setup BentoPDF"
|
||||||
|
|
||||||
|
msg_info "Creating Service"
|
||||||
|
cat <<EOF >/etc/systemd/system/bentopdf.service
|
||||||
|
[Unit]
|
||||||
|
Description=BentoPDF Service
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
WorkingDirectory=/opt/bentopdf
|
||||||
|
ExecStart=/usr/bin/npx serve dist -p 8080
|
||||||
|
Restart=always
|
||||||
|
RestartSec=10
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
|
||||||
|
systemctl enable -q --now bentopdf
|
||||||
|
msg_ok "Created & started service"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
|
||||||
|
msg_info "Cleaning up"
|
||||||
|
$STD apt -y autoremove
|
||||||
|
$STD apt -y autoclean
|
||||||
|
$STD apt -y clean
|
||||||
|
msg_ok "Cleaned"
|
||||||
106
install/livebook-install.sh
Normal file
106
install/livebook-install.sh
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
|
# Author: dkuku
|
||||||
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
|
# Source: https://github.com/livebook-dev/livebook
|
||||||
|
|
||||||
|
source /dev/stdin <<<"$FUNCTIONS_FILE_PATH"
|
||||||
|
color
|
||||||
|
verb_ip6
|
||||||
|
catch_errors
|
||||||
|
setting_up_container
|
||||||
|
network_check
|
||||||
|
update_os
|
||||||
|
|
||||||
|
msg_info "Installing Dependencies"
|
||||||
|
$STD apt-get install -y \
|
||||||
|
build-essential \
|
||||||
|
ca-certificates \
|
||||||
|
cmake \
|
||||||
|
git \
|
||||||
|
libncurses5-dev
|
||||||
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
|
msg_info "Creating livebook user"
|
||||||
|
mkdir -p /opt/livebook /data
|
||||||
|
export HOME=/opt/livebook
|
||||||
|
$STD adduser --system --group --home /opt/livebook --shell /bin/bash livebook
|
||||||
|
msg_ok "Created livebook user"
|
||||||
|
|
||||||
|
msg_warn "WARNING: This script will run an external installer from a third-party source (https://elixir-lang.org)."
|
||||||
|
msg_warn "The following code is NOT maintained or audited by our repository."
|
||||||
|
msg_warn "If you have any doubts or concerns, please review the installer code before proceeding:"
|
||||||
|
msg_custom "${TAB3}${GATEWAY}${BGN}${CL}" "\e[1;34m" "→ https://elixir-lang.org/install.sh"
|
||||||
|
echo
|
||||||
|
read -r -p "${TAB3}Do you want to continue? [y/N]: " CONFIRM
|
||||||
|
if [[ ! "$CONFIRM" =~ ^([yY][eE][sS]|[yY])$ ]]; then
|
||||||
|
msg_error "Aborted by user. No changes have been made."
|
||||||
|
exit 10
|
||||||
|
fi
|
||||||
|
curl -fsSO https://elixir-lang.org/install.sh
|
||||||
|
$STD sh install.sh elixir@latest otp@latest
|
||||||
|
|
||||||
|
msg_info "Setup Erlang and Elixir"
|
||||||
|
ERLANG_VERSION=$(ls /opt/livebook/.elixir-install/installs/otp/ | head -n1)
|
||||||
|
ELIXIR_VERSION=$(ls /opt/livebook/.elixir-install/installs/elixir/ | head -n1)
|
||||||
|
LIVEBOOK_PASSWORD=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c16)
|
||||||
|
|
||||||
|
export ERLANG_BIN="/opt/livebook/.elixir-install/installs/otp/$ERLANG_VERSION/bin"
|
||||||
|
export ELIXIR_BIN="/opt/livebook/.elixir-install/installs/elixir/$ELIXIR_VERSION/bin"
|
||||||
|
export PATH="$ERLANG_BIN:$ELIXIR_BIN:$PATH"
|
||||||
|
|
||||||
|
$STD mix local.hex --force
|
||||||
|
$STD mix local.rebar --force
|
||||||
|
$STD mix escript.install hex livebook --force
|
||||||
|
|
||||||
|
cat <<EOF >/opt/livebook/.env
|
||||||
|
export HOME=/opt/livebook
|
||||||
|
export ERLANG_VERSION=$ERLANG_VERSION
|
||||||
|
export ELIXIR_VERSION=$ELIXIR_VERSION
|
||||||
|
export LIVEBOOK_PORT=8080
|
||||||
|
export LIVEBOOK_IP="::"
|
||||||
|
export LIVEBOOK_HOME=/data
|
||||||
|
export LIVEBOOK_PASSWORD="$LIVEBOOK_PASSWORD"
|
||||||
|
export ESCRIPTS_BIN=/opt/livebook/.mix/escripts
|
||||||
|
export ERLANG_BIN="/opt/livebook/.elixir-install/installs/otp/\${ERLANG_VERSION}/bin"
|
||||||
|
export ELIXIR_BIN="/opt/livebook/.elixir-install/installs/elixir/\${ELIXIR_VERSION}/bin"
|
||||||
|
export PATH="\$ESCRIPTS_BIN:\$ERLANG_BIN:\$ELIXIR_BIN:\$PATH"
|
||||||
|
EOF
|
||||||
|
{
|
||||||
|
echo "Livebook-Credentials"
|
||||||
|
echo "Livebook Password: $LIVEBOOK_PASSWORD"
|
||||||
|
} >>~/livebook.creds
|
||||||
|
msg_ok "Installed Erlang $ERLANG_VERSION and Elixir $ELIXIR_VERSION"
|
||||||
|
|
||||||
|
msg_info "Installing Livebook"
|
||||||
|
cat <<EOF >/etc/systemd/system/livebook.service
|
||||||
|
[Unit]
|
||||||
|
Description=Livebook
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=exec
|
||||||
|
User=livebook
|
||||||
|
Group=livebook
|
||||||
|
WorkingDirectory=/data
|
||||||
|
EnvironmentFile=-/opt/livebook/.env
|
||||||
|
ExecStart=/bin/bash -c 'source /opt/livebook/.env && cd /opt/livebook && livebook server'
|
||||||
|
Restart=always
|
||||||
|
RestartSec=5
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
chown -R livebook:livebook /opt/livebook /data
|
||||||
|
systemctl enable -q --now livebook
|
||||||
|
msg_ok "Installed Livebook"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
|
||||||
|
msg_info "Cleaning Up"
|
||||||
|
$STD apt autoremove -y
|
||||||
|
$STD apt autoclean -y
|
||||||
|
$STD apt clean -y
|
||||||
|
msg_ok "Cleaned Up"
|
||||||
164
install/reitti-install.sh
Normal file
164
install/reitti-install.sh
Normal file
@@ -0,0 +1,164 @@
|
|||||||
|
#!/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/dedicatedcode/reitti
|
||||||
|
|
||||||
|
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 \
|
||||||
|
rabbitmq-server \
|
||||||
|
libpq-dev \
|
||||||
|
zstd
|
||||||
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
|
JAVA_VERSION="24" setup_java
|
||||||
|
PG_VERSION="17" PG_MODULES="postgis" setup_postgresql
|
||||||
|
|
||||||
|
msg_info "Setting up PostgreSQL"
|
||||||
|
DB_NAME="reitti_db"
|
||||||
|
DB_USER="reitti"
|
||||||
|
DB_PASS="$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)"
|
||||||
|
$STD sudo -u postgres psql -c "CREATE ROLE $DB_USER WITH LOGIN PASSWORD '$DB_PASS';"
|
||||||
|
$STD sudo -u postgres psql -c "CREATE DATABASE $DB_NAME WITH OWNER $DB_USER ENCODING 'UTF8' TEMPLATE template0;"
|
||||||
|
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET client_encoding TO 'utf8';"
|
||||||
|
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET default_transaction_isolation TO 'read committed';"
|
||||||
|
$STD sudo -u postgres psql -c "ALTER ROLE $DB_USER SET timezone TO 'UTC';"
|
||||||
|
$STD sudo -u postgres psql -d "$DB_NAME" -c "CREATE EXTENSION IF NOT EXISTS postgis;"
|
||||||
|
$STD sudo -u postgres psql -d "$DB_NAME" -c "CREATE EXTENSION IF NOT EXISTS postgis_topology;"
|
||||||
|
{
|
||||||
|
echo "Reitti Credentials"
|
||||||
|
echo "Database Name: $DB_NAME"
|
||||||
|
echo "Database User: $DB_USER"
|
||||||
|
echo "Database Password: $DB_PASS"
|
||||||
|
} >>~/reitti.creds
|
||||||
|
msg_ok "PostgreSQL Setup Completed"
|
||||||
|
|
||||||
|
msg_info "Configuring RabbitMQ"
|
||||||
|
RABBIT_USER="reitti"
|
||||||
|
RABBIT_PASS="$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | cut -c1-13)"
|
||||||
|
RABBIT_VHOST="/"
|
||||||
|
$STD rabbitmqctl add_user "$RABBIT_USER" "$RABBIT_PASS"
|
||||||
|
$STD rabbitmqctl add_vhost "$RABBIT_VHOST"
|
||||||
|
$STD rabbitmqctl set_permissions -p "$RABBIT_VHOST" "$RABBIT_USER" ".*" ".*" ".*"
|
||||||
|
$STD rabbitmqctl set_user_tags "$RABBIT_USER" administrator
|
||||||
|
{
|
||||||
|
echo ""
|
||||||
|
echo "Reitti Credentials"
|
||||||
|
echo "RabbitMQ User: $RABBIT_USER"
|
||||||
|
echo "RabbitMQ Password: $RABBIT_PASS"
|
||||||
|
} >>~/reitti.creds
|
||||||
|
msg_ok "Configured RabbitMQ"
|
||||||
|
|
||||||
|
USE_ORIGINAL_FILENAME="true" fetch_and_deploy_gh_release "reitti" "dedicatedcode/reitti" "singlefile" "latest" "/opt/reitti" "reitti-app.jar"
|
||||||
|
mv /opt/reitti/reitti-*.jar /opt/reitti/reitti.jar
|
||||||
|
USE_ORIGINAL_FILENAME="true" fetch_and_deploy_gh_release "photon" "komoot/photon" "singlefile" "latest" "/opt/photon" "photon-0*.jar"
|
||||||
|
mv /opt/photon/photon-*.jar /opt/photon/photon.jar
|
||||||
|
|
||||||
|
msg_info "Creating Reitti Configuration-File"
|
||||||
|
cat <<EOF >/opt/reitti/application.properties
|
||||||
|
# Reitti Server Base URI
|
||||||
|
reitti.server.advertise-uri=http://127.0.0.1:8080
|
||||||
|
|
||||||
|
# PostgreSQL Database Connection
|
||||||
|
spring.datasource.url=jdbc:postgresql://127.0.0.1:5432/$DB_NAME
|
||||||
|
spring.datasource.username=$DB_USER
|
||||||
|
spring.datasource.password=$DB_PASS
|
||||||
|
spring.datasource.driver-class-name=org.postgresql.Driver
|
||||||
|
|
||||||
|
# Flyway Database Migrations
|
||||||
|
spring.flyway.enabled=true
|
||||||
|
spring.flyway.locations=classpath:db/migration
|
||||||
|
spring.flyway.baseline-on-migrate=true
|
||||||
|
|
||||||
|
# RabbitMQ (Message Queue)
|
||||||
|
spring.rabbitmq.host=127.0.0.1
|
||||||
|
spring.rabbitmq.port=5672
|
||||||
|
spring.rabbitmq.username=$RABBIT_USER
|
||||||
|
spring.rabbitmq.password=$RABBIT_PASS
|
||||||
|
|
||||||
|
# Redis (Cache)
|
||||||
|
spring.data.redis.host=127.0.0.1
|
||||||
|
spring.data.redis.port=6379
|
||||||
|
|
||||||
|
# Server Port
|
||||||
|
server.port=8080
|
||||||
|
|
||||||
|
# Optional: Logging & Performance
|
||||||
|
logging.level.root=INFO
|
||||||
|
spring.jpa.hibernate.ddl-auto=none
|
||||||
|
spring.datasource.hikari.maximum-pool-size=10
|
||||||
|
|
||||||
|
# OIDC / Security Settings
|
||||||
|
reitti.security.oidc.registration.enabled=false
|
||||||
|
|
||||||
|
# Photon (Geocoding)
|
||||||
|
PHOTON_BASE_URL=http://127.0.0.1:2322
|
||||||
|
PROCESSING_WAIT_TIME=15
|
||||||
|
PROCESSING_BATCH_SIZE=1000
|
||||||
|
PROCESSING_WORKERS_PER_QUEUE=4-16
|
||||||
|
|
||||||
|
# Disable potentially dangerous features unless needed
|
||||||
|
DANGEROUS_LIFE=false
|
||||||
|
EOF
|
||||||
|
msg_ok "Created Configuration-File for Reitti"
|
||||||
|
|
||||||
|
msg_info "Creating Services"
|
||||||
|
cat <<EOF >/etc/systemd/system/reitti.service
|
||||||
|
[Unit]
|
||||||
|
Description=Reitti
|
||||||
|
After=network.target postgresql.service redis-server.service rabbitmq-server.service photon.service
|
||||||
|
Wants=postgresql.service redis-server.service rabbitmq-server.service photon.service
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
WorkingDirectory=/opt/reitti/
|
||||||
|
ExecStart=/usr/bin/java --enable-native-access=ALL-UNNAMED -jar -Xmx2g reitti.jar
|
||||||
|
TimeoutStopSec=20
|
||||||
|
KillMode=process
|
||||||
|
Restart=on-failure
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
|
||||||
|
cat <<'EOF' >/etc/systemd/system/photon.service
|
||||||
|
[Unit]
|
||||||
|
Description=Photon Geocoding Service (Germany, OpenSearch)
|
||||||
|
After=network.target
|
||||||
|
|
||||||
|
[Service]
|
||||||
|
Type=simple
|
||||||
|
WorkingDirectory=/opt/photon
|
||||||
|
ExecStart=/usr/bin/java -Xmx4g -jar photon.jar \
|
||||||
|
-data-dir /opt/photon \
|
||||||
|
-listen-port 2322 \
|
||||||
|
-listen-ip 0.0.0.0 \
|
||||||
|
-cors-any
|
||||||
|
Restart=on-failure
|
||||||
|
TimeoutStopSec=20
|
||||||
|
|
||||||
|
[Install]
|
||||||
|
WantedBy=multi-user.target
|
||||||
|
EOF
|
||||||
|
systemctl enable -q --now photon
|
||||||
|
systemctl enable -q --now reitti
|
||||||
|
msg_ok "Created Services"
|
||||||
|
|
||||||
|
motd_ssh
|
||||||
|
customize
|
||||||
|
|
||||||
|
msg_info "Cleaning up"
|
||||||
|
$STD apt -y autoremove
|
||||||
|
$STD apt -y autoclean
|
||||||
|
$STD apt -y clean
|
||||||
|
msg_ok "Cleaned"
|
||||||
@@ -368,6 +368,51 @@ run_container_safe() {
|
|||||||
" || __handle_general_error "lxc-attach to CT $ct"
|
" || __handle_general_error "lxc-attach to CT $ct"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cleanup_lxc() {
|
||||||
|
msg_info "Cleaning up"
|
||||||
|
if is_alpine; then
|
||||||
|
$STD apk cache clean || true
|
||||||
|
rm -rf /var/cache/apk/*
|
||||||
|
else
|
||||||
|
$STD apt -y autoremove || true
|
||||||
|
$STD apt -y autoclean || true
|
||||||
|
$STD apt -y clean || true
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -rf /tmp/* /var/tmp/*
|
||||||
|
|
||||||
|
# Remove temp files created by mktemp/tempfile
|
||||||
|
find /tmp /var/tmp -type f -name 'tmp*' -delete 2>/dev/null || true
|
||||||
|
find /tmp /var/tmp -type f -name 'tempfile*' -delete 2>/dev/null || true
|
||||||
|
|
||||||
|
find /var/log -type f -exec truncate -s 0 {} +
|
||||||
|
|
||||||
|
# Python pip
|
||||||
|
if command -v pip &>/dev/null; then pip cache purge || true; fi
|
||||||
|
# Python uv
|
||||||
|
if command -v uv &>/dev/null; then uv cache clear || true; fi
|
||||||
|
# Node.js npm
|
||||||
|
if command -v npm &>/dev/null; then npm cache clean --force || true; fi
|
||||||
|
# Node.js yarn
|
||||||
|
if command -v yarn &>/dev/null; then yarn cache clean || true; fi
|
||||||
|
# Node.js pnpm
|
||||||
|
if command -v pnpm &>/dev/null; then pnpm store prune || true; fi
|
||||||
|
# Go
|
||||||
|
if command -v go &>/dev/null; then go clean -cache -modcache || true; fi
|
||||||
|
# Rust cargo
|
||||||
|
if command -v cargo &>/dev/null; then cargo clean || true; fi
|
||||||
|
# Ruby gem
|
||||||
|
if command -v gem &>/dev/null; then gem cleanup || true; fi
|
||||||
|
# Composer (PHP)
|
||||||
|
if command -v composer &>/dev/null; then composer clear-cache || true; fi
|
||||||
|
|
||||||
|
if command -v journalctl &>/dev/null; then
|
||||||
|
$STD journalctl --rotate
|
||||||
|
$STD journalctl --vacuum-time=10m
|
||||||
|
fi
|
||||||
|
msg_ok "Cleaned"
|
||||||
|
}
|
||||||
|
|
||||||
check_or_create_swap() {
|
check_or_create_swap() {
|
||||||
msg_info "Checking for active swap"
|
msg_info "Checking for active swap"
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user