Some checks failed
Build & Deploy to Staging / Build & Deploy to Staging (push) Has been cancelled
- Add swagger-jsdoc dependency for auto-generating OpenAPI spec from JSDoc - Add JSDoc @openapi annotations to all route handlers - Create scripts/generate-openapi.mjs build step - OpenAPI spec now auto-generated from code — no manual JSON editing - All 13 endpoints documented with full parameters - New demo endpoints documented, signup marked as deprecated - Updated info description: demo-first, no free tier references - Dockerfile updated to run openapi generation during build - Build script updated: npm run build generates spec before compile
39 lines
1 KiB
Docker
39 lines
1 KiB
Docker
FROM node:22-bookworm-slim
|
|
|
|
# Install Chromium and dependencies as root
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
chromium fonts-liberation \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Create non-root user
|
|
RUN groupadd --gid 1001 docfast \
|
|
&& useradd --uid 1001 --gid docfast --shell /bin/bash --create-home docfast
|
|
|
|
# Set environment variables
|
|
ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true
|
|
ENV PUPPETEER_EXECUTABLE_PATH=/usr/bin/chromium
|
|
|
|
# Build stage - compile TypeScript
|
|
WORKDIR /app
|
|
COPY package*.json tsconfig.json ./
|
|
RUN npm install
|
|
COPY src/ src/
|
|
RUN npx tsc
|
|
|
|
# Remove dev dependencies
|
|
RUN npm prune --omit=dev
|
|
COPY scripts/ scripts/
|
|
COPY public/ public/
|
|
RUN node scripts/generate-openapi.mjs
|
|
RUN node scripts/build-html.cjs
|
|
RUN rm -f public/swagger-ui && ln -s /app/node_modules/swagger-ui-dist public/swagger-ui
|
|
|
|
# Create data directory and set ownership to docfast user
|
|
RUN mkdir -p /app/data && chown -R docfast:docfast /app
|
|
|
|
# Switch to non-root user
|
|
USER docfast
|
|
|
|
ENV PORT=3100
|
|
EXPOSE 3100
|
|
CMD ["node", "dist/index.js"]
|