feat: systematic functional audit — fix 18 issues across Phase A/B

Phase A (P1 production blockers):
- A1: Apply IP rate limiting to public routes (login/refresh)
- A2: Publish domain events for workflow instance state transitions
  (completed/suspended/resumed/terminated) via outbox pattern
- A3: Replace hardcoded nil UUID default tenant with dynamic DB lookup
- A4: Add GET /api/v1/audit-logs query endpoint with pagination
- A5: Enhance CORS wildcard warning for production environments

Phase B (P2 functional gaps):
- B1: Remove dead erp-common crate (zero references in codebase)
- B2: Refactor 5 settings pages to use typed API modules instead of
  direct client calls; create api/themes.ts; delete dead errors.ts
- B3: Add resume/suspend buttons to InstanceMonitor page
- B4: Remove unused EventHandler trait from erp-core
- B5: Handle task.completed events in message module (send notifications)
- B6: Wire TimeoutChecker as 60s background task
- B7: Auto-skip ServiceTask nodes instead of crashing the process
- B8: Remove empty register_routes() from ErpModule trait and modules
This commit is contained in:
iven
2026-04-12 15:22:28 +08:00
parent 685df5e458
commit 14f431efff
34 changed files with 785 additions and 304 deletions

13
Cargo.lock generated
View File

@@ -807,7 +807,6 @@ dependencies = [
"async-trait",
"axum",
"chrono",
"erp-common",
"erp-core",
"jsonwebtoken",
"sea-orm",
@@ -822,17 +821,6 @@ dependencies = [
"validator",
]
[[package]]
name = "erp-common"
version = "0.1.0"
dependencies = [
"chrono",
"serde",
"serde_json",
"tracing",
"uuid",
]
[[package]]
name = "erp-config"
version = "0.1.0"
@@ -899,7 +887,6 @@ dependencies = [
"chrono",
"config",
"erp-auth",
"erp-common",
"erp-config",
"erp-core",
"erp-message",