package status import ( "errors" "fmt" "time" ) const ( // UserAlreadyExists indicates that user already exists UserAlreadyExists Type = 1 // PreconditionFailed indicates that some pre-condition for the operation hasn't been fulfilled PreconditionFailed Type = 2 // PermissionDenied indicates that user has no permissions to view data PermissionDenied Type = 3 // NotFound indicates that the object wasn't found in the system (or under a given Account) NotFound Type = 4 // Internal indicates some generic internal error Internal Type = 5 // InvalidArgument indicates some generic invalid argument error InvalidArgument Type = 6 // AlreadyExists indicates a generic error when an object already exists in the system AlreadyExists Type = 7 // Unauthorized indicates that user is not authorized Unauthorized Type = 8 // BadRequest indicates that user is not authorized BadRequest Type = 9 // Unauthenticated indicates that user is not authenticated due to absence of valid credentials Unauthenticated Type = 10 ) // Type is a type of the Error type Type int32 // Error is an internal error type Error struct { ErrorType Type Message string } // Type returns the Type of the error func (e *Error) Type() Type { return e.ErrorType } // Error is an error string func (e *Error) Error() string { return e.Message } // Errorf returns Error(ErrorType, fmt.Sprintf(format, a...)). func Errorf(errorType Type, format string, a ...interface{}) error { return &Error{ ErrorType: errorType, Message: fmt.Sprintf(format, a...), } } // FromError returns Error, true if the provided error is of type of Error. nil, false otherwise func FromError(err error) (s *Error, ok bool) { if err == nil { return nil, true } var e *Error if errors.As(err, &e) { return e, true } return nil, false } // NewPeerNotFoundError creates a new Error with NotFound type for a missing peer func NewPeerNotFoundError(peerKey string) error { return Errorf(NotFound, "peer not found: %s", peerKey) } // NewAccountNotFoundError creates a new Error with NotFound type for a missing account func NewAccountNotFoundError(accountKey string) error { return Errorf(NotFound, "account not found: %s", accountKey) } // NewUserNotFoundError creates a new Error with NotFound type for a missing user func NewUserNotFoundError(userKey string) error { return Errorf(NotFound, "user not found: %s", userKey) } // NewPeerNotRegisteredError creates a new Error with NotFound type for a missing peer func NewPeerNotRegisteredError() error { return Errorf(Unauthenticated, "peer is not registered") } // NewPeerLoginExpiredError creates a new Error with PermissionDenied type for an expired peer func NewPeerLoginExpiredError() error { return Errorf(PermissionDenied, "peer login has expired, please log in once more") } // NewSetupKeyNotFoundError creates a new Error with NotFound type for a missing setup key func NewSetupKeyNotFoundError(setupKeyID string) error { return Errorf(NotFound, "setup key: %s not found", setupKeyID) } func NewGetAccountFromStoreError(err error) error { return Errorf(Internal, "issue getting account from store: %s", err) } // NewUserNotPartOfAccountError creates a new Error with PermissionDenied type for a user not being part of an account func NewUserNotPartOfAccountError() error { return Errorf(PermissionDenied, "user is not part of this account") } // NewGetUserFromStoreError creates a new Error with Internal type for an issue getting user from store func NewGetUserFromStoreError() error { return Errorf(Internal, "issue getting user from store") } // NewAdminPermissionError creates a new Error with PermissionDenied type for actions requiring admin role. func NewAdminPermissionError() error { return Errorf(PermissionDenied, "admin role required to perform this action") } // NewStoreContextCanceledError creates a new Error with Internal type for a canceled store context func NewStoreContextCanceledError(duration time.Duration) error { return Errorf(Internal, "store access: context canceled after %v", duration) } // NewInvalidKeyIDError creates a new Error with InvalidArgument type for an issue getting a setup key func NewInvalidKeyIDError() error { return Errorf(InvalidArgument, "invalid key ID") } // NewGetAccountError creates a new Error with Internal type for an issue getting account func NewGetAccountError(err error) error { return Errorf(Internal, "error getting account: %s", err) }