first pass

This commit is contained in:
2026-01-26 22:33:55 -06:00
commit fe66be4aad
37 changed files with 3127 additions and 0 deletions

View File

@@ -0,0 +1,47 @@
node_modules
npm-debug.log*
.git
.gitignore
.env
.env.local
.env.*.local
*.tar
*.tar.gz
# IDE
.vscode
.idea
*.swp
*.swo
# Test & Coverage
coverage
.nyc_output
*.test.js
*.spec.js
__tests__
# Build artifacts
dist
build
# Documentation
README.md
README.DOCKER.md
CHANGELOG.md
docs
# Docker files (don't include in image)
Dockerfile
docker-compose.yml
docker-compose.yaml
.dockerignore
docker-deployment.json
# Scripts
*.ps1
*.sh
# Logs
logs
*.log

View File

@@ -0,0 +1,27 @@
FROM node:{{NODE_VERSION}}-slim
WORKDIR /app
# Copy package files first for better caching
COPY package.json package-lock.json* ./
# Install production dependencies only
RUN npm ci --omit=dev
# Copy application source
COPY . .
# Set environment
ENV NODE_ENV=production
ENV PORT={{PORT}}
{{#if BUILD_COMMAND}}
# Build application
RUN {{BUILD_COMMAND}}
{{/if}}
# Expose port
EXPOSE {{PORT}}
# Start application
CMD ["node", "{{ENTRY_POINT}}"]

View File

@@ -0,0 +1,24 @@
services:
{{PROJECT_NAME}}:
build: .
container_name: {{PROJECT_NAME}}
restart: unless-stopped
ports:
- "${HOST_PORT:-{{PORT}}}:{{PORT}}"
{{#if USE_ENV_FILE}}
env_file:
- .env
{{/if}}
environment:
NODE_ENV: production
PORT: {{PORT}}
{{#if HAS_VOLUMES}}
volumes:
{{#each VOLUMES}}
- {{this}}
{{/each}}
{{/if}}
{{#if EXTRA_HOSTS}}
extra_hosts:
- "host.docker.internal:host-gateway"
{{/if}}

View File

@@ -0,0 +1,32 @@
node_modules
npm-debug.log*
.git
.gitignore
.env
.env.local
.env.*.local
*.tar
*.tar.gz
# IDE
.vscode
.idea
# Test & Coverage
coverage
.nyc_output
# Build output (built during docker build)
dist
# Documentation
README.md
README.DOCKER.md
docs
# Docker files
Dockerfile
docker-compose.yml
.dockerignore
docker-deployment.json
*.ps1

View File

@@ -0,0 +1,34 @@
# Stage 1: Build
FROM node:{{NODE_VERSION}}-alpine AS builder
WORKDIR /app
COPY package.json package-lock.json* ./
RUN npm ci
COPY . .
RUN npm run build
# Stage 2: Production
FROM node:{{NODE_VERSION}}-alpine
WORKDIR /app
# Copy package files and install production dependencies
COPY package.json package-lock.json* ./
RUN npm ci --omit=dev
# Copy built files from builder
COPY --from=builder /app/dist ./dist
# Copy server file
COPY server.mjs ./server.mjs
# Set environment
ENV NODE_ENV=production
ENV PORT={{PORT}}
ENV DIST_DIR=/app/dist
EXPOSE {{PORT}}
CMD ["node", "server.mjs"]

View File

@@ -0,0 +1,24 @@
services:
{{PROJECT_NAME}}:
build: .
container_name: {{PROJECT_NAME}}
restart: unless-stopped
ports:
- "${HOST_PORT:-{{PORT}}}:{{PORT}}"
{{#if USE_ENV_FILE}}
env_file:
- .env
{{/if}}
environment:
NODE_ENV: production
PORT: {{PORT}}
{{#if HAS_VOLUMES}}
volumes:
{{#each VOLUMES}}
- {{this}}
{{/each}}
{{/if}}
{{#if EXTRA_HOSTS}}
extra_hosts:
- "host.docker.internal:host-gateway"
{{/if}}

View File

@@ -0,0 +1,32 @@
node_modules
npm-debug.log*
.git
.gitignore
.env
.env.local
.env.*.local
*.tar
*.tar.gz
# IDE
.vscode
.idea
# Test & Coverage
coverage
.nyc_output
# Build output (built during docker build)
dist
# Documentation
README.md
README.DOCKER.md
docs
# Docker files
Dockerfile
docker-compose.yml
.dockerignore
docker-deployment.json
*.ps1

View File

@@ -0,0 +1,23 @@
# Stage 1: Build
FROM node:{{NODE_VERSION}}-alpine AS builder
WORKDIR /app
COPY package.json package-lock.json* ./
RUN npm ci
COPY . .
RUN npm run build
# Stage 2: Production (Nginx)
FROM nginx:alpine
# Copy built files
COPY --from=builder /app/dist /usr/share/nginx/html
# Copy nginx configuration
COPY nginx.conf /etc/nginx/conf.d/default.conf
EXPOSE 80
CMD ["nginx", "-g", "daemon off;"]

View File

@@ -0,0 +1,13 @@
services:
{{PROJECT_NAME}}:
build: .
container_name: {{PROJECT_NAME}}
restart: unless-stopped
ports:
- "${HOST_PORT:-80}:80"
{{#if HAS_VOLUMES}}
volumes:
{{#each VOLUMES}}
- {{this}}
{{/each}}
{{/if}}

View File

@@ -0,0 +1,25 @@
server {
listen 80;
server_name localhost;
root /usr/share/nginx/html;
index index.html;
# Handle client-side routing
location / {
try_files $uri $uri/ /index.html;
}
# Cache static assets
location ~* \.(jpg|jpeg|png|gif|ico|css|js|svg|woff|woff2|ttf|eot)$ {
expires 1y;
add_header Cache-Control "public, immutable";
}
# Gzip compression
gzip on;
gzip_vary on;
gzip_min_length 1024;
gzip_proxied expired no-cache no-store private auth;
gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
}