coin secure&and&anonymous& decentralized&bitcoin&mixing& … · roman...

28
Secure and Anonymous Decentralized Bitcoin Mixing Jan Henrik Ziegeldorf, Roman Matzu7, Fred Grossmann, Mar;n Henze, Klaus Wehrle Communica;on and Distributed Systems (COMSYS), RWTH Aachen, Germany www.comsys.rwthaachen.de COIN PARTY

Upload: others

Post on 15-Aug-2020

4 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

Secure  and  Anonymous  Decentralized  Bitcoin  Mixing  

Jan  Henrik  Ziegeldorf,  Roman  Matzu7,  Fred  Grossmann,  Mar;n  Henze,  Klaus  Wehrle  Communica;on  and  Distributed  Systems  (COMSYS),  RWTH  Aachen,  Germany                        

www.comsys.rwth-­‐aachen.de  

COIN

PARTY

Page 2: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

2 Roman Matzutt 2

Bitcoin  in  a  nutshell  

Bitcoin:  A  decentralized  crypto-­‐currency.  

TRANSACTIONS  Signed  transfers  between  Bitcoin  addresses.    

BLOCKCHAIN  A  shared  public  ledger  of  all  accepted    transac;ons  to  keep  balances.  Rules  out,  e.g.,  double  spending.    

TX:  Alice  to  Bob  

P2P  WORKER  POOL  Proof  of  work  to  ensure  correctness.  

BLK1   BLK2   BLK3   BLK4   BLK5  

From:  Alice  

To:  Bob  

Signed:  Alice  

Page 3: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

3 Roman Matzutt 3

The  Bitcoin  Hype  Cycle  

Inflated  expectaNons  

Disillusionment  

Technology  trigger  

Slope  of  enlightenment  

Page 4: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

4 Roman Matzutt 4

Is  it  used  at  all?  

Page 5: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

5 Roman Matzutt 5

Pro’s  and  Con’s  

Why  is  Bitcoin  used?  

•  Investment  (a  really  bad  one)  •  Fast  (and  simple)  •  More  secure  (in  a  way)  •  Cool  &  hip  •  …    

           vs.    •  Scams,  crime,  the\  •  Vola;lity  •  Low  adop;on  •  …  

Because  it  offers  …        

 

ANONYMITY  /  FINANCIAL  PRIVACY  

   

(No,  it  doesn’t)    

Page 6: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

6 Roman Matzutt 6

Downfall  of  Silkroad  

Page 7: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

7 Roman Matzutt 7

Financial  Privacy  in  Bitcoin  

vs  

PSEUDONYMITY  

Virtually  unlimited  amount  of  addresses.    

DE-­‐ANONYMISATION  

Blockchain  taint  analysis  +  side  channels.  

Input: QWxpY2U Output: Qm9iYnk Value: 0.2 BTC

Input: Alice Output: Bob Value: 0.2 BTC

How to re-establish Bitcoin’s broken promise of financial privacy?

Page 8: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

8 Roman Matzutt 8

Bitcoin  Mixing  by  Example  

Alice  

Bob  

Charlie  

Page 9: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

9 Roman Matzutt 9

Bitcoin  Mixing  by  Example  

Alice  

Bob  

Charlie  

AnonymisaNon  

Page 10: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

10 Roman Matzutt 10

1st  Gen:  Centralized  mixing  /  eWallets  /  Improvements  

Mixing  Service                      

Bitcoin  Pool                

,  O1  Alice  

,  O2  Bob  

,  O3  Charlie  

,  O4  Danny   O4  

O3  

O2  

O1  

IdenNfied    users  

Anonymous    recipients  

•  Pros:  Easy  to  use,  scalable,  big    anonymity  sets  •  Cons:  TTP  is  single  point  of  failure,  involved  mixing  &  Transac;on  fees  •  Improvements:  Mixcoin,  BlindCoin  

Page 11: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

11 Roman Matzutt 11

Decentralized  Mixing  Service  

Anonymous    recipients  

2nd  Gen:  Decentralized  Mixing  (CoinJoin,  CoinShuffle,  …)  

•  E.g.  CoinJoin,  CoinShuffle  (implemented  in  NXTcoin?),  XIM  •  Pros:  Secure,  anonymity  against  insiders,  no  TTP,  no  SPoF  •  Cons:  Small  anonymity  sets,  no  deniability,  (scalability)  

Group  TransacNon                        

I4  

I3  

I2  

I1  

O2  

O4  

O1  

O3  Alice  

Bob  

Charlie  

Danny  

