feat(core): implement event outbox persistence

Add domain_events migration and SeaORM entity. Modify EventBus::publish
to persist events before broadcasting (best-effort: DB failure logs
warning but still broadcasts in-memory). Update all 19 publish call
sites across 4 crates to pass db reference.

Add outbox relay background task that polls pending events every 5s
and re-broadcasts them, ensuring no events are lost on server restart.
This commit is contained in:
iven
2026-04-12 00:10:49 +08:00
parent 529d90ff46
commit 685df5e458
23 changed files with 235 additions and 31 deletions

View File

@@ -107,7 +107,7 @@ impl DefinitionService {
"process_definition.created",
tenant_id,
serde_json::json!({ "definition_id": id, "key": req.key }),
));
), db).await;
audit_service::record(
AuditLog::new(tenant_id, Some(operator_id), "process_definition.create", "process_definition")
@@ -245,7 +245,7 @@ impl DefinitionService {
"process_definition.published",
tenant_id,
serde_json::json!({ "definition_id": id }),
));
), db).await;
audit_service::record(
AuditLog::new(tenant_id, Some(operator_id), "process_definition.publish", "process_definition")

View File

@@ -130,7 +130,7 @@ impl InstanceService {
"process_instance.started",
tenant_id,
serde_json::json!({ "instance_id": instance_id, "definition_id": definition.id, "started_by": operator_id }),
));
), db).await;
audit_service::record(
AuditLog::new(tenant_id, Some(operator_id), "process_instance.start", "process_instance")

View File

@@ -242,7 +242,7 @@ impl TaskService {
"task.completed",
tenant_id,
serde_json::json!({ "task_id": id, "outcome": req.outcome }),
));
), db).await;
audit_service::record(
AuditLog::new(tenant_id, Some(operator_id), "task.complete", "task")