htlcswitch/circuit_map: relax circuit deletion

Previously, we would only allow deletion of circuits if all circuit keys
were found in the pending map.

In this commit, we relax this to allow for deletion of any circuits
that are found pending, and ignore those that are not found. This
is a preliminary step to cleaning up duplicate forwards that get caught
by the switch. It also allows us to gracefully handle any nodes that
are still afflicted by the split mailbox issue.
This commit is contained in:
Conner Fromknecht 2018-07-27 02:25:37 -07:00
parent 0372bf9319
commit c2055d4a9e
No known key found for this signature in database
GPG Key ID: E7D737B67FA592C7

@ -770,10 +770,12 @@ func (cm *circuitMap) CloseCircuit(outKey CircuitKey) (*PaymentCircuit, error) {
return circuit, nil return circuit, nil
} }
// DeleteCircuits destroys the target circuit by removing it from the circuit map, // DeleteCircuits destroys the target circuits by removing them from the circuit
// additionally removing the circuit's keystone if the HTLC was forwarded // map, additionally removing the circuits' keystones if any HTLCs were
// through an outgoing link. The circuit should be identified by its incoming // forwarded through an outgoing link. The circuits should be identified by its
// circuit key. // incoming circuit key. If a given circuit is not found in the circuit map, it
// will be ignored from the query. This would typically indicate that the
// circuit was already cleaned up at a different point in time.
func (cm *circuitMap) DeleteCircuits(inKeys ...CircuitKey) error { func (cm *circuitMap) DeleteCircuits(inKeys ...CircuitKey) error {
log.Tracef("Deleting resolved circuits: %v", newLogClosure(func() string { log.Tracef("Deleting resolved circuits: %v", newLogClosure(func() string {
@ -786,22 +788,15 @@ func (cm *circuitMap) DeleteCircuits(inKeys ...CircuitKey) error {
) )
cm.mtx.Lock() cm.mtx.Lock()
// First check that all provided keys are still known to the circuit // Remove any references to the circuits from memory, keeping track of
// map. // which circuits were removed, and which ones had been marked closed.
// This can be used to restore these entries later if the persistent
// removal fails.
for _, inKey := range inKeys { for _, inKey := range inKeys {
if _, ok := cm.pending[inKey]; !ok { circuit, ok := cm.pending[inKey]
cm.mtx.Unlock() if !ok {
return ErrUnknownCircuit continue
} }
}
// If no offenders were found, remove any references to the circuit from
// memory, keeping track of which circuits were removed, and which ones
// had been marked closed. This can be used to restore these entries
// later if the persistent removal fails.
for _, inKey := range inKeys {
circuit := cm.pending[inKey]
delete(cm.pending, inKey) delete(cm.pending, inKey)
if _, ok := cm.closed[inKey]; ok { if _, ok := cm.closed[inKey]; ok {