Improve build/install scripts for multiple apps
Switch development builds to production and harden install/update steps across several apps. - Akaunting: use `npm run production` instead of `npm run dev` in both install and update scripts to produce production assets. - Blinko: make bun installs run with `--unsafe-perm`, run `bun run build:web` and `bun run build:seed`, copy built public assets into `/opt/blinko/server/public`, run prisma migrations, and execute the generated seed script. Add PORT and NEXT_PUBLIC_BASE_URL to the .env. Update the systemd service to use WorkingDirectory `/opt/blinko/server` and start the app with `node /opt/blinko/dist/index.js`. - InvoiceShelf & SolidTime: stop capturing APP_KEY via `php artisan key:generate --show` + sed; instead run `php artisan key:generate` during install after composer install. SolidTime also runs `php artisan storage:link` after build. These changes simplify key generation and ensure proper storage linking. Overall these updates ensure production-ready builds, proper artifact placement, and correct runtime configuration for services.
This commit is contained in:
@@ -52,7 +52,7 @@ function update_script() {
|
||||
cd /opt/akaunting
|
||||
$STD composer install --no-dev --optimize-autoloader
|
||||
$STD npm install
|
||||
$STD npm run dev
|
||||
$STD npm run production
|
||||
$STD php artisan migrate --force
|
||||
$STD php artisan optimize:clear
|
||||
chown -R www-data:www-data /opt/akaunting
|
||||
|
||||
@@ -47,9 +47,12 @@ function update_script() {
|
||||
|
||||
msg_info "Updating Application"
|
||||
cd /opt/blinko
|
||||
$STD bun install
|
||||
$STD bun install --unsafe-perm
|
||||
$STD bun run build:web
|
||||
$STD bun run build:seed
|
||||
mkdir -p /opt/blinko/server/public
|
||||
cp -r /opt/blinko/dist/public/. /opt/blinko/server/public/ 2>/dev/null || true
|
||||
$STD bunx prisma migrate deploy
|
||||
$STD bun run build
|
||||
msg_ok "Updated Application"
|
||||
|
||||
msg_info "Starting Service"
|
||||
|
||||
@@ -28,7 +28,7 @@ msg_info "Setting up Akaunting"
|
||||
cd /opt/akaunting
|
||||
$STD composer install --no-dev --optimize-autoloader
|
||||
$STD npm install
|
||||
$STD npm run dev
|
||||
$STD npm run production
|
||||
cat <<EOF >/opt/akaunting/.env
|
||||
APP_NAME=Akaunting
|
||||
APP_ENV=production
|
||||
|
||||
@@ -31,15 +31,19 @@ msg_info "Setting up Blinko"
|
||||
cd /opt/blinko
|
||||
cat <<EOF >/opt/blinko/.env
|
||||
NODE_ENV=production
|
||||
PORT=1111
|
||||
DATABASE_URL=postgresql://${PG_DB_USER}:${PG_DB_PASS}@127.0.0.1:5432/${PG_DB_NAME}
|
||||
NEXT_PUBLIC_BASE_URL=http://${LOCAL_IP}:1111
|
||||
NEXTAUTH_URL=http://${LOCAL_IP}:1111
|
||||
NEXTAUTH_SECRET=$(openssl rand -base64 32)
|
||||
NEXT_PUBLIC_BASE_URL=http://${LOCAL_IP}:1111
|
||||
EOF
|
||||
$STD bun install
|
||||
$STD bunx prisma generate
|
||||
$STD bun install --unsafe-perm
|
||||
$STD bun run build:web
|
||||
$STD bun run build:seed
|
||||
mkdir -p /opt/blinko/server/public
|
||||
cp -r /opt/blinko/dist/public/. /opt/blinko/server/public/ 2>/dev/null || true
|
||||
$STD bunx prisma migrate deploy
|
||||
$STD bun run build
|
||||
$STD node /opt/blinko/dist/seed.js
|
||||
msg_ok "Set up Blinko"
|
||||
|
||||
msg_info "Creating Service"
|
||||
@@ -51,9 +55,9 @@ After=network.target postgresql.service
|
||||
[Service]
|
||||
Type=simple
|
||||
User=root
|
||||
WorkingDirectory=/opt/blinko
|
||||
WorkingDirectory=/opt/blinko/server
|
||||
EnvironmentFile=/opt/blinko/.env
|
||||
ExecStart=/usr/bin/node /opt/blinko/.next/standalone/server.js
|
||||
ExecStart=/usr/bin/node /opt/blinko/dist/index.js
|
||||
Restart=on-failure
|
||||
RestartSec=5
|
||||
|
||||
|
||||
@@ -28,8 +28,6 @@ fetch_and_deploy_gh_release "invoiceshelf" "InvoiceShelf/InvoiceShelf" "tarball"
|
||||
msg_info "Setting up InvoiceShelf"
|
||||
cd /opt/invoiceshelf
|
||||
cp .env.example .env
|
||||
APP_KEY=$($STD php artisan key:generate --show)
|
||||
sed -i "s|^APP_KEY=.*|APP_KEY=${APP_KEY}|" .env
|
||||
sed -i "s|^APP_ENV=.*|APP_ENV=production|" .env
|
||||
sed -i "s|^APP_DEBUG=.*|APP_DEBUG=false|" .env
|
||||
sed -i "s|^APP_URL=.*|APP_URL=http://${LOCAL_IP}|" .env
|
||||
@@ -40,6 +38,7 @@ sed -i "s|^DB_DATABASE=.*|DB_DATABASE=${PG_DB_NAME}|" .env
|
||||
sed -i "s|^DB_USERNAME=.*|DB_USERNAME=${PG_DB_USER}|" .env
|
||||
sed -i "s|^DB_PASSWORD=.*|DB_PASSWORD=${PG_DB_PASS}|" .env
|
||||
$STD composer install --no-dev --optimize-autoloader
|
||||
$STD php artisan key:generate
|
||||
$STD yarn install
|
||||
$STD yarn build
|
||||
mkdir -p storage/framework/{cache,sessions,views} storage/logs bootstrap/cache
|
||||
|
||||
@@ -28,8 +28,6 @@ fetch_and_deploy_gh_release "solidtime" "solidtime-io/solidtime" "tarball"
|
||||
msg_info "Setting up SolidTime"
|
||||
cd /opt/solidtime
|
||||
cp .env.example .env
|
||||
APP_KEY=$($STD php artisan key:generate --show)
|
||||
sed -i "s|^APP_KEY=.*|APP_KEY=${APP_KEY}|" .env
|
||||
sed -i "s|^APP_ENV=.*|APP_ENV=production|" .env
|
||||
sed -i "s|^APP_DEBUG=.*|APP_DEBUG=false|" .env
|
||||
sed -i "s|^APP_URL=.*|APP_URL=http://${LOCAL_IP}|" .env
|
||||
@@ -40,11 +38,13 @@ sed -i "s|^DB_DATABASE=.*|DB_DATABASE=${PG_DB_NAME}|" .env
|
||||
sed -i "s|^DB_USERNAME=.*|DB_USERNAME=${PG_DB_USER}|" .env
|
||||
sed -i "s|^DB_PASSWORD=.*|DB_PASSWORD=${PG_DB_PASS}|" .env
|
||||
$STD composer install --no-dev --optimize-autoloader
|
||||
$STD php artisan key:generate
|
||||
$STD npm install
|
||||
$STD npm run build
|
||||
mkdir -p storage/framework/{cache,sessions,views} storage/logs bootstrap/cache
|
||||
chown -R www-data:www-data /opt/solidtime
|
||||
chmod -R 775 storage bootstrap/cache
|
||||
$STD php artisan storage:link
|
||||
$STD php artisan migrate --force
|
||||
msg_ok "Set up SolidTime"
|
||||
|
||||
|
||||
Reference in New Issue
Block a user