|
|
|
@ -87,6 +87,7 @@ msg_ok "Set up Redis" |
|
|
|
|
#-- END REDIS CACHE |
|
|
|
|
|
|
|
|
|
# GHOSTFOLIO ================================= |
|
|
|
|
msg_info "Set up Ghostfolio" |
|
|
|
|
## Setup Vars |
|
|
|
|
## default node to 20 (current required version, but determine from nvmrc later) |
|
|
|
|
NODE_VERSION=20 |
|
|
|
@ -112,6 +113,10 @@ $STD rm ghostfolio-$GHOSTFOLIO_VERSION.tgz |
|
|
|
|
|
|
|
|
|
cd /opt/ghostfolio-$GHOSTFOLIO_VERSION |
|
|
|
|
|
|
|
|
|
# Stash these so we have clean versions later |
|
|
|
|
cp /opt/ghostfolio-$GHOSTFOLIO_VERSION/package.json /opt/ghostfolio-$GHOSTFOLIO_VERSION/package.json.bak |
|
|
|
|
cp /opt/ghostfolio-$GHOSTFOLIO_VERSION/package-lock.json /opt/ghostfolio-$GHOSTFOLIO_VERSION/package-lock.json.bak |
|
|
|
|
|
|
|
|
|
# Get node version and install node |
|
|
|
|
test -f .nvmrc && NODE_VERSION=$(sed 's/^v\([0-9]*\)[.]*.*/\1/g' .nvmrc) # get first digits after an v, excluding potential .minor.patch versions |
|
|
|
|
$STD curl -fsSL https://deb.nodesource.com/setup_$NODE_VERSION.x -o nodesource_setup.sh |
|
|
|
@ -125,14 +130,15 @@ $STD npm install |
|
|
|
|
$STD npm run build:production |
|
|
|
|
|
|
|
|
|
# package.json was generated by the build process, however the original package-lock.json needs to be used to ensure the same versions |
|
|
|
|
mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/package-lock.json /opt/ghostfolio-$GHOSTFOLIO_VERSION/dist/apps/api/ |
|
|
|
|
mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/package-lock.json.bak /opt/ghostfolio-$GHOSTFOLIO_VERSION/dist/apps/api/package-lock.json |
|
|
|
|
|
|
|
|
|
cd /opt/ghostfolio-$GHOSTFOLIO_VERSION/dist/apps/api/ |
|
|
|
|
$STD npm install |
|
|
|
|
mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/prisma . |
|
|
|
|
|
|
|
|
|
# Overwrite the generated package.json with the original one to ensure having all the scripts |
|
|
|
|
mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/package.json /opt/ghostfolio-$GHOSTFOLIO_VERSION/dist/apps/api/ |
|
|
|
|
mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/package.json.bak /opt/ghostfolio-$GHOSTFOLIO_VERSION/dist/apps/api/package.json |
|
|
|
|
|
|
|
|
|
$STD npm run database:generate-typings |
|
|
|
|
|
|
|
|
|
# Move the built project to /opt/ghostfolio |
|
|
|
@ -141,10 +147,11 @@ mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/dist/apps /opt/ghostfolio |
|
|
|
|
mv /opt/ghostfolio-$GHOSTFOLIO_VERSION/docker/entrypoint.sh /opt/ghostfolio/ |
|
|
|
|
|
|
|
|
|
rm -rf /opt/ghostfolio-$GHOSTFOLIO_VERSION |
|
|
|
|
|
|
|
|
|
msg_ok "Set up Ghostfolio" |
|
|
|
|
# --- END GHOSTFOLIO |
|
|
|
|
|
|
|
|
|
# SERVICE ================================= |
|
|
|
|
msg_info "Creating Startup Scripts" |
|
|
|
|
# Create env file |
|
|
|
|
msg_info "Creating Environment File" |
|
|
|
|
cat <<EOF >/opt/ghostfolio/api/.env |
|
|
|
@ -162,7 +169,6 @@ DATABASE_URL="$DATABASE_URL" |
|
|
|
|
JWT_SECRET_KEY=$JWT_SECRET_KEY |
|
|
|
|
EOF |
|
|
|
|
|
|
|
|
|
msg_info "Creating Startup Script" |
|
|
|
|
# Create startup script |
|
|
|
|
cat <<EOF >/opt/ghostfolio/start.sh |
|
|
|
|
#!/bin/bash |
|
|
|
@ -201,7 +207,7 @@ EOF |
|
|
|
|
# Make the service run on container startup |
|
|
|
|
systemctl enable ghostfolio |
|
|
|
|
systemctl start ghostfolio |
|
|
|
|
msg_ok "Created Service" |
|
|
|
|
msg_ok "Created Startup Scripts" |
|
|
|
|
# -- END SERVICE |
|
|
|
|
|
|
|
|
|
motd_ssh |
|
|
|
|