🔧 RESTRUCTURATION - UserResource déplacé de adapter.http vers application.rest - FournisseurResource déplacé vers application.rest - Suppression des contrôleurs obsolètes (presentation.controller) - Suppression de MaterielFournisseurService en doublon 📝 STANDARDISATION DOCUMENTATION - Annotations OpenAPI uniformes (@Operation, @APIResponse, @Parameter) - Descriptions concises et cohérentes pour tous les endpoints - Codes de réponse HTTP standards (200, 201, 400, 404, 500) 🛠️ ENDPOINTS USERS STANDARDISÉS - GET /api/v1/users - Liste tous les utilisateurs - GET /api/v1/users/{id} - Détails d'un utilisateur - GET /api/v1/users/stats - Statistiques globales - GET /api/v1/users/count - Comptage - GET /api/v1/users/pending - Utilisateurs en attente - POST /api/v1/users - Création - PUT /api/v1/users/{id} - Mise à jour - DELETE /api/v1/users/{id} - Suppression - POST /api/v1/users/{id}/approve - Approbation - POST /api/v1/users/{id}/reject - Rejet - PUT /api/v1/users/{id}/status - Changement de statut - PUT /api/v1/users/{id}/role - Changement de rôle ⚠️ GESTION D'ERREURS - Format uniforme: Map.of("error", "message") - Codes HTTP cohérents avec les autres ressources - Validation des entrées standardisée ✅ VALIDATION - Compilation réussie: mvn clean compile -DskipTests - Pattern conforme aux autres ressources (PhaseTemplate, Fournisseur) - Documentation OpenAPI/Swagger complète et cohérente
46 lines
1.3 KiB
Docker
46 lines
1.3 KiB
Docker
####
|
|
# This Dockerfile is used to build a production-ready Quarkus application
|
|
####
|
|
|
|
## Stage 1 : Build with Maven
|
|
FROM maven:3.9.6-eclipse-temurin-17 AS build
|
|
WORKDIR /build
|
|
|
|
# Copy pom.xml and download dependencies
|
|
COPY pom.xml .
|
|
RUN mvn dependency:go-offline -B
|
|
|
|
# Copy source code
|
|
COPY src ./src
|
|
|
|
# Build application with optimizations
|
|
RUN mvn clean package -DskipTests -Dquarkus.package.type=uber-jar
|
|
|
|
## Stage 2 : Create runtime image
|
|
FROM eclipse-temurin:17-jre-alpine
|
|
|
|
ENV LANGUAGE='en_US:en'
|
|
|
|
# Install curl for health checks
|
|
RUN apk add --no-cache curl
|
|
|
|
# Create app user and directories
|
|
RUN addgroup -g 185 -S appuser && adduser -u 185 -S appuser -G appuser
|
|
RUN mkdir -p /deployments && chown -R appuser:appuser /deployments
|
|
|
|
# Copy the uber-jar (single JAR with all dependencies)
|
|
COPY --from=build --chown=appuser:appuser /build/target/*-runner.jar /deployments/app.jar
|
|
|
|
EXPOSE 8080
|
|
USER appuser
|
|
|
|
# Optimized JVM settings for production
|
|
ENV JAVA_OPTS="-Dquarkus.http.host=0.0.0.0 -Djava.util.logging.manager=org.jboss.logmanager.LogManager -XX:+UseG1GC -XX:MaxRAMPercentage=75.0 -XX:+UseStringDeduplication"
|
|
|
|
# Health check
|
|
HEALTHCHECK --interval=30s --timeout=10s --start-period=60s --retries=3 \
|
|
CMD curl -f http://localhost:8080/q/health/ready || exit 1
|
|
|
|
ENTRYPOINT [ "java", "-jar", "/deployments/app.jar" ]
|
|
|