Skip to content
/ errors Public

The errors package provides an enterprise approach of error handling.

License

Notifications You must be signed in to change notification settings

axkit/errors

Repository files navigation

errors

Build Status Go Report Card GoDoc Coverage Status

The errors package provides an enterprise approach of error handling.

In large and complex applications, each error typically has a unique code. Using this code, you can find in the documentation the possible causes of the error and the ways to resolve it. This package allows you to define a list of errors with specific attributes: error code, message text, corresponding HTTP status code, and severity level.

Example:

var ErrInvalidCustomerID = errors.New("invalid customer id").
    StatusCode(400).
    Code("ERR-0199").
    Severity(errors.Medium)

With a unique error code, we can direct the user to the page https://mysomeservice.com/content/errors/ERR-0199 where the causes of the error and methods for resolving it will be described in detail, if necessary.

Any predefined error is instantiated and transformed into an Error object when the Raise method is invoked. Additionally, key-value pairs can be attached to the error, which can be viewed by the administrator in the logs, all predefined attributes cab be reassigned.

    // type request struct {
	//		SessionID int 
	//		CustomerID int 
	// 		CustomerFirstName string  
	// }

	if request.CustomerID <= 0 {
		return ErrInvalidCustomerID.Raise().
			Set("sessionId", request.SessionID).
			Severity(errors.Critical)
	}

About

The errors package provides an enterprise approach of error handling.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages