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:
Olaoluwa Osuntokun 2017-08-21 23:30:01 -07:00
parent 01b0ddf1c5
commit 8f25a73332
No known key found for this signature in database
GPG Key ID: 9CC5B105D03521A2

@ -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))
} }
} }