115 lines
4.7 KiB
Bash
115 lines
4.7 KiB
Bash
#!/usr/bin/env bash
|
|
source <(curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVED/main/misc/build.func)
|
|
# Copyright (c) 2021-2026 community-scripts ORG
|
|
# Author: ProxmoxVED Community
|
|
# License: MIT | https://github.com/community-scripts/ProxmoxVED/raw/main/LICENSE
|
|
# Source: https://aliasvault.net
|
|
|
|
APP="AliasVault"
|
|
var_tags="${var_tags:-security;passwords;privacy}"
|
|
var_cpu="${var_cpu:-4}"
|
|
var_ram="${var_ram:-6144}"
|
|
var_disk="${var_disk:-30}"
|
|
var_os="${var_os:-debian}"
|
|
var_version="${var_version:-12}"
|
|
var_arm64="${var_arm64:-no}"
|
|
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/aliasvault/.env ]]; then
|
|
msg_error "No ${APP} Installation Found!"
|
|
exit
|
|
fi
|
|
|
|
if check_for_gh_release "aliasvault" "aliasvault/aliasvault"; then
|
|
RELEASE=$(get_latest_github_release "aliasvault/aliasvault")
|
|
|
|
msg_info "Stopping Services"
|
|
systemctl stop aliasvault-api aliasvault-admin aliasvault-smtp aliasvault-taskrunner
|
|
msg_ok "Stopped Services"
|
|
|
|
msg_info "Backing up Configuration"
|
|
cp /opt/aliasvault/.env /opt/aliasvault_env.bak
|
|
cp -r /opt/aliasvault/certificates /opt/aliasvault_certs.bak
|
|
msg_ok "Backed up Configuration"
|
|
|
|
CLEAN_INSTALL=1 fetch_and_deploy_gh_release "aliasvault" "aliasvault/aliasvault" "tarball"
|
|
|
|
msg_info "Building Core Libraries (Patience)"
|
|
source "$HOME/.cargo/env"
|
|
$STD rustup target add wasm32-unknown-unknown
|
|
cd /opt/aliasvault/core
|
|
$STD bash build-and-distribute.sh --browser
|
|
msg_ok "Built Core Libraries"
|
|
|
|
msg_info "Copying Core Artifacts"
|
|
mkdir -p /opt/aliasvault/apps/server/AliasVault.Client/wwwroot/wasm
|
|
cp /opt/aliasvault/core/rust/dist/wasm/aliasvault_core_bg.wasm \
|
|
/opt/aliasvault/apps/server/AliasVault.Client/wwwroot/wasm/
|
|
cp /opt/aliasvault/core/rust/dist/wasm/aliasvault_core.js \
|
|
/opt/aliasvault/apps/server/AliasVault.Client/wwwroot/wasm/
|
|
mkdir -p /opt/aliasvault/apps/server/AliasVault.Client/wwwroot/js/dist/core/{identity-generator,password-generator,vault}
|
|
cp -r /opt/aliasvault/core/typescript/identity-generator/dist/. \
|
|
/opt/aliasvault/apps/server/AliasVault.Client/wwwroot/js/dist/core/identity-generator/
|
|
cp -r /opt/aliasvault/core/typescript/password-generator/dist/. \
|
|
/opt/aliasvault/apps/server/AliasVault.Client/wwwroot/js/dist/core/password-generator/
|
|
cp -r /opt/aliasvault/core/vault/dist/. \
|
|
/opt/aliasvault/apps/server/AliasVault.Client/wwwroot/js/dist/core/vault/
|
|
msg_ok "Copied Core Artifacts"
|
|
|
|
msg_info "Building AliasVault Applications (Patience)"
|
|
cd /opt/aliasvault/apps/server
|
|
$STD dotnet workload install wasm-tools
|
|
$STD dotnet restore aliasvault.sln
|
|
$STD dotnet publish AliasVault.Api/AliasVault.Api.csproj -c Release -o /opt/aliasvault/api --no-restore
|
|
$STD dotnet build AliasVault.Client/AliasVault.Client.csproj -c Release --no-restore
|
|
$STD dotnet publish AliasVault.Client/AliasVault.Client.csproj -c Release -o /opt/aliasvault/client --no-restore
|
|
python3 -c "
|
|
import json, pathlib
|
|
p = pathlib.Path('/opt/aliasvault/client/wwwroot/appsettings.json')
|
|
c = json.loads(p.read_text()); c['ApiUrl'] = ''; p.write_text(json.dumps(c, indent=2))
|
|
for ext in ['.gz', '.br']:
|
|
q = pathlib.Path(str(p) + ext)
|
|
if q.exists(): q.unlink()
|
|
"
|
|
mkdir -p /opt/certificates/app
|
|
$STD dotnet publish AliasVault.Admin/AliasVault.Admin.csproj -c Release -o /opt/aliasvault/admin --no-restore
|
|
$STD dotnet publish Services/AliasVault.SmtpService/AliasVault.SmtpService.csproj -c Release -o /opt/aliasvault/smtp --no-restore
|
|
$STD dotnet publish Services/AliasVault.TaskRunner/AliasVault.TaskRunner.csproj -c Release -o /opt/aliasvault/taskrunner --no-restore
|
|
msg_ok "Built AliasVault Applications"
|
|
|
|
msg_info "Restoring Configuration"
|
|
cp /opt/aliasvault_env.bak /opt/aliasvault/.env
|
|
cp -r /opt/aliasvault_certs.bak/. /opt/aliasvault/certificates/
|
|
rm -f /opt/aliasvault_env.bak
|
|
rm -rf /opt/aliasvault_certs.bak
|
|
msg_ok "Restored Configuration"
|
|
|
|
msg_info "Starting Services"
|
|
systemctl start aliasvault-api aliasvault-admin aliasvault-smtp aliasvault-taskrunner
|
|
msg_ok "Started Services"
|
|
msg_ok "Updated successfully to ${RELEASE}!"
|
|
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}https://${IP}${CL}"
|
|
echo -e "${INFO}${YW} Admin Panel:${CL} ${TAB}${GATEWAY}${BGN}https://${IP}/admin${CL}"
|
|
echo -e "${INFO}${YW} Admin credentials were shown in the installation output above.${CL}"
|