run as livebook user
This commit is contained in:
parent
d1c5ac135f
commit
dd3fccdc76
@ -1,11 +1,11 @@
|
|||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/refs/heads/main/misc/build.func)
|
# source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/refs/heads/main/misc/build.func)
|
||||||
|
source <(curl -fsSL https://raw.githubusercontent.com/dkuku/ProxmoxVED/refs/heads/livebook/misc/build.func)
|
||||||
# Copyright (c) 2021-2025 community-scripts ORG
|
# Copyright (c) 2021-2025 community-scripts ORG
|
||||||
# Author: dkuku
|
# Author: dkuku
|
||||||
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
# License: MIT | https://github.com/community-scripts/ProxmoxVE/raw/main/LICENSE
|
||||||
# Source: https://github.com/livebook-dev/livebook
|
# Source: https://github.com/livebook-dev/livebook
|
||||||
|
|
||||||
echo -e "Loading..."
|
|
||||||
APP="Livebook"
|
APP="Livebook"
|
||||||
var_tags="${var_tags:-development}"
|
var_tags="${var_tags:-development}"
|
||||||
var_disk="${var_disk:-4}"
|
var_disk="${var_disk:-4}"
|
||||||
@ -33,11 +33,6 @@ function update_script() {
|
|||||||
msg_info "Checking for updates..."
|
msg_info "Checking for updates..."
|
||||||
RELEASE=$(curl -fsSL https://api.github.com/repos/livebook-dev/livebook/releases/latest | grep "tag_name" | awk -F'"' '{print $4}')
|
RELEASE=$(curl -fsSL https://api.github.com/repos/livebook-dev/livebook/releases/latest | grep "tag_name" | awk -F'"' '{print $4}')
|
||||||
|
|
||||||
if [[ -z "$RELEASE" ]]; then
|
|
||||||
msg_error "Failed to fetch latest version information"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt 2>/dev/null)" ]]; then
|
if [[ "${RELEASE}" != "$(cat /opt/${APP}_version.txt 2>/dev/null)" ]]; then
|
||||||
msg_info "Updating ${APP} LXC"
|
msg_info "Updating ${APP} LXC"
|
||||||
$STD apt-get update
|
$STD apt-get update
|
||||||
@ -47,10 +42,10 @@ function update_script() {
|
|||||||
msg_info "Updating ${APP} to ${RELEASE}"
|
msg_info "Updating ${APP} to ${RELEASE}"
|
||||||
source /opt/.env
|
source /opt/.env
|
||||||
cd /opt || exit 1
|
cd /opt || exit 1
|
||||||
rm /opt/.mix/escripts/livebook
|
|
||||||
mix escript.install hex livebook --force
|
mix escript.install hex livebook --force
|
||||||
|
|
||||||
echo "$RELEASE" | $STD tee /opt/${APP}_version.txt >/dev/null
|
echo "$RELEASE" | $STD tee /opt/${APP}_version.txt >/dev/null
|
||||||
|
chown -R livebook:livebook /opt /data
|
||||||
|
|
||||||
msg_ok "Successfully updated to ${RELEASE}"
|
msg_ok "Successfully updated to ${RELEASE}"
|
||||||
else
|
else
|
||||||
|
@ -23,6 +23,10 @@ $STD apt-get install -y \
|
|||||||
curl
|
curl
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
|
msg_info "Creating livebook user"
|
||||||
|
adduser --system --group --home /opt --shell /bin/bash livebook
|
||||||
|
msg_ok "Created livebook user"
|
||||||
|
|
||||||
msg_info "Installing Erlang and Elixir"
|
msg_info "Installing Erlang and Elixir"
|
||||||
|
|
||||||
mkdir -p /opt /data
|
mkdir -p /opt /data
|
||||||
@ -33,13 +37,9 @@ curl -fsSO https://elixir-lang.org/install.sh
|
|||||||
$STD sh install.sh elixir@latest otp@latest
|
$STD sh install.sh elixir@latest otp@latest
|
||||||
RELEASE=$(curl -fsSL https://api.github.com/repos/livebook-dev/livebook/releases/latest | grep "tag_name" | awk -F'"' '{print $4}')
|
RELEASE=$(curl -fsSL https://api.github.com/repos/livebook-dev/livebook/releases/latest | grep "tag_name" | awk -F'"' '{print $4}')
|
||||||
|
|
||||||
# Get the actual installed versions from directory names
|
|
||||||
ERLANG_VERSION=$(ls /opt/.elixir-install/installs/otp/ | head -n1)
|
ERLANG_VERSION=$(ls /opt/.elixir-install/installs/otp/ | head -n1)
|
||||||
ELIXIR_VERSION=$(ls /opt/.elixir-install/installs/elixir/ | head -n1)
|
ELIXIR_VERSION=$(ls /opt/.elixir-install/installs/elixir/ | head -n1)
|
||||||
|
|
||||||
# TODO remove
|
|
||||||
echo "Found Erlang version: $ERLANG_VERSION"
|
|
||||||
echo "Found Elixir version: $ELIXIR_VERSION"
|
|
||||||
export ERLANG_BIN="/opt/.elixir-install/installs/otp/$ERLANG_VERSION/bin"
|
export ERLANG_BIN="/opt/.elixir-install/installs/otp/$ERLANG_VERSION/bin"
|
||||||
export ELIXIR_BIN="/opt/.elixir-install/installs/elixir/$ELIXIR_VERSION/bin"
|
export ELIXIR_BIN="/opt/.elixir-install/installs/elixir/$ELIXIR_VERSION/bin"
|
||||||
export PATH="$ERLANG_BIN:$ELIXIR_BIN:$PATH"
|
export PATH="$ERLANG_BIN:$ELIXIR_BIN:$PATH"
|
||||||
@ -48,7 +48,13 @@ $STD mix local.hex --force
|
|||||||
$STD mix local.rebar --force
|
$STD mix local.rebar --force
|
||||||
$STD mix escript.install hex livebook --force
|
$STD mix escript.install hex livebook --force
|
||||||
|
|
||||||
# Create .env file with all environment variables
|
LIVEBOOK_PASSWORD=$(openssl rand -base64 18 | tr -dc 'a-zA-Z0-9' | head -c16)
|
||||||
|
|
||||||
|
cat <<EOF > /opt/livebook.creds
|
||||||
|
Livebook-Credentials
|
||||||
|
Livebook Password: $LIVEBOOK_PASSWORD
|
||||||
|
EOF
|
||||||
|
|
||||||
cat <<EOF > /opt/.env
|
cat <<EOF > /opt/.env
|
||||||
export HOME=/opt
|
export HOME=/opt
|
||||||
export LIVEBOOK_VERSION=$RELEASE
|
export LIVEBOOK_VERSION=$RELEASE
|
||||||
@ -57,7 +63,7 @@ export ELIXIR_VERSION=$ELIXIR_VERSION
|
|||||||
export LIVEBOOK_PORT=8080
|
export LIVEBOOK_PORT=8080
|
||||||
export LIVEBOOK_IP="::"
|
export LIVEBOOK_IP="::"
|
||||||
export LIVEBOOK_HOME=/data
|
export LIVEBOOK_HOME=/data
|
||||||
export LIVEBOOK_TOKEN_ENABLED=false
|
export LIVEBOOK_PASSWORD="$LIVEBOOK_PASSWORD"
|
||||||
export ESCRIPTS_BIN=/opt/.mix/escripts
|
export ESCRIPTS_BIN=/opt/.mix/escripts
|
||||||
export ERLANG_BIN="/opt/.elixir-install/installs/otp/\${ERLANG_VERSION}/bin"
|
export ERLANG_BIN="/opt/.elixir-install/installs/otp/\${ERLANG_VERSION}/bin"
|
||||||
export ELIXIR_BIN="/opt/.elixir-install/installs/elixir/\${ELIXIR_VERSION}/bin"
|
export ELIXIR_BIN="/opt/.elixir-install/installs/elixir/\${ELIXIR_VERSION}/bin"
|
||||||
@ -74,8 +80,8 @@ After=network.target
|
|||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
Type=exec
|
Type=exec
|
||||||
User=root
|
User=livebook
|
||||||
Group=root
|
Group=livebook
|
||||||
WorkingDirectory=/data
|
WorkingDirectory=/data
|
||||||
EnvironmentFile=-/opt/.env
|
EnvironmentFile=-/opt/.env
|
||||||
ExecStart=/bin/bash -c 'source /opt/.env && cd /opt && livebook server'
|
ExecStart=/bin/bash -c 'source /opt/.env && cd /opt && livebook server'
|
||||||
@ -86,6 +92,10 @@ RestartSec=5
|
|||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
msg_info "Setting ownership and permissions"
|
||||||
|
chown -R livebook:livebook /opt /data
|
||||||
|
msg_ok "Set ownership and permissions"
|
||||||
|
|
||||||
systemctl enable -q --now livebook
|
systemctl enable -q --now livebook
|
||||||
msg_ok "Installed Livebook"
|
msg_ok "Installed Livebook"
|
||||||
|
|
||||||
|
@ -1438,7 +1438,8 @@ EOF'
|
|||||||
fi
|
fi
|
||||||
msg_ok "Customized LXC Container"
|
msg_ok "Customized LXC Container"
|
||||||
|
|
||||||
lxc-attach -n "$CTID" -- bash -c "$(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/install/${var_install}.sh)"
|
lxc-attach -n "$CTID" -- bash -c "$(curl -fsSL https://raw.githubusercontent.com/dkuku/ProxmoxVED/refs/heads/livebook/install/${var_install}.sh)"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
destroy_lxc() {
|
destroy_lxc() {
|
||||||
|
@ -196,7 +196,7 @@ EOF
|
|||||||
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
systemctl restart $(basename $(dirname $GETTY_OVERRIDE) | sed 's/\.d//')
|
||||||
msg_ok "Customized Container"
|
msg_ok "Customized Container"
|
||||||
fi
|
fi
|
||||||
echo "bash -c \"\$(curl -fsSL https://github.com/community-scripts/ProxmoxVED/raw/main/ct/${app}.sh)\"" >/usr/bin/update
|
echo "bash -c \"\$(curl -fsSL https://github.com/dkuku/ProxmoxVED/refs/heads/livebook/ct/${app}.sh)\"" >/usr/bin/update
|
||||||
chmod +x /usr/bin/update
|
chmod +x /usr/bin/update
|
||||||
if [[ -n "${SSH_AUTHORIZED_KEY}" ]]; then
|
if [[ -n "${SSH_AUTHORIZED_KEY}" ]]; then
|
||||||
mkdir -p /root/.ssh
|
mkdir -p /root/.ssh
|
||||||
|
Loading…
x
Reference in New Issue
Block a user