#data-privacy #data-transfer #oblivious-transfer #ot-multiplication #simplest-ot

no-std oblivious_transfer_protocols

Oblivious Transfer (OT), Oblivious Transfer Extensions (OTE) and multiplication protocol using them

9 breaking releases

0.10.0 Dec 19, 2024
0.9.0 Jul 18, 2024
0.8.0 Jun 21, 2024
0.6.0 Mar 4, 2024
0.2.0 Jun 23, 2023

#9 in #data-privacy

Download history 23/week @ 2024-09-11 26/week @ 2024-09-18 38/week @ 2024-09-25 14/week @ 2024-10-02 3/week @ 2024-10-09 4/week @ 2024-10-16 5/week @ 2024-10-23 3/week @ 2024-10-30 6/week @ 2024-11-06 22/week @ 2024-11-13 54/week @ 2024-11-20 14/week @ 2024-11-27 16/week @ 2024-12-04 43/week @ 2024-12-11 147/week @ 2024-12-18 22/week @ 2024-12-25

229 downloads per month
Used in 7 crates (3 directly)

Apache-2.0

465KB
10K SLoC

Oblivious Transfer (OT), Oblivious Transfer Extensions (OTE) and multi-party protocols based on that.

Oblivious Transfer protocols

  1. Simplest OT protocol
  2. Naor Pinkas OT
  3. Endemic OT

Oblivious Transfer Extensions

  1. ALSZ
  2. KOS

Oblivious Transfer based multiplication

  1. DKLS18 - 2 party multiplication of where each party has a single input
  2. DKLS19 - 2 party batch-multiplication of where each party has multiple inputs, say n inputs and those inputs will be multiplied, i.e. a total of 2*n multiplications will be done with each being between 2 inputs

lib.rs:

Oblivious Transfer (OT), Oblivious Transfer Extensions (OTE) and multi-party protocols based on that.

Oblivious Transfer protocols

  1. Simplest OT protocol
  2. Naor Pinkas OT
  3. Endemic OT

Oblivious Transfer Extensions

  1. ALSZ
  2. KOS

Oblivious Transfer based multiplication

  1. DKLS18 - 2 party multiplication of where each party has a single input
  2. DKLS19 - 2 party batch-multiplication of where each party has multiple inputs, say n inputs and those inputs will be multiplied, i.e. a total of 2*n multiplications will be done with each being between 2 inputs

Dependencies

~9.5MB
~173K SLoC