This module implements semi local compression algorithm described in Optimizing the Compression Cycle: Algorithms for Multilateral Netting in OTC Derivatives Markets.
The goal is to run a netting algo in an enclave so that each party can submit their inputs: payments (direction, recipient and amount) or derivative contracts (direction, recipient, notional) encrypted to hide them from other parties, adversaries and the executor of the algo. The inputs are decrypted within the enclave, the algo calculates, results are encrypted and returned to the parties.
- enclave is created, a pair of keys is generated: the private key never leaves the enclave, public one is made available for every party to submit their inputs.
- each party uses enclave's public key to encrypt their inputs: payments to other parties. The inputs are submitted to the algo as a one dimensional array and become a row in a symmetrical matrix of payments. Along with the inputs the party submits its public key with which the enclave will encrypt the results to send back.
- once every party's rows have been submitted, the algo decrypts the matrix with the enclave's private key and calculates the results: a sparser symmetrical matrix whose rows still represent each party's payments whose number is now reduced by the compression algo.
- each party queries the algo for their part of the results: a row of payments. The algo encrypts the results with the party's public key it has saved with the inputs and returns encrypted results. The party decrypts the results using their private key.
- implement compression algo in C using description in the publication and Java code as reference. Deliverables: a compiled library with the implementation, an executable to run it, unit tests. Input to the library: a matrix of payments in clear text. Output: matrix of the results in clear text.
- put the library into the enclave to run the algo Deliverables: an executable that establishes an enclave and runs the algo from the library. Input and outputs are still clear text
- create a service that receives encrypted input as rows to the matrix one by one, calculates once it's received all inputs and outputs encrypted results. Deliverables: an executable that takes inputs as files of one dimensional arrays of numbers representing a row in the input matrix plus a public key; outputs are files with arrays of resulting numbers encrypted by the party's public key
- http or grpc endpoint to receive inputs and respond to queries for results
- add remote attestation query endpoint
- put in a docker container
For this project, you mainly need the SGX SDK. You can also install the driver and PSW for hardware support.
First, load the sgx sdk environment into your shell
$ . /opt/intel/sgxsdk/environment
To build, create a build directory and run cmake to generate the makefiles
$ mkdir sgx-netting-build && cd sgx-netting-build
$ cmake /path/to/source/folder -DSGX_MODE=SIM
$ make
Where /path/to/source/folder is the relative/absolute path to this repo.
SGX_MODE can be 'HW'
The built executable 'app' is under sgx-netting-build/bin. Run it as such:
$ . /opt/intel/sgxsdk/environment # load the sgx sdk environment if not loaded
$ cd sgx-netting-build/bin
$ ./app
sudo apt-get install build-essential python cmake
git clone git@github.com:dpsberlab/linux-sgx.git
cd linux-sgx
./download_prebuilt.sh
make && make sdk_install_pkg
cd linux/installer/bin
./sgx_linux_x64_sdk_${version}.bin # choose install directory - /opt/intel
. /opt/intel/sgxsdk/environment # source the sgxsdk environment into the shell
git clone git@github.com:olegabu/sgx-netting.git
mkdir sgx-netting-build
cd sgx-netting-build
cmake ../sgx-netting -DSGX_MODE=SIM
make -j 10
bin/rest_sgx is the rest server binary.
By default it listens on 0.0.0.0:8080.
usage: rest_sgx [port] [threads]
There is a Dockerfile for running the rest server under docker.
To build it, from the source directory run:
docker build -t sgx .
Then run it as:
docker run -t -p 8080:80 sgx
This binds the server to the local port 8080.
To keep the state of the enclave (i.e. its cryptographic state, so it can decrypt inputs), reuse the same container.
There are 2 tests that can be run using CMake CTest.
Do not forget to load the SGX env first.
To run the tests, go to the cmake build directory and:
ctest --verbose
Not use the enclave_private.pem in the git repo for signing the enclave and use the 2-step method for signing the enclave.