⚡ Lightning Network ⚡

Scalare Bitcoin mantenendo la decentralizzazione

Alekos Filini - @afilini

Bitcoin Dev Kit

Introduction

  • Lavoro su bitcoin dal 2017
  • Precedentemente a BHB Network e Blockstream
  • Dal 2020 maintainer di BDK (Bitcoin Dev Kit)
    • Libreria open source in Rust per creare wallet bitcoin
    • Grant annuale da Brink

"Decentralizzazione"

  • Permissionless
  • Nessun single point of failure
  • Zero fiducia
  • Zero censura

 

  • Per garantire la decentralizzazione, il protocollo deve essere accessibile a tutti

"Scaling"

  • Bitcoin attualmente può confermare ~3 tx/s
  • Chiaramente insufficiente per un utilizzo "di massa"
  • Ingrandire i blocchi rende più difficile validare
    • e sostanzialmente non risolve il problema

More
with
Less

  • È possibile ottenere
    • Più trasferimenti bitcoin
    • Meno transazioni Bitcoin
  • Si
    • Esempio: Coinbase
  • È possibile ottenere
    • Più trasferimenti bitcoin
    • Meno transazioni Bitcoin
    • ... mantenedo custodia dei propri BTC
    • ... in modo trustless
  • Si
    • Con i payment channels

Payment Channels

  • Due parti collaborano e bloccano fondi on-chain
  • Le transazioni che rappresentano in ogni momento lo stato del canale vengono tenute off-chain
  • Il canale può essere chiuso in qualunque momento
    • Pubblicando l'ultimo stato

Canali Monodirezionali

  • Alice blocca dei fondi in un 2-of-2 con Bob

Canali Monodirezionali

  • Ad ogni pagamento verso Bob spende dal 2-of-2 e crea due output
    • Uno verso sé stessa
    • Uno verso Bob
  • Firma la transazione e la passa a Bob

Canali Monodirezionali

  • Bob può chiudere il canale in qualunque momento aggiungendo la propria firma
  • È incentivato economicamente a pubblicare l'ultimo stato

Canali Bidirezionali

  • Alice e/o Bob bloccano fondi in un 2-of-2
  • Preparano una transazione con i due output e un timelock nel futuro
  • Si scambiano le firme

Canali Bidirezionali

  • Ad ogni pagamento viene aggiornato il valore dei due output e ridotto il timelock
  • L'ultimo stato può essere confermato prima dei precedenti
  • Il canale va chiuso quando la blockchain raggiunge l'ultimo timelock

Punishment-Based Enforcement

  • Gli output di Alice e Bob contengono in aggiunta una revocation key
    • Scambiata ad ogni aggiornamento di stato
    • Sono reedemable da Alice o Bob dopo alcuni blocchi

Punishment-Based Enforcement

  • Incentivo a pubblicare l'ultimo stato
  • Se Bob provasse a pubblicare uno stato revocato
  • Alice potrebbe spendere entrambi gli output
    • Il proprio con la propria key
    • Quello di Bob con la revocation key

HTLC - Hash Time Locked Contract

  • Condizione di spesa che può essere soddisfatta da una firma in aggiunta a
    • Mostrare la preimage di un hash
    • Oppure aspettare un timelock

Routing

  • Una parte del balance di un canale può essere allocato per il routing di pagamenti
  • Catene di HTLC dal payer al payee
  • Se il pagamento ha successo viene risolto con la preimage
  • Altrimenti può andare in timeout

Routing

  • Quando la catena raggiunge il payee, lui mostra la preimage
  • A catena tutti i pagamenti vengono risolti

⚡ Lightning Network ⚡

Scalare Bitcoin mantenendo la decentralizzazione

Alekos Filini - @afilini

Bitcoin Dev Kit

Lightning Network - rev 2

By Alekos Filini

Lightning Network - rev 2

  • 260