From 0dda9e06ce5ed8cec78928435f2d6a4f09dca47b Mon Sep 17 00:00:00 2001 From: nsa Date: Fri, 26 Jun 2020 21:04:15 -0400 Subject: [PATCH] multi: exporting PendingUpdate, ChannelCloseUpdate, ErrorBufferSize --- peer.go | 32 ++++++++++++++++---------------- rpcserver.go | 18 +++++++++--------- server.go | 2 +- 3 files changed, 26 insertions(+), 26 deletions(-) diff --git a/peer.go b/peer.go index efe58fcd..fba338c5 100644 --- a/peer.go +++ b/peer.go @@ -58,8 +58,8 @@ const ( // this struct. outgoingQueueLen = 50 - // errorBufferSize is the number of historic peer errors that we store. - errorBufferSize = 10 + // ErrorBufferSize is the number of historic peer errors that we store. + ErrorBufferSize = 10 ) // outgoingMsg packages an lnwire.Message to be sent out on the wire, along with @@ -87,23 +87,23 @@ type closeMsg struct { msg lnwire.Message } -// pendingUpdate describes the pending state of a closing channel. -type pendingUpdate struct { +// PendingUpdate describes the pending state of a closing channel. +type PendingUpdate struct { Txid []byte OutputIndex uint32 } -// channelCloseUpdate contains the outcome of the close channel operation. -type channelCloseUpdate struct { +// ChannelCloseUpdate contains the outcome of the close channel operation. +type ChannelCloseUpdate struct { ClosingTxid []byte Success bool } -// timestampedError is a timestamped error that is used to store the most recent +// TimestampedError is a timestamped error that is used to store the most recent // errors we have experienced with our peers. -type timestampedError struct { - error error - timestamp time.Time +type TimestampedError struct { + Error error + Timestamp time.Time } // peer is an active peer on the Lightning Network. This struct is responsible @@ -1347,7 +1347,7 @@ func (p *peer) storeError(err error) { } p.errorBuffer.Add( - ×tampedError{timestamp: time.Now(), error: err}, + &TimestampedError{Timestamp: time.Now(), Error: err}, ) } @@ -2562,18 +2562,18 @@ func (p *peer) finalizeChanClosure(chanCloser *chancloser.ChanCloser) { // If this is a locally requested shutdown, update the caller with a // new event detailing the current pending state of this request. if closeReq != nil { - closeReq.Updates <- &pendingUpdate{ + closeReq.Updates <- &PendingUpdate{ Txid: closingTxid[:], } } - go waitForChanToClose(chanCloser.NegotiationHeight(), notifier, errChan, + go WaitForChanToClose(chanCloser.NegotiationHeight(), notifier, errChan, chanPoint, &closingTxid, closingTx.TxOut[0].PkScript, func() { // Respond to the local subsystem which requested the // channel closure. if closeReq != nil { - closeReq.Updates <- &channelCloseUpdate{ + closeReq.Updates <- &ChannelCloseUpdate{ ClosingTxid: closingTxid[:], Success: true, } @@ -2581,12 +2581,12 @@ func (p *peer) finalizeChanClosure(chanCloser *chancloser.ChanCloser) { }) } -// waitForChanToClose uses the passed notifier to wait until the channel has +// WaitForChanToClose uses the passed notifier to wait until the channel has // been detected as closed on chain and then concludes by executing the // following actions: the channel point will be sent over the settleChan, and // finally the callback will be executed. If any error is encountered within // the function, then it will be sent over the errChan. -func waitForChanToClose(bestHeight uint32, notifier chainntnfs.ChainNotifier, +func WaitForChanToClose(bestHeight uint32, notifier chainntnfs.ChainNotifier, errChan chan error, chanPoint *wire.OutPoint, closingTxID *chainhash.Hash, closeScript []byte, cb func()) { diff --git a/rpcserver.go b/rpcserver.go index 2b161f7b..8adef137 100644 --- a/rpcserver.go +++ b/rpcserver.go @@ -2105,17 +2105,17 @@ func (r *rpcServer) CloseChannel(in *lnrpc.CloseChannelRequest, // With the transaction broadcast, we send our first update to // the client. updateChan = make(chan interface{}, 2) - updateChan <- &pendingUpdate{ + updateChan <- &PendingUpdate{ Txid: closingTxid[:], } errChan = make(chan error, 1) notifier := r.server.cc.chainNotifier - go waitForChanToClose(uint32(bestHeight), notifier, errChan, chanPoint, + go WaitForChanToClose(uint32(bestHeight), notifier, errChan, chanPoint, &closingTxid, closingTx.TxOut[0].PkScript, func() { // Respond to the local subsystem which // requested the channel closure. - updateChan <- &channelCloseUpdate{ + updateChan <- &ChannelCloseUpdate{ ClosingTxid: closingTxid[:], Success: true, } @@ -2228,7 +2228,7 @@ out: // then we can break out of our dispatch loop as we no // longer need to process any further updates. switch closeUpdate := closingUpdate.(type) { - case *channelCloseUpdate: + case *ChannelCloseUpdate: h, _ := chainhash.NewHash(closeUpdate.ClosingTxid) rpcsLog.Infof("[closechannel] close completed: "+ "txid(%v)", h) @@ -2246,7 +2246,7 @@ func createRPCCloseUpdate(update interface{}) ( *lnrpc.CloseStatusUpdate, error) { switch u := update.(type) { - case *channelCloseUpdate: + case *ChannelCloseUpdate: return &lnrpc.CloseStatusUpdate{ Update: &lnrpc.CloseStatusUpdate_ChanClose{ ChanClose: &lnrpc.ChannelCloseUpdate{ @@ -2254,7 +2254,7 @@ func createRPCCloseUpdate(update interface{}) ( }, }, }, nil - case *pendingUpdate: + case *PendingUpdate: return &lnrpc.CloseStatusUpdate{ Update: &lnrpc.CloseStatusUpdate_ClosePending{ ClosePending: &lnrpc.PendingUpdate{ @@ -2601,11 +2601,11 @@ func (r *rpcServer) ListPeers(ctx context.Context, // Add the relevant peer errors to our response. for _, error := range peerErrors { - tsError := error.(*timestampedError) + tsError := error.(*TimestampedError) rpcErr := &lnrpc.TimestampedError{ - Timestamp: uint64(tsError.timestamp.Unix()), - Error: tsError.error.Error(), + Timestamp: uint64(tsError.Timestamp.Unix()), + Error: tsError.Error.Error(), } peer.Errors = append(peer.Errors, rpcErr) diff --git a/server.go b/server.go index f53f4170..f3ac2201 100644 --- a/server.go +++ b/server.go @@ -2792,7 +2792,7 @@ func (s *server) peerConnected(conn net.Conn, connReq *connmgr.ConnReq, errBuffer, ok := s.peerErrors[pkStr] if !ok { var err error - errBuffer, err = queue.NewCircularBuffer(errorBufferSize) + errBuffer, err = queue.NewCircularBuffer(ErrorBufferSize) if err != nil { srvrLog.Errorf("unable to create peer %v", err) return