thirteenth version
This commit is contained in:
@@ -3,6 +3,7 @@ package risk
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"os"
|
||||
"time"
|
||||
|
||||
"github.com/shopspring/decimal"
|
||||
@@ -10,6 +11,8 @@ import (
|
||||
"overnight-trading-bot/internal/domain"
|
||||
)
|
||||
|
||||
var exitProcess = os.Exit
|
||||
|
||||
type EventSink interface {
|
||||
InsertRiskEvent(ctx context.Context, event domain.RiskEvent) error
|
||||
SaveSystemState(ctx context.Context, state domain.SystemState, mode domain.Mode, halted bool, reason string, contextJSON string) error
|
||||
@@ -63,6 +66,11 @@ func (m Manager) Halt(ctx context.Context, mode domain.Mode, eventType, reason s
|
||||
if m.sink == nil {
|
||||
return nil
|
||||
}
|
||||
if err := m.sink.SaveSystemState(ctx, domain.StateHalted, mode, true, reason, "{}"); err != nil {
|
||||
_, _ = fmt.Fprintf(os.Stderr, "fail-stop: persist halt state: %v\n", err)
|
||||
exitProcess(1)
|
||||
return fmt.Errorf("persist halt state: %w", err)
|
||||
}
|
||||
event := domain.RiskEvent{
|
||||
TS: time.Now().UTC(),
|
||||
Severity: domain.SeverityCritical,
|
||||
@@ -73,9 +81,6 @@ func (m Manager) Halt(ctx context.Context, mode domain.Mode, eventType, reason s
|
||||
if err := m.sink.InsertRiskEvent(ctx, event); err != nil {
|
||||
return fmt.Errorf("insert halt risk event: %w", err)
|
||||
}
|
||||
if err := m.sink.SaveSystemState(ctx, domain.StateHalted, mode, true, reason, "{}"); err != nil {
|
||||
return fmt.Errorf("persist halt state: %w", err)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user