(traceContext, event, status = "success", payload = {})
| 464 | } |
| 465 | |
| 466 | async function finishEvent(traceContext, event, status = "success", payload = {}) { |
| 467 | if (!traceContext || !event) { |
| 468 | return null; |
| 469 | } |
| 470 | |
| 471 | const finishedAt = new Date(); |
| 472 | const mergedPayload = sanitizePayload({ |
| 473 | ...(event.payload || {}), |
| 474 | ...payload, |
| 475 | }); |
| 476 | const durationMs = getDurationMs(event.startedAt, finishedAt); |
| 477 | |
| 478 | try { |
| 479 | if (db.UpdateRunEvent && event.id) { |
| 480 | await db.UpdateRunEvent.update({ |
| 481 | status, |
| 482 | finishedAt, |
| 483 | durationMs, |
| 484 | payload: mergedPayload, |
| 485 | }, { where: { id: event.id } }); |
| 486 | } |
| 487 | } catch (error) { |
| 488 | emitAuditInternalError("[updateAudit] failed to update event", error); |
| 489 | } |
| 490 | |
| 491 | emitStructuredAuditLog("event_finished", { |
| 492 | runId: traceContext.runId, |
| 493 | traceId: traceContext.traceId, |
| 494 | rootTraceId: traceContext.rootTraceId, |
| 495 | sequence: event.sequence, |
| 496 | stage: event.stage, |
| 497 | status, |
| 498 | durationMs, |
| 499 | payload: mergedPayload, |
| 500 | }); |
| 501 | |
| 502 | return { |
| 503 | ...event, |
| 504 | status, |
| 505 | finishedAt, |
| 506 | durationMs, |
| 507 | payload: mergedPayload, |
| 508 | }; |
| 509 | } |
| 510 | |
| 511 | async function completeRun(traceContext, options = {}) { |
| 512 | if (!traceContext) { |
no test coverage detected