IdenNfied    users  

Page 12: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

12 Roman Matzutt 12

Desiderata  

Requirements  for  an  ideal  mixing  service  

COST  EFFICIENCY  No  mixing  fees.  Minimal  transac;on  fees.  

SECURITY  No  the\,  double  spending  or  loss  of  funds.  No  DoS.  

ANONYMITY  Anonymous  against  in-­‐  and  outsiders.    Big  anonymity  sets.  Unbiased  randomness.  

DENIABILITY  Means  of  plausible  deniability.    No  cryptographic  evidence.  

SCALABILITY  Large  numbers  of  users.    Low  impact  on  Bitcoin  network.  

APPLICABILITY  &  USABILITY  Compa;ble  with  Bitcoin  network.    No  addi;onal  so\ware.  

MISUSE  PREVENTION  Prevent  money-­‐laundering,  …      [ ]

Page 13: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

13 Roman Matzutt 13

This  presentaNon  

Centralized  mixing    

Decentralized  mixing    

Anonymity  

Usability  

Security   Deniability  

OUR  APPROACH    

•  Threshold  ECDSA  •  Single  instead  of  group  transac;ons  •  Separate  input  and  mixing  peers  

COIN

PARTY

Bitcoin    Pool    

     

Costs  Scalability  

Mixing  network  

Group    TransacNon  

             

I4  

I3  

I2  

I1  

O2  

O4  

O1  

O3  

Usability  

Security   Deniability  

Costs  Scalability  

Anonymity  

Security  

Anonymity  

Scalability  

Costs  

Usability  

Deniability  

Page 14: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

14 Roman Matzutt 14

M1  

M2  

M3  

CoinParty  Protocol  Overview  INPU

T  PE

ERS  

 

MIXING  NETWORK

 

SHUFFLING    

SHUFFLE  2 COMMITMENT  1 TRANSACTION  3

E1   E3  E2  

Distributed  Genera;on  of  Bitcoin  Addresses  

Efficient  and    Verifiable  shuffling  

Threshold  ECDSA    in  the  malicious  model  

Larger  anonymity  sets  and  plausible  deniability  

Users  

E1   E3  E2  

Fresh  unlinkable    Output  addresses  

O2  O1   O3  

O2  O1   O3  

O1  O2   O3  

O3  O2   O1  

O3  O2   O1  

Page 15: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

15 Roman Matzutt 15

M1  

M2  

M3  

CoinParty  Protocol  Overview  INPU

T  PE

ERS  

 

MIXING  NETWORK

 

SHUFFLING    

Users  

SHUFFLE  2 COMMITMENT  1 TRANSACTION  3

E1   E3  E2  

Distributed  Genera;on  of  Bitcoin  Addresses  

Efficient  and    Verifiable  shuffling  

Threshold  ECDSA  via  SMC    in  the  malicious  model  

Larger  anonymity  sets  and  plausible  deniability  

E1   E3  E2  

Fresh  unlinkable    Output  addresses  

O2  O1   O3  

O2  O1   O3  

O1  O2   O3  

O3  O2   O1  

O3  O2   O1  

Page 16: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

16 Roman Matzutt 16

Goal  1:  Shared  control  addresses  •  Gennaro  et  al.  adapted  to  EC  

•  Shared  private  key  d  =  Recombine([d]1,[d]2,[d]3)  •  Full  public  key  D  =  dG  

•  Indis&nguishable  from  normal  Bitcoin  address  •  Precompute  ~  80  %  of  overhead    

       

Goal  2:  Receive  commitments  •  Mixing  peers  provide  web  interface  •  User  checks  mixing  parameters  •  User  commits  funds  in  standard  transac;on  

Commitment  Phase  

M1   M2   M3  

Gennaro, Rosario, et al. "Secure distributed key generation for discrete-log based cryptosystems.” EUROCRYPT’99. Springer, 1999.

DISTRIBUTED  ECDSA  KEY  GENERATION    (ECDKG)  (adapted  to  EC  from  Gennaro  et  al.)  

[d]1 [d]2 [d]3 D = dG D = dG D = dG

Page 17: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

17 Roman Matzutt 17

CoinParty  Protocol  Overview  INPU

T  PE

ERS  

 

MIXING  NETWORK

 

SHUFFLING    

Users  

COMMITMENT  1 TRANSACTION  3

E1   E3  E2  

Distributed  Genera;on  of  Bitcoin  Addresses  

Threshold  ECDSA  SMC    in  the  malicious  model  

Larger  anonymity  sets  and  plausible  deniability  

