funding: abandon usage of Code field in lnwire.Error
This commit modifies the generation and parsing of errors to abandon usage of the Code field, and instead use the first byte of the Data field to store the error codes that we currently use. With this change, we ensure that our error messages properly match BOLT-0002.
This commit is contained in:
parent
01b0ddf1c5
commit
8f25a73332
@ -635,8 +635,7 @@ func (f *fundingManager) handleFundingOpen(fmsg *fundingOpenMsg) {
|
|||||||
if len(f.activeReservations[peerIDKey]) >= cfg.MaxPendingChannels {
|
if len(f.activeReservations[peerIDKey]) >= cfg.MaxPendingChannels {
|
||||||
errMsg := &lnwire.Error{
|
errMsg := &lnwire.Error{
|
||||||
ChanID: fmsg.msg.PendingChannelID,
|
ChanID: fmsg.msg.PendingChannelID,
|
||||||
Code: lnwire.ErrMaxPendingChannels,
|
Data: lnwire.ErrorData{byte(lnwire.ErrMaxPendingChannels)},
|
||||||
Data: []byte("Number of pending channels exceed maximum"),
|
|
||||||
}
|
}
|
||||||
if err := f.cfg.SendToPeer(fmsg.peerAddress.IdentityKey, errMsg); err != nil {
|
if err := f.cfg.SendToPeer(fmsg.peerAddress.IdentityKey, errMsg); err != nil {
|
||||||
fndgLog.Errorf("unable to send max pending channels "+
|
fndgLog.Errorf("unable to send max pending channels "+
|
||||||
@ -658,8 +657,7 @@ func (f *fundingManager) handleFundingOpen(fmsg *fundingOpenMsg) {
|
|||||||
if !isSynced {
|
if !isSynced {
|
||||||
errMsg := &lnwire.Error{
|
errMsg := &lnwire.Error{
|
||||||
ChanID: fmsg.msg.PendingChannelID,
|
ChanID: fmsg.msg.PendingChannelID,
|
||||||
Code: lnwire.ErrSynchronizingChain,
|
Data: lnwire.ErrorData{byte(lnwire.ErrSynchronizingChain)},
|
||||||
Data: []byte("Synchronizing blockchain"),
|
|
||||||
}
|
}
|
||||||
if err := f.cfg.SendToPeer(fmsg.peerAddress.IdentityKey, errMsg); err != nil {
|
if err := f.cfg.SendToPeer(fmsg.peerAddress.IdentityKey, errMsg); err != nil {
|
||||||
fndgLog.Errorf("unable to send error message to peer %v", err)
|
fndgLog.Errorf("unable to send error message to peer %v", err)
|
||||||
@ -673,7 +671,7 @@ func (f *fundingManager) handleFundingOpen(fmsg *fundingOpenMsg) {
|
|||||||
if msg.FundingAmount > maxFundingAmount {
|
if msg.FundingAmount > maxFundingAmount {
|
||||||
errMsg := &lnwire.Error{
|
errMsg := &lnwire.Error{
|
||||||
ChanID: fmsg.msg.PendingChannelID,
|
ChanID: fmsg.msg.PendingChannelID,
|
||||||
Data: []byte("channel too large"),
|
Data: lnwire.ErrorData{byte(lnwire.ErrChanTooLarge)},
|
||||||
}
|
}
|
||||||
err := f.cfg.SendToPeer(fmsg.peerAddress.IdentityKey, errMsg)
|
err := f.cfg.SendToPeer(fmsg.peerAddress.IdentityKey, errMsg)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -1892,7 +1890,8 @@ func (f *fundingManager) processFundingError(err *lnwire.Error,
|
|||||||
func (f *fundingManager) handleErrorMsg(fmsg *fundingErrorMsg) {
|
func (f *fundingManager) handleErrorMsg(fmsg *fundingErrorMsg) {
|
||||||
e := fmsg.err
|
e := fmsg.err
|
||||||
|
|
||||||
switch e.Code {
|
lnErr := lnwire.ErrorCode(e.Data[0])
|
||||||
|
switch lnErr {
|
||||||
case lnwire.ErrChanTooLarge:
|
case lnwire.ErrChanTooLarge:
|
||||||
fallthrough
|
fallthrough
|
||||||
case lnwire.ErrMaxPendingChannels:
|
case lnwire.ErrMaxPendingChannels:
|
||||||
@ -1908,16 +1907,14 @@ func (f *fundingManager) handleErrorMsg(fmsg *fundingErrorMsg) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fndgLog.Errorf("Received funding error from %x: %v",
|
fndgLog.Errorf("Received funding error from %x: %v",
|
||||||
peerKey.SerializeCompressed(), newLogClosure(func() string {
|
peerKey.SerializeCompressed(), lnErr,
|
||||||
return spew.Sdump(e)
|
|
||||||
}),
|
|
||||||
)
|
)
|
||||||
|
|
||||||
ctx.err <- grpc.Errorf(e.Code.ToGrpcCode(), string(e.Data))
|
ctx.err <- grpc.Errorf(lnErr.ToGrpcCode(), lnErr.String())
|
||||||
return
|
return
|
||||||
|
|
||||||
default:
|
default:
|
||||||
fndgLog.Warnf("unknown funding error (%v:%v)", e.Code, e.Data)
|
fndgLog.Warnf("unknown funding error: %v", spew.Sdump(e.Data))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user