Skip to content

Latest commit

 

History

History
136 lines (107 loc) · 5.17 KB

settlement.mdx

File metadata and controls

136 lines (107 loc) · 5.17 KB

import { Callout, Steps, Tabs } from 'nextra/components'

Settlement

Settlement is the process by which a processor debits funds from a Safenet account to repay the liquidity provider for the short-term loan (pre-funding) used in a Safenet transaction.

The settlement engine handles debit requests on the debit chain by transferring funds from the Safenet Safe to a beneficiary designated by the liquidity provider. This occurs after the liquidity provider has fronted funds on the spend chain.

Once settlement is initiated, a delay period begins, during which validators can verify the settlement's correctness and challenge it if necessary. If no challenge is made during this period, the processor completes the settlement, debiting the Safe and transferring the funds to the beneficiary, which includes repayment of the liquidity provision and relayer fees.

If a validator challenges the settlement, the cross-chain challenge process begins:

Challenge Process

Challenge Initiation

The validator initiates a transaction with the settlement engine to start a challenge on the debit chain, with a separate challenge delay. During this delay, the processor must prove the settlement's correctness.

Correctness Proof

The processor sends an attestation from the spend chain (where the Safenet transaction was executed) to the home chain to validate the settlement.

Challenge Resolution

The processor proves the settlement's validity to the guarantee engine on the home chain, which then informs the settlement contract on the debit chain: * If the settlement is validated, the settlement can proceed immediately, bypassing the remaining settlement delay. * If the processor fails to prove the settlement's validity, the challenge delay expires, and the settlement is deemed invalid, meaning it can never be executed.

When a challenge is successful, the processor or liquidity provider loses the fronted funds, and the user does not pay anything. The user could benefit from the outgoing transaction.

Flow Diagrams

Happy Flow

sequenceDiagram
	box MVP Processor
		actor P as Processor
		actor LP as Liquidity Provider
	end
	actor V as Validator
  participant S as Settlement Engine
	participant A as Account

  P->>S: settle (WITH COLLATERAL Ξ)
  Note over S: Settlement Delay...
  V->>V: check settlement correctness
  Note over S: ...Settlement Delay
  P->>+S: executeSettlement
  A-->>LP: transferFrom(Account, Liquidity Provider)
  deactivate S
Loading

The happy flow diagram illustrates the process of a successful settlement. The processor initiates the settlement process by debiting the Safe and transferring funds to the beneficiary. The validator verifies the settlement's correctness and, if no challenge is made, the settlement is completed.

Sad Flow

sequenceDiagram
	box MVP Processor
		actor P as Processor
		actor LP as Liquidity Provider
	end
	actor V as Validator
	box rgb(255,165,0,0.2)
		participant G as Guarantee Engine<br>(HOME CHAIN)
	end
	participant B as Bridge
  participant S as Settlement Engine
	participant A as Account

  P->>S: settle
	Note over S: Settlement Delay...
  V->>V: check settlement correctness
  
  opt Incorrect Settlement
	  V->>S: challenge (WITH COLLATERAL Ξ)
	end
  
  alt Correctness Proven
    G-->>+B: correctnessProven
	  B->>S: correctnessProven
    A-->>LP: transferFrom(Account, Liquidity Provider)
    deactivate B
  else
	  Note over S: ...Settlement Delay
	  P-->>P: punished: loses fronted funds
  end
Loading

The sad flow diagram illustrates the process of a failed settlement. The validator challenges the settlement, and the processor must prove the settlement's validity. If the processor fails to provide proof, the settlement is deemed invalid, and the funds are not transferred.

Correctness Proof (Attestation)

sequenceDiagram
	box MVP Processor
		actor P as Processor
	end
	box rgb(255,165,0,0.2)
		participant E as Entry Point<br>(SPEND CHAIN)
		participant S as Settlement Engine<br>(DEBIT CHAIN)
	end
	participant TS as Transceiver<br>for Spend Chain
	participant TD as Transceiver<br>for Debit Chain
	participant G as Guarantee Engine
	participant G1 as Guarantee 1...
	participant GN as ...Guarantee N
  
  P->>+E: sendReceipt()
  E-->>+TS: receipt
  deactivate E
  TS->>G: safenetReceipt()
  deactivate TS
    
  P->>+G: prove()
  G->>G1: checkGuarantee()
  G->>GN: checkGuarantee()
  G->>-TD: correctnessProven()
  TD-->>S: correctnessProven
Loading

The correctness proof diagram illustrates the process of proving the settlement's validity. The processor sends information from the spend chain to the home chain, where the guarantee engine validates the settlement. If the settlement is proven correct, the settlement can proceed immediately.

The processor can voluntarily provide the attestation at the moment of settlement to bypass the challenge delay and ensure a faster settlement process.