E1   E3  E2  

Fresh  unlinkable    Output  addresses  

O2  O1   O3   O3  O2   O1  

M1  

M2  

M3  

SHUFFLE  2

O2  O1   O3  

O1  O2   O3  

O3  O2   O1  Efficient  and    

Verifiable  shuffling  

Page 18: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

18 Roman Matzutt 18

Shuffle  Phase  

Goal:    SoluNon:  

O1   O2   O3  

M1   O3   O1   O2  

O3   O2   O1  

O1   O3   O2  

M2  

M3  

O2   O1   O3  

O1   O3   O2  

π1  =  (231)

π2  =  (23)

π2  =  (312)

πfix  =  (123)

πPRNG  =  (321)

M1   M2   M3  

M1   M2   M3  

Unlink  users  from  supplied  addresses.   Shuffle  addresses.  Verifiable  shuffle

Page 19: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

19 Roman Matzutt 19

…  

…  

Shuffle  Phase  (cont’d)  

Verifying  the  shuffle  =  Verifying  decryp;on  without  breaking  unlinkability  

Output  address  

C0  hash  

hash  

hash  

C1  

C2  

C3  

Verifica;on  Data   Verifica;on  Data   Verifica;on  Data  

User  i  secret  shares  Cij  to  the  mix  peers.  

M1   O3   O1   O2  

M1  

M3  

Reconstruct(                  +                    +                  )    =   H(                          )    O3   +  H(                          )    O’2   +  H(                          )    O1  [C11]   [C21]   [C31]  

C1  :=  C11  +  C21  +  C31   C’1  :=  C31  +  C’21  +  C11  =

O3   O2   O1  M2   O’2  

Users’  verifica;on  informa;on    =    Checksum  of  shuffle  stage

Page 20: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

20 Roman Matzutt 20

Shuffling  Phase  (cont’d)  

Handling  malicious  behavior    Case  1:  Mix  M2  did  not  decrypt  correctly            •  Reconstruct  M2’s  private  key  and  check  decryp;on  •  Skip  and  punish  dishonest  mix  M2  

 

Case  2:  Users  supplied  inconsistent  verificaNon  informaNon          

•  Reconstruct  all  checksums  Cj1  on  shuffle  stage  •  Iden;fy  and  punish  all  misbehaving  users  j  •  Need  to  abort  shuffle  

Reconstruct(                  +                    +                  )    =   H(                          )    O3   +  H(                          )    O’2   +  H(                          )    O1  [C11]   [C21]   [C31]  

C1  :=  C11  +  C21  +  C31   C’1  :=  C31  +  C’21  +  C11  =

Users’  verifica;on  informa;on    =    Checksum  of  shuffle  stage

Reconstruct(                  +                    +                  )    =   H(                          )    O3   +  H(                          )    O2   +  H(                          )    O1  [C11]   [C’21]   [C31]  

C’1  :=  C11  +  C’21  +  C31   C1  :=  C31  +  C21  +  C11  =

Users’  verifica;on  informa;on    =    Checksum  of  shuffle  stage

Page 21: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

21 Roman Matzutt 21

M1  

M2  

M3  

CoinParty  Protocol  Overview  INPU

T  PE

ERS  

 

MIXING  NETWORK

 

SHUFFLING    

Users  

SHUFFLE  2 COMMITMENT  1

E1   E3  E2  

Distributed  Genera;on  of  Bitcoin  Addresses  

Threshold  ECDSA    in  the  malicious  model  

Larger  anonymity  sets  and  plausible  deniability  

E1   E3  E2  

Fresh  unlinkable    Output  addresses  

O2  O1   O3  

O2  O1   O3  

O1  O2   O3  

O3  O2   O1  

O3  O2   O1  

Efficient  and    Verifiable  shuffling  

TRANSACTION  3

Page 22: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

22 Roman Matzutt 22

TransacNon  Phase  

GOAL:  Sign  transac;on  from  a  shared  Bitcoin  address  

M1   M2   M3  

Threshold  ECDSA  Signature  Algorithm  

(adapted  from  Ibrahim  et  al.)  

[d]1 [d]2 [d]3

E1   E3  E2  

O3  O2   O1  

TX( ) O2  E1  

Sig(TX( ), d) O2  E1  

•  Precompute  ~  75  %  of  overhead  •  Threshold  transac;ons  are  indisNnguishable  from  normal  Bitcoin  transac;ons  

Ibrahim, Maged H., et al. "A robust threshold elliptic curve digital signature providing a new verifiable secret sharing scheme." Circuits and Systems, IEEE, 2003.

