This commit is contained in:
2025-12-02 15:44:35 +01:00
parent bd3eb14edc
commit 8653c510b7
5 changed files with 4694 additions and 63 deletions

1
.gitignore vendored
View File

@@ -10,6 +10,7 @@ __pycache__/
*.so *.so
.Python .Python
node_modules/
# Generated diagram files # Generated diagram files
*.pdf *.pdf
*.gv *.gv

View File

@@ -1,61 +1,18 @@
# Multi-stage Dockerfile for static frontend deployment # Build stage
# Stage 1: Build the diagrams FROM node:20-alpine AS build
FROM python:3.11-slim AS builder
# Install system dependencies for Graphviz
RUN apt-get update && \
apt-get install -y --no-install-recommends \
graphviz \
&& rm -rf /var/lib/apt/lists/*
# Set working directory
WORKDIR /app WORKDIR /app
# Copy requirements and install Python dependencies # Copy package files
COPY requirements.txt . COPY package*.json ./
RUN pip install --no-cache-dir -r requirements.txt RUN npm ci
# Copy source files COPY . .
COPY *.py . RUN npm run build
# Generate diagrams (outputs will be in /app) # Runtime stage
RUN python lan_architecture.py && \
python main.py
# Verify generated files exist
RUN ls -la *.png || echo "Warning: No PNG files generated"
# Stage 2: Serve with Nginx
FROM nginx:alpine FROM nginx:alpine
# Remove default nginx static assets COPY --from=build /app/dist/ /usr/share/nginx/html/
RUN rm -rf /usr/share/nginx/html/*
# Copy generated diagram files from builder stage
COPY --from=builder /app/*.png /usr/share/nginx/html/
# Copy any HTML/CSS files for the frontend
COPY public/ /usr/share/nginx/html/
# Create a simple nginx config for serving static files
RUN echo 'server { \
listen 80; \
server_name _; \
root /usr/share/nginx/html; \
index index.html; \
location / { \
try_files $uri $uri/ /index.html; \
} \
# Enable CORS if needed \
add_header Access-Control-Allow-Origin *; \
}' > /etc/nginx/conf.d/default.conf
# Expose port 80
EXPOSE 80 EXPOSE 80
# Health check
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD wget --quiet --tries=1 --spider http://localhost/ || exit 1
# Start nginx
CMD ["nginx", "-g", "daemon off;"]

View File

@@ -1,9 +1,7 @@
version: '3.8'
services: services:
viewer: viewer:
build: build:
context: . context: /opt/apps/viewer
dockerfile: Dockerfile dockerfile: Dockerfile
container_name: viewer container_name: viewer
restart: unless-stopped restart: unless-stopped
@@ -14,15 +12,15 @@ services:
- "traefik.http.routers.viewer.rule=Host(`viewer.appmodel.nl`)" - "traefik.http.routers.viewer.rule=Host(`viewer.appmodel.nl`)"
- "traefik.http.routers.viewer.entrypoints=websecure" - "traefik.http.routers.viewer.entrypoints=websecure"
- "traefik.http.routers.viewer.tls=true" - "traefik.http.routers.viewer.tls=true"
- "traefik.http.routers.viewer.tls.certresolver=letsencrypt"
- "traefik.http.services.viewer.loadbalancer.server.port=80" - "traefik.http.services.viewer.loadbalancer.server.port=80"
# Optional: mount logs - "traefik.http.routers.viewer-http.rule=Host(`viewer.appmodel.nl`)"
volumes: - "traefik.http.routers.viewer-http.entrypoints=web"
- ./logs:/var/log/nginx - "traefik.http.routers.viewer-http.middlewares=viewer-https"
# Optional: environment variables - "traefik.http.middlewares.viewer-https.redirectscheme.scheme=https"
environment: - "traefik.http.routers.auction.tls.certresolver=letsencrypt",
- TZ=Europe/Amsterdam - "traefik.http.middlewares.viewer-https.redirectscheme.permanent=true"
networks: networks:
traefik_net: traefik_net:
external: true external: true
name: traefik_net

4651
package-lock.json generated Normal file

File diff suppressed because it is too large Load Diff

24
package.json Normal file
View File

@@ -0,0 +1,24 @@
{
"name": "viewer",
"version": "0.0.1",
"description": "",
"private": true,
"keywords": [
""
],
"license": "",
"author": "",
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"start": "webpack serve --open --config webpack.config.dev.js",
"build": "webpack --config webpack.config.prod.js"
},
"devDependencies": {
"copy-webpack-plugin": "^11.0.0",
"html-webpack-plugin": "^5.6.0",
"webpack": "^5.91.0",
"webpack-cli": "^5.1.4",
"webpack-dev-server": "^5.0.4",
"webpack-merge": "^5.10.0"
}
}