valknut-rs 1.3.1

High-performance Rust implementation of valknut code analysis algorithms
Documentation
# Multi-stage Docker build for Valknut
# Optimized for production deployment and CI/CD usage

# Build stage - Use latest Rust with all build tools
FROM rust:1.75-slim-bullseye as builder

# Install system dependencies for building
RUN apt-get update && apt-get install -y \
    pkg-config \
    libssl-dev \
    ca-certificates \
    && rm -rf /var/lib/apt/lists/*

# Create app user for security
RUN groupadd -r valknut && useradd -r -g valknut valknut

# Set up working directory
WORKDIR /app

# Copy dependency files first for layer caching
COPY Cargo.toml Cargo.lock ./
COPY .cargo/ ./.cargo/

# Copy source code
COPY src/ ./src/
COPY templates/ ./templates/
COPY datasets/ ./datasets/

# Build with release optimizations and all features
RUN cargo build --release --all-features \
    && strip target/release/valknut \
    && chmod +x target/release/valknut

# Runtime stage - Minimal base image
FROM debian:bullseye-slim

# Install minimal runtime dependencies
RUN apt-get update && apt-get install -y \
    ca-certificates \
    libssl1.1 \
    && rm -rf /var/lib/apt/lists/* \
    && apt-get clean

# Create app user with same UID/GID as builder
RUN groupadd -r valknut && useradd -r -g valknut valknut

# Create necessary directories
RUN mkdir -p /app/cache /app/reports /app/config \
    && chown -R valknut:valknut /app

# Copy binary from builder stage
COPY --from=builder /app/target/release/valknut /usr/local/bin/valknut
COPY --from=builder --chown=valknut:valknut /app/templates/ /app/templates/

# Set up working directory and user
WORKDIR /app
USER valknut

# Health check
HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \
    CMD valknut --version || exit 1

# Default configuration
ENV VALKNUT_CACHE_DIR=/app/cache \
    VALKNUT_CONFIG_PATH=/app/config/valknut.toml \
    VALKNUT_LOG_LEVEL=info \
    RUST_LOG=valknut=info

# Expose volume for mounting source code
VOLUME ["/workspace", "/app/cache", "/app/reports", "/app/config"]

# Default entrypoint
ENTRYPOINT ["valknut"]
CMD ["--help"]

# Labels for metadata
LABEL org.opencontainers.image.title="Valknut" \
      org.opencontainers.image.description="High-performance code analysis engine" \
      org.opencontainers.image.version="1.0.0" \
      org.opencontainers.image.vendor="Valknut Project" \
      org.opencontainers.image.licenses="MIT" \
      org.opencontainers.image.source="https://github.com/your-org/valknut" \
      org.opencontainers.image.documentation="https://valknut.dev/docs"