Page 23: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

23 Roman Matzutt 23

Reminder  

Requirements  for  an  ideal  mixing  service  

COST  EFFICIENCY  No  mixing  fees.  Minimal  transac;on  fees.  

SECURITY  No  the\,  double  spending  or  loss  of  funds.  No  DoS.  

ANONYMITY  Anonymous  against  in-­‐  and  outsiders.    Big  anonymity  sets.  Unbiased  randomness.  

DENIABILITY  Means  of  plausible  deniability.    No  cryptographic  evidence.  

SCALABILITY  Large  numbers  of  users.    Low  impact  on  Bitcoin  network.  

APPLICABILITY  &  USABILITY  Compa;ble  with  Bitcoin  network.    No  addi;onal  so\ware.  

MISUSE  PREVENTION  Prevent  money-­‐laundering,  …      [ ]

Page 24: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

24 Roman Matzutt 24

Discussion:  Security  

Proof  Sketch  •  Use  secure  primi;ves:  Secret  sharing,  ECDKG,  TECDSA  

•  Security  of  Commitment  and  Transac;on  phase  follows  directly  •  Shuffle  stage  

•  Malicious  behavior  is  detected  •  Skip  malicious  mixes  J  •  Malicious  users  can  DoS  L  •  But  we  can  punish  them  effec;vely  K    

Security  Thresholds  •  Secret  Sharing,  ECDKG,  TECDSA  are  essen;ally  MPC  problems  

•  Need  guaranteed  output  •  Don’t  have  broadcast  channel  

•  m/3  malicious  mixes  is  theore;c  upper  bound  •  Any  number  of  malicious  users  

Page 25: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

25 Roman Matzutt 25

3 6 9 12 15 18 21 24 27 30 33 36 39 42 45 48

0i[ing window [h]

0

1000

2000

3000

4000

5000

An

on

ym

ity s

et

si]e

Mixing  Window  [h]    

Discussion:  Anonymity  

Anonymity  against  •  Mixing  peers:    #  of  users  •  Other  users:  #  of  users  -­‐  #  of  sybils  •  Passive  observers:  Analyze  blockchain    

BLK1   BLK2   BLK3   BLK4   BLK5  

On  top  of  basic    anonymity  set    

Page 26: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

26 Roman Matzutt 26

Discussion:  Scalability  

MIXING  OVERHEAD  in  CLOUD  SETTING    

Hosts  Azure  Cloud  A1  Instances  1  virtual  core,  1.75  GB  RAM  

Network  US  and  EU  Loca;ons  50    -­‐  100  ms  intracon;nental  150  -­‐200  ms  intercon;nental  

MIXING  OVERHEAD  in  LAN  SETTING        

Host  16  CPUs  /  32  Threads  32  GB  RAM  

Network  Gigabit  LAN  

<  3  minutes  with  15  Mixing  Peers  

Scales  with  number  of  inputs  and  MPs  

Most  overhead  due  to  communicaNon  

Approx.  75  %  can    be  precomputed  

Page 27: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

27 Roman Matzutt 27

Discussion:  Deniability  

Deniability  against  …  

•  Passive  observers:  Full  –  Mixing  TXs  are  indis;nguishable  from  normal  TXs  •  Mixing  peers:  None  –  MPs  can  iden;fy  their  own  mixing  transac;ons  •  Other  users:  Reduced  –  Sybil  a7acks  threaten  deniability  

Input  peers  

Malicious  users  

Compromise  50  %  users  Iden;fy  75  %  of  mixing  TXs  

p =1− (1− c / n)2

Page 28: COIN Secure&and&Anonymous& Decentralized&Bitcoin&Mixing& … · Roman Matzutt 3 TheBitcoinHypeCycle Inflated expectaons& Disillusionment& Technology& trigger& Slopeof& enlightenment&

28 Roman Matzutt 28

Conclusion  

OUR  APPROACH  

 

Mixing  in  single  transac;ons  using  Threshold  ECDSA.  Refined  shuffling  for  deniability.  

Security   Against  1/3  malicious  adversary  

Privacy   Orders  of  magnitude  more  anon.  

With  some  restric;ons  

Costs   No  mixing  fees.  No  TX  fees.  

Applicability   Fully  standard  Bitcoin  TXs  

Deniability  

COIN

PARTY Scalability   100s  –  1000s  of  users  

Deniability  

FUTURE  WORK  

PREVENTING  MISUSE  Applica;ons  

[email protected]­‐aachen.de