0
Fork 0
mirror of https://codeberg.org/SafeTwitch/safetwitch.git synced 2025-01-05 04:10:05 -05:00

Allow docker image to work off of environment variables instead of hardcoded on build

This commit is contained in:
dragongoose 2023-04-26 10:31:07 -04:00
parent 4f03d41b0a
commit c1b214b0c9
No known key found for this signature in database
GPG key ID: 50DB99B921579009
4 changed files with 32 additions and 17 deletions

View file

@ -6,13 +6,10 @@
FROM node:16 AS builder FROM node:16 AS builder
# Set working directory # Set working directory
WORKDIR /app WORKDIR /app
ARG VITE_BACKEND_DOMAIN
ARG VITE_INSTANCE_DOMAIN
ARG VITE_HTTPS
ENV VITE_BACKEND_DOMAIN $VITE_BACKEND_DOMAIN ENV VITE_BACKEND_DOMAIN VITE_BACKEND_DOMAIN_PLACEHOLDER
ENV VITE_INSTANCE_DOMAIN $VITE_INSTANCE_DOMAIN ENV VITE_INSTANCE_DOMAIN VITE_INSTANCE_DOMAIN_PLACEHOLDER
ENV VITE_HTTPS $VITE_HTTPS ENV VITE_HTTPS VITE_HTTPS_PLACEHOLDER
# Copy all files from current directory to working dir in image # Copy all files from current directory to working dir in image
COPY . . COPY . .
# install node modules and build assets # install node modules and build assets
@ -22,11 +19,13 @@ RUN npm i && npm run build
FROM nginx:alpine FROM nginx:alpine
COPY ./nginx.conf /etc/nginx/nginx.conf COPY ./nginx.conf /etc/nginx/nginx.conf
# Set working directory to nginx asset directory # Set working directory to nginx asset directory
WORKDIR /usr/share/nginx/html RUN mkdir /app
# Remove default nginx static assets
RUN rm -rf ./*
# Copy static assets from builder stage # Copy static assets from builder stage
COPY --from=builder /app/dist . COPY --from=builder /app/dist /app
# Containers run nginx with global directives and daemon off # Containers run nginx with global directives and daemon off
EXPOSE 80 EXPOSE 80
ENTRYPOINT ["nginx", "-g", "daemon off;"]
# Overriding the default NGINX container behavior
COPY ./substitute_environment_variables.sh ./substitute_environment_variables.sh
RUN chmod +x /substitute_environment_variables.sh
ENTRYPOINT ["/substitute_environment_variables.sh"]

View file

@ -4,9 +4,10 @@ services:
build: build:
context: "../" context: "../"
dockerfile: ./docker/Dockerfile dockerfile: ./docker/Dockerfile
args : ports:
- "8080:80"
environment:
- VITE_BACKEND_DOMAIN=localhost:7000 - VITE_BACKEND_DOMAIN=localhost:7000
- VITE_INSTANCE_DOMAIN=localhost:80 - VITE_INSTANCE_DOMAIN=localhost:80
- VITE_HTTPS=false - VITE_HTTPS=false
ports:
- "8080:80"

View file

@ -9,7 +9,7 @@ http {
location / { location / {
root /usr/share/nginx/html; root /app;
index index.html; index index.html;
try_files $uri $uri/ /index.html; try_files $uri $uri/ /index.html;
} }

View file

@ -0,0 +1,15 @@
#!/bin/sh
ROOT_DIR=/app
# Replace env vars in files served by NGINX
for file in $ROOT_DIR/assets/*.js $ROOT_DIR/index.html;
do
sed -i 's|VITE_BACKEND_DOMAIN_PLACEHOLDER|'${VITE_BACKEND_DOMAIN}'|g' $file
sed -i 's|VITE_INSTANCE_DOMAIN_PLACEHOLDER|'${VITE_INSTANCE_DOMAIN}'|g' $file
sed -i 's|VITE_HTTPS_PLACEHOLDER|'${VITE_HTTPS}'|g' $file
# Your other variables here...
done
# Starting NGINX
nginx -g 'daemon off;'