Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[epic]: Payment and Router separation #8834

Open
2 tasks
yyforyongyu opened this issue Jun 13, 2024 · 0 comments
Open
2 tasks

[epic]: Payment and Router separation #8834

yyforyongyu opened this issue Jun 13, 2024 · 0 comments
Labels
advanced Issues suitable for very experienced developers architecture Related to system design bug fix enhancement Improvements to existing features / behaviour epic Issues created to track large feature development payments Related to invoices/payments routing

Comments

@yyforyongyu
Copy link
Member

paymentLifecyle is the main struct to handle sending payments and can be moved out of routing package, which has the benefits,

  • indepedent package is easier to analyze/maintain, e.g., we can easily increase logging verbosity for this subservice.
  • fixed an interface violation which can cause a race condition when sending HTLCs.

Current State

As of today, multiple components are involved when sending payments, as shown below,

flowchart LR
		pay_req-->paymentLifecycle
		
		subgraph paymentLifecycle
	    p[resumePayment]
    end
    
    subgraph PaymentSession
	    RequestRoute-->p
	    p-->UpdateAdditionalEdge
	    p-->GetAdditionalEdgePolicy
    end
    
    subgraph MissionControl
      p-->ReportPaymentSuccess
      p-->ReportPaymentFailure
    end
    
    subgraph PaymentAttemptDispatcher
    	p-->SendHTLC
    	GetAttemptResult-->p
    end
    
    subgraph ControlTower
    	crud[DB operations]-->p
    	FetchPayment
    	FailPayment
    	more[...]
    end
    
    subgraph ChannelRouter
        p--->ChannelRouter.applyChannelUpdate
    end
Loading

The components are,

  • ControlTower: handles interaction with DB(CRUD)
  • MissionControl: records success probablity
  • PaymentSession(paymentSession): requests routes and updates edges/policies from private channels
  • PaymentAttemptDispatcher: interacts with Switch to send HTLC and get HTLC attempt results, which is an interface violation.
  • ChannelRouter.applyChannelUpdate: updates edges using failed HTLCs

Proposed Design

The proposed architecture,

flowchart LR
    pay_req-->paymentLifecycle
    
    subgraph paymentLifecycle
      p[resumePayment]
      ct
    end

    subgraph ct[ControlTower]
      crud[DB operations]
      FetchPayment
      FailPayment
      more[...]
    end
    
    subgraph cg[ChannelRouter]
      p-->sa[SendAttempt]
      ps
      mc
      pad
    end
    
    subgraph ps[PaymentSession]
      RequestRoute
      UpdateAdditionalEdge
      GetAdditionalEdgePolicy
    end
    
    subgraph mc[MissionControl]
      ReportPaymentSuccess
      ReportPaymentFailure
    end
    
    subgraph pad[PaymentAttemptDispatcher]
      SendHTLC
      GetHTLCResult
    end
Loading

Some highlights,

  • Payment lifecycle is in its own package (payment) and interacts with the third layer ChannelRouter.
  • The only interface method used by paymentLifecycle is ChannelRouter.SendAttempt, which takes an attempt request specifying params like routes, onions, amt, etc.
  • "HTLC" is a concept used in htlcswitch (layer-two), and "HTLC attempt" or "Attempt" (or other better names?) is a concept used in routing (layer-three).

By adding SendAttempt, htlcswitch is no longer exposed to paymentLifecycle. Instead, an HTLC attempt always goes through the graph managed by ChannelRouter first, and it's up to ChannelRouter to decide whether a route can be used or not, which solves the race condition when two HTLC attempts are using the same route without being aware of each other, as manifested in itest flakes.

Plan

  • Create a new package and move paymentLifecycle out of routing.
  • Add interface method SendAttempt, implement it in routing and use it in paymentLifecycle.
@yyforyongyu yyforyongyu added enhancement Improvements to existing features / behaviour advanced Issues suitable for very experienced developers routing payments Related to invoices/payments bug fix architecture Related to system design labels Jun 13, 2024
@saubyk saubyk added the epic Issues created to track large feature development label Jun 13, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
advanced Issues suitable for very experienced developers architecture Related to system design bug fix enhancement Improvements to existing features / behaviour epic Issues created to track large feature development payments Related to invoices/payments routing
Projects
None yet
Development

No branches or pull requests

2 participants