From 7e4494256a08f585523e01b1bbc51f41ff4e2b95 Mon Sep 17 00:00:00 2001 From: jwijenbergh Date: Mon, 26 Sep 2022 14:50:22 +0200 Subject: Refactor: Errors into custom export types and expose types --- types/error.go | 82 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 types/error.go (limited to 'types/error.go') diff --git a/types/error.go b/types/error.go new file mode 100644 index 0000000..607e6c6 --- /dev/null +++ b/types/error.go @@ -0,0 +1,82 @@ +package types + +import ( + "errors" + "fmt" +) + +type ErrorLevel int8 + +const ( + // All other errors + ERR_OTHER ErrorLevel = iota + + // The error is just here as additional info + ERR_INFO +) + +type WrappedErrorMessage struct { + Level ErrorLevel + Message string + Err error +} + +func (e *WrappedErrorMessage) Unwrap() error { + return e.Err +} + +func (e *WrappedErrorMessage) Cause() error { + causeErr := e.Err + for errors.Unwrap(causeErr) != nil { + causeErr = errors.Unwrap(causeErr) + } + return causeErr +} + +func (e *WrappedErrorMessage) Traceback() string { + returnStr := fmt.Sprintf("%s\n%s", e.Message, "Traceback:") + causeErr := e.Err + for errors.Unwrap(causeErr) != nil { + causeErr = errors.Unwrap(causeErr) + var wrappedErr *WrappedErrorMessage + + errorStr := causeErr.Error() + + if errors.As(causeErr, &wrappedErr) { + errorStr = wrappedErr.Message + } + returnStr += fmt.Sprintf("\n - %s", errorStr) + } + return returnStr +} + +func (e *WrappedErrorMessage) Error() string { + return fmt.Sprintf("Got error: %s, with cause: %s", e.Message, e.Err) +} + +func GetErrorTraceback(err error) string { + var wrappedErr *WrappedErrorMessage + + if errors.As(err, &wrappedErr) { + return wrappedErr.Traceback() + } + return err.Error() +} + +func GetErrorCause(err error) error { + var wrappedErr *WrappedErrorMessage + + if errors.As(err, &wrappedErr) { + return wrappedErr.Cause() + } + return err +} + +func GetErrorLevel(err error) ErrorLevel { + var wrappedErr *WrappedErrorMessage + + if errors.As(err, &wrappedErr) { + return wrappedErr.Level + } + return ERR_OTHER +} -- cgit v1.2.3