refactor: split LogEvent into smaller functions
This commit is contained in:
@@ -11,42 +11,50 @@ func NewFxLogger() fxevent.Logger {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (fxLogger) LogEvent(event fxevent.Event) {
|
func (fxLogger) LogEvent(event fxevent.Event) {
|
||||||
|
eventName, fields, err := describeFXEventError(event)
|
||||||
|
if err == nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
Error(eventName, "fx", "", fields, err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func describeFXEventError(event fxevent.Event) (string, map[string]any, error) {
|
||||||
|
if ok, eventName, fields, err := describeFXExecutionEventError(event); ok {
|
||||||
|
return eventName, fields, err
|
||||||
|
}
|
||||||
|
|
||||||
|
return describeFXLifecycleEventError(event)
|
||||||
|
}
|
||||||
|
|
||||||
|
func describeFXExecutionEventError(event fxevent.Event) (bool, string, map[string]any, error) {
|
||||||
switch e := event.(type) {
|
switch e := event.(type) {
|
||||||
case *fxevent.Provided:
|
case *fxevent.Provided:
|
||||||
if e.Err != nil {
|
return true, "fx_provide_failed", map[string]any{"constructor": e.ConstructorName}, e.Err
|
||||||
Error("fx_provide_failed", "fx", "", map[string]any{"constructor": e.ConstructorName}, e.Err)
|
|
||||||
}
|
|
||||||
case *fxevent.Invoked:
|
case *fxevent.Invoked:
|
||||||
if e.Err != nil {
|
return true, "fx_invoke_failed", map[string]any{"function": e.FunctionName}, e.Err
|
||||||
Error("fx_invoke_failed", "fx", "", map[string]any{"function": e.FunctionName}, e.Err)
|
|
||||||
}
|
|
||||||
case *fxevent.Run:
|
case *fxevent.Run:
|
||||||
if e.Err != nil {
|
return true, "fx_run_failed", map[string]any{"function": e.Name, "kind": e.Kind}, e.Err
|
||||||
Error("fx_run_failed", "fx", "", map[string]any{"function": e.Name, "kind": e.Kind}, e.Err)
|
|
||||||
}
|
|
||||||
case *fxevent.OnStartExecuted:
|
case *fxevent.OnStartExecuted:
|
||||||
if e.Err != nil {
|
return true, "fx_on_start_failed", map[string]any{"caller": e.CallerName, "function": e.FunctionName, "runtime": e.Runtime}, e.Err
|
||||||
Error("fx_on_start_failed", "fx", "", map[string]any{"caller": e.CallerName, "function": e.FunctionName, "runtime": e.Runtime}, e.Err)
|
|
||||||
}
|
|
||||||
case *fxevent.OnStopExecuted:
|
case *fxevent.OnStopExecuted:
|
||||||
if e.Err != nil {
|
return true, "fx_on_stop_failed", map[string]any{"caller": e.CallerName, "function": e.FunctionName, "runtime": e.Runtime}, e.Err
|
||||||
Error("fx_on_stop_failed", "fx", "", map[string]any{"caller": e.CallerName, "function": e.FunctionName, "runtime": e.Runtime}, e.Err)
|
default:
|
||||||
}
|
return false, "", nil, nil
|
||||||
case *fxevent.Started:
|
}
|
||||||
if e.Err != nil {
|
}
|
||||||
Error("fx_start_failed", "fx", "", nil, e.Err)
|
|
||||||
}
|
func describeFXLifecycleEventError(event fxevent.Event) (string, map[string]any, error) {
|
||||||
case *fxevent.Stopped:
|
switch e := event.(type) {
|
||||||
if e.Err != nil {
|
case *fxevent.Started:
|
||||||
Error("fx_stop_failed", "fx", "", nil, e.Err)
|
return "fx_start_failed", nil, e.Err
|
||||||
}
|
case *fxevent.Stopped:
|
||||||
case *fxevent.RollingBack:
|
return "fx_stop_failed", nil, e.Err
|
||||||
if e.StartErr != nil {
|
case *fxevent.RollingBack:
|
||||||
Error("fx_rollback_start", "fx", "", nil, e.StartErr)
|
return "fx_rollback_start", nil, e.StartErr
|
||||||
}
|
case *fxevent.RolledBack:
|
||||||
case *fxevent.RolledBack:
|
return "fx_rollback_failed", nil, e.Err
|
||||||
if e.Err != nil {
|
default:
|
||||||
Error("fx_rollback_failed", "fx", "", nil, e.Err)
|
return "", nil, nil
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user