generated from vincent/template-projet
feat: Phase 1 — socle backend FastAPI + frontend Next.js
Backend (FastAPI + SQLAlchemy): - Modèles : User, Client, Audit, Cible, Vulnérabilité, Action - Auth JWT (register/login/me) avec bcrypt - Routes CRUD complets : clients, audits, cibles, vulnérabilités, actions - Schémas Pydantic v2, migrations Alembic configurées - Rate limiting (slowapi), CORS, structure scanners/reports pour phase 2 Frontend (Next.js 14 App Router): - shadcn/ui : Button, Input, Card, Badge, Label - Page login avec gestion token JWT - Dashboard avec stats temps réel - Pages Clients (grille) et Audits (liste) avec recherche - Layout avec sidebar navigation + protection auth - Dockerfiles multi-stage (backend + frontend standalone) Infrastructure: - docker-compose.yml : postgres, redis, backend, frontend - docker-compose.prod.yml avec labels Traefik - .env.example complet - .gitignore mis à jour Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
0
backend/schemas/__init__.py
Normal file
0
backend/schemas/__init__.py
Normal file
99
backend/schemas/audit.py
Normal file
99
backend/schemas/audit.py
Normal file
@@ -0,0 +1,99 @@
|
||||
from pydantic import BaseModel
|
||||
from datetime import datetime
|
||||
from backend.models.audit import AuditStatut
|
||||
from backend.models.target import CibleType
|
||||
from backend.models.vulnerability import Criticite
|
||||
from backend.models.action import ActionStatut
|
||||
|
||||
|
||||
class CibleCreate(BaseModel):
|
||||
type: CibleType
|
||||
valeur: str
|
||||
|
||||
|
||||
class CibleRead(BaseModel):
|
||||
id: int
|
||||
audit_id: int
|
||||
type: CibleType
|
||||
valeur: str
|
||||
validee: bool
|
||||
|
||||
model_config = {"from_attributes": True}
|
||||
|
||||
|
||||
class VulnerabiliteCreate(BaseModel):
|
||||
criticite: Criticite
|
||||
titre: str
|
||||
description: str
|
||||
recommandation: str
|
||||
cve: str | None = None
|
||||
cvss_score: float | None = None
|
||||
cible: str | None = None
|
||||
|
||||
|
||||
class VulnerabiliteRead(BaseModel):
|
||||
id: int
|
||||
audit_id: int
|
||||
criticite: Criticite
|
||||
titre: str
|
||||
description: str
|
||||
recommandation: str
|
||||
cve: str | None
|
||||
cvss_score: float | None
|
||||
cible: str | None
|
||||
|
||||
model_config = {"from_attributes": True}
|
||||
|
||||
|
||||
class ActionCreate(BaseModel):
|
||||
vulnerabilite_id: int
|
||||
assigne_a: str | None = None
|
||||
note: str | None = None
|
||||
|
||||
|
||||
class ActionUpdate(BaseModel):
|
||||
statut: ActionStatut | None = None
|
||||
assigne_a: str | None = None
|
||||
note: str | None = None
|
||||
|
||||
|
||||
class ActionRead(BaseModel):
|
||||
id: int
|
||||
vulnerabilite_id: int
|
||||
statut: ActionStatut
|
||||
assigne_a: str | None
|
||||
note: str | None
|
||||
|
||||
model_config = {"from_attributes": True}
|
||||
|
||||
|
||||
class AuditCreate(BaseModel):
|
||||
client_id: int
|
||||
nom: str
|
||||
date_debut: datetime | None = None
|
||||
|
||||
|
||||
class AuditUpdate(BaseModel):
|
||||
nom: str | None = None
|
||||
statut: AuditStatut | None = None
|
||||
date_debut: datetime | None = None
|
||||
date_fin: datetime | None = None
|
||||
score_global: float | None = None
|
||||
|
||||
|
||||
class AuditRead(BaseModel):
|
||||
id: int
|
||||
client_id: int
|
||||
nom: str
|
||||
statut: AuditStatut
|
||||
date_debut: datetime | None
|
||||
date_fin: datetime | None
|
||||
score_global: float | None
|
||||
created_at: datetime
|
||||
|
||||
model_config = {"from_attributes": True}
|
||||
|
||||
|
||||
class AuditDetail(AuditRead):
|
||||
cibles: list[CibleRead] = []
|
||||
vulnerabilites: list[VulnerabiliteRead] = []
|
||||
30
backend/schemas/client.py
Normal file
30
backend/schemas/client.py
Normal file
@@ -0,0 +1,30 @@
|
||||
from pydantic import BaseModel, EmailStr
|
||||
from datetime import datetime
|
||||
|
||||
|
||||
class ClientCreate(BaseModel):
|
||||
nom: str
|
||||
contact: str | None = None
|
||||
email: str | None = None
|
||||
telephone: str | None = None
|
||||
notes: str | None = None
|
||||
|
||||
|
||||
class ClientUpdate(BaseModel):
|
||||
nom: str | None = None
|
||||
contact: str | None = None
|
||||
email: str | None = None
|
||||
telephone: str | None = None
|
||||
notes: str | None = None
|
||||
|
||||
|
||||
class ClientRead(BaseModel):
|
||||
id: int
|
||||
nom: str
|
||||
contact: str | None
|
||||
email: str | None
|
||||
telephone: str | None
|
||||
notes: str | None
|
||||
created_at: datetime
|
||||
|
||||
model_config = {"from_attributes": True}
|
||||
26
backend/schemas/user.py
Normal file
26
backend/schemas/user.py
Normal file
@@ -0,0 +1,26 @@
|
||||
from pydantic import BaseModel, EmailStr
|
||||
|
||||
|
||||
class UserCreate(BaseModel):
|
||||
email: EmailStr
|
||||
full_name: str
|
||||
password: str
|
||||
|
||||
|
||||
class UserRead(BaseModel):
|
||||
id: int
|
||||
email: str
|
||||
full_name: str
|
||||
is_active: bool
|
||||
is_admin: bool
|
||||
|
||||
model_config = {"from_attributes": True}
|
||||
|
||||
|
||||
class Token(BaseModel):
|
||||
access_token: str
|
||||
token_type: str = "bearer"
|
||||
|
||||
|
||||
class TokenData(BaseModel):
|
||||
user_id: int
|
||||
Reference in New Issue
Block a user