Thanks to visit codestin.com
Credit goes to github.com

Skip to content

diogoftm/QMP-SPDZ

 
 

Repository files navigation

Quantum MP-SPDZ

Integrates quantum-generated oblivious keys as Base OTs with the possibility of PSK combination to quantum-enable OT-Based Secure Multiparty Computation protocols.

The updates were carried out in the qdev branch. This branch is based on MP-SPDZ v0.4.0.

Supported (tested) protocols

Program Protocol
mascot-party.x MASCOT
semi-party.x Semi-honest version of MASCOT
yao-party.x Yao with half-gate garbling (see Zahur et al. and Guo et al.)

Supported Key Retrieval interfaces

The current version supports the following KMS interfaces that are slightly modified for coexistence of both symmetric and oblivious keys (not in the scope of the original standards):

Installation and Example Usage

  1. Clone this repository and install main dependencies:

    git clone https://github.com/diogoftm/QMP-SPDZ.git
    cd QMP-SPDZ
    git submodule update --init --recursive
    apt-get install -y automake build-essential clang cmake git libgmp-dev libntl-dev libsodium-dev libssl-dev libtool libboost-dev libjansson-dev yasm texinfo libexplain-dev libb64-dev
  2. Set environment variables in ENV.env based on your infrastructure and then run:

    source ENV.sh
  3. Build the library:

    make -j 8 tldr

    Note: This command will rename either OTKeys_014/ or OTKeys_004/ to OTKeys/ based on the KEY_REQUEST_INTERFACE. To change the interface, rename the directory back to its original name.

  4. Compile, for example, the MASCOT executable mascot-party.x:

    make -j 8 mascot-party.x
  5. Create a parties IP file:

    In this file it is defined the IP, port and SAE ID of each party in the computation, and also an optional PSK per peer.

    The general structure of the file is the following:

     <IP>:<PORT> <SAE_ID> <KSID> <BASE_KEY_INDEX> <psk>
     <IP>:<PORT> <SAE_ID> <KSID> <BASE_KEY_INDEX> <psk>
     ...
    

    For 004, not only the IDs of the application need to be provided, but also the key stream ID and the index of the keys to be used need to be provided for each peer. For the 014 interface with the KMS only the SAE ID need to be set. The indicated key stream must have been already opened with a 4096-byte key chunk size. Also, a 256-bit base64 encoded PSK can be indicated that will be combined with the oblivious key received from the KMS. Key stream information (i.e. KSID and key index) are only used for the peers, so there's no need to indicate this information for the party that will use this file.

    Example (SAE IDs 004 style and considering that this is the config file for party 0):

    # players_0.txt
    127.0.0.1:1234 qkd://app1@aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa - - -
    127.0.0.1:1238 qkd://app2@bbbbbbbb-bbbb-bbbb-bbbb-bbbbbbbbbbbb 550e8400-e29b-41d4-a716-446655440000 0 -
    

    Example (SAE IDs 004 style and considering that this is the config file for party 1):

    # players_1.txt
    127.0.0.1:1234 qkd://app1@aaaaaaaa-aaaa-aaaa-aaaa-aaaaaaaaaaaa 550e8400-e29b-41d4-a716-446655440000 0 -
    127.0.0.1:1238 qkd://app2@bbbbbbbb-bbbb-bbbb-bbbb-bbbbbbbbbbbb - - -
    
  6. Compile the MPC program (e.g. crash_detection_test):

    ./compile.py -F 64 crash_detection_test
  7. Finally, run the computation (e.g. using mascot):

    ./mascot-party.x -N 2 -ip players_0.txt -I -p 0 crash_detection_test
    ./mascot-party.x -N 2 -ip players_1.txt -I -p 1 crash_detection_test

    For this computation just input 3 numbers separated by a space or by a new line. The first number is the flag (0 or 1) that tells if there was a crash or not, the other two number are the $(x, y)$ coordinates. The output will be the highest coordinate where a crash was indicated.

Generate shared keys

Shared key generation is performed, if wished, before running the computation in order to set up the PSK filed in the respective parties file. This can be done using the generate_shared_key.py script that will perform an online key exchange using a Key Encapsulation Mechanism (KEM). Currently, the only supported KEM is ML-KEM that will be used by default leveraging BoringSSL's implementation.

For each party run:

python3 pq/generate_shared_key.py <ip-file-name> <playerno>

The script will also automatically update the respective parties file (<ip-file-name>) with the generated keys.

The flow of the key exchange between two parties is depicted in the diagram bellow.

sequenceDiagram
    participant PartyA as Party A
    participant PartyB as Party B

    Note over PartyA: Generate Ephemeral Keys (A_pub, A_priv)
    Note over PartyB: Generate Ephemeral Keys (B_pub, B_priv)

    PartyA->>PartyB: Send Public Key (A_pub)
    PartyB->>PartyA: Send Public Key (B_pub)

    Note over PartyA: Encapsulate Key using B_pub (K0, Encapsulated_K0)
    PartyA->>PartyB: Send Encapsulated_K0
    Note over PartyB: Decapsulate Encapsulated_K0 → K0 using B_priv
    Note over PartyB: Encapsulate Key A_pub (K1, Encapsulated_K1)

    PartyB->>PartyA: Send Encapsulated_K1

    Note over PartyA: Decapsulate Encapsulated_K1 → K1 using A_priv

    Note over PartyA, PartyB: Shared Key = K0 ⊕ K1
Loading

This script should be seen only as an example basepoint to setup the PSKs using PQC and not as a finishd solution.

More documentation

Please check the original MP-SPDZ documentation.

About

Versatile framework for multi-party computation

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 64.6%
  • Python 33.3%
  • C 1.2%
  • Other 0.9%