htlcswitch: replace outgoing failure with interface
Add a FailureDetail interface which allows us have different kinds of failures for link errors. This interface will be used to cover failures that occur when on invoice payment, because the errors have already been enumerated in the invoices package.
This commit is contained in:
parent
bdd9411bbd
commit
9390d3bbfd
@ -34,8 +34,8 @@ type LinkError struct {
|
||||
// node.
|
||||
msg lnwire.FailureMessage
|
||||
|
||||
// OutgoingFailure enriches the wire error with additional information.
|
||||
OutgoingFailure
|
||||
// FailureDetail enriches the wire error with additional information.
|
||||
FailureDetail
|
||||
}
|
||||
|
||||
// NewLinkError returns a LinkError with the failure message provided.
|
||||
@ -48,11 +48,11 @@ func NewLinkError(msg lnwire.FailureMessage) *LinkError {
|
||||
// NewDetailedLinkError returns a link error that enriches a wire message with
|
||||
// a failure detail.
|
||||
func NewDetailedLinkError(msg lnwire.FailureMessage,
|
||||
detail OutgoingFailure) *LinkError {
|
||||
detail FailureDetail) *LinkError {
|
||||
|
||||
return &LinkError{
|
||||
msg: msg,
|
||||
OutgoingFailure: detail,
|
||||
FailureDetail: detail,
|
||||
}
|
||||
}
|
||||
|
||||
@ -72,11 +72,11 @@ func (l *LinkError) WireMessage() lnwire.FailureMessage {
|
||||
func (l *LinkError) Error() string {
|
||||
// If the link error has no failure detail, return the wire message's
|
||||
// error.
|
||||
if l.OutgoingFailure == OutgoingFailureNone {
|
||||
if l.FailureDetail == nil {
|
||||
return l.msg.Error()
|
||||
}
|
||||
|
||||
return fmt.Sprintf("%v: %v", l.msg.Error(), l.OutgoingFailure)
|
||||
return fmt.Sprintf("%v: %v", l.msg.Error(), l.FailureDetail)
|
||||
}
|
||||
|
||||
// ForwardingError wraps an lnwire.FailureMessage in a struct that also
|
||||
|
@ -1,5 +1,13 @@
|
||||
package htlcswitch
|
||||
|
||||
// FailureDetail is an interface implemented by failures that occur on
|
||||
// our incoming or outgoing link, or within the switch itself.
|
||||
type FailureDetail interface {
|
||||
// FailureString returns the string representation of a failure
|
||||
// detail.
|
||||
FailureString() string
|
||||
}
|
||||
|
||||
// OutgoingFailure is an enum which is used to enrich failures which occur in
|
||||
// the switch or on our outgoing link with additional metadata.
|
||||
type OutgoingFailure int
|
||||
@ -36,8 +44,10 @@ const (
|
||||
OutgoingFailureCircularRoute
|
||||
)
|
||||
|
||||
// String returns the string representation of a failure detail.
|
||||
func (fd OutgoingFailure) String() string {
|
||||
// FailureString returns the string representation of a failure detail.
|
||||
//
|
||||
// Note: it is part of the FailureDetail interface.
|
||||
func (fd OutgoingFailure) FailureString() string {
|
||||
switch fd {
|
||||
case OutgoingFailureNone:
|
||||
return "no failure detail"
|
||||
|
@ -923,8 +923,8 @@ func (s *Switch) parseFailedPayment(deobfuscator ErrorDecrypter,
|
||||
)
|
||||
|
||||
log.Errorf("%v: (hash=%v, pid=%d): %v",
|
||||
linkError.OutgoingFailure, paymentHash, paymentID,
|
||||
err)
|
||||
linkError.FailureDetail.FailureString(),
|
||||
paymentHash, paymentID, err)
|
||||
|
||||
return linkError
|
||||
}
|
||||
@ -942,7 +942,8 @@ func (s *Switch) parseFailedPayment(deobfuscator ErrorDecrypter,
|
||||
OutgoingFailureOnChainTimeout,
|
||||
)
|
||||
|
||||
log.Info("%v: hash=%v, pid=%d", linkError.OutgoingFailure,
|
||||
log.Info("%v: hash=%v, pid=%d",
|
||||
linkError.FailureDetail.FailureString(),
|
||||
paymentHash, paymentID)
|
||||
|
||||
return linkError
|
||||
|
Loading…
Reference in New Issue
Block a user