Skip to content

Commit

Permalink
Doc improvements
Browse files Browse the repository at this point in the history
  • Loading branch information
robinhundt committed May 7, 2024
1 parent 1b9e908 commit 314ef32
Show file tree
Hide file tree
Showing 46 changed files with 331 additions and 123 deletions.
4 changes: 2 additions & 2 deletions .github/workflows/pull_request.yml
Original file line number Diff line number Diff line change
Expand Up @@ -31,7 +31,7 @@ jobs:
uses: dtolnay/rust-toolchain@master
id: toolchain
with:
toolchain: nightly-2024-03-19
toolchain: nightly-2024-05-03
- name: Override default toolchain
run: rustup override set ${{steps.toolchain.outputs.name}}
- run: cargo --version
Expand All @@ -55,7 +55,7 @@ jobs:
uses: dtolnay/rust-toolchain@master
id: toolchain
with:
toolchain: nightly-2024-03-19
toolchain: nightly-2024-05-03
components: "clippy, rustfmt"
- name: Override default toolchain
run: rustup override set ${{steps.toolchain.outputs.name}}
Expand Down
4 changes: 2 additions & 2 deletions .github/workflows/push.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
name: Push
name: CI

on: [ "push" ]

Expand All @@ -17,7 +17,7 @@ jobs:
uses: dtolnay/rust-toolchain@master
id: toolchain
with:
toolchain: nightly-2024-03-19
toolchain: nightly-2024-05-03
- name: Override default toolchain
run: rustup override set ${{steps.toolchain.outputs.name}}
- run: cargo --version
Expand Down
7 changes: 5 additions & 2 deletions .github/workflows/rustdoc.yml
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@ jobs:
# Build job
build:
runs-on: "ubuntu-latest"
env:
# deny rustdoc warnings
RUSTDOCFLAGS: -D warnings
steps:
- name: Check out repository
uses: actions/checkout@v4
Expand All @@ -18,14 +21,14 @@ jobs:
uses: dtolnay/rust-toolchain@master
id: toolchain
with:
toolchain: nightly-2024-01-12
toolchain: nightly-2024-05-03
- name: Override default toolchain
run: rustup override set ${{steps.toolchain.outputs.name}}
- run: cargo --version
- name: Cache
uses: Swatinem/rust-cache@v2
- name: Create Docs
run: cargo doc --workspace --verbose --all-features --no-deps
run: cargo doc --workspace --verbose --all-features --no-deps -Zunstable-options -Zrustdoc-scrape-examples
- name: Fix permissions
run: |
chmod -c -R +rX "target/doc/" | while read line; do
Expand Down
16 changes: 16 additions & 0 deletions LICENSE
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
Copyright 2024 Robin Hundt

Permission is hereby granted, free of charge, to any person obtaining a copy of this software
and associated documentation files (the “Software”), to deal in the Software without
restriction, including without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom
the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies
or substantial portions of the Software.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
107 changes: 98 additions & 9 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,19 +1,58 @@
# SEEC
# SEEC Executes Enormous Circuits

This framework implements secure 2-party secret-sharing based multi party computation protocols. Currently, we implement the Boolean and arithmetic versions of GMW87 with multiplication triple preprocessing. Additionally, we implement the Boolean part of the ABY2.0 protocol.
![ci badge](https://github.com/encryptogroup/SEEC/actions/workflows/push.yml/badge.svg?branch=main) [![rustdoc](https://github.com/encryptogroup/SEEC/actions/workflows/rustdoc.yml/badge.svg)](https://encryptogroup.github.io/SEEC/seec/)

This framework implements secure 2-party secret-sharing-based multi party computation protocols. Currently, we implement
the Boolean and arithmetic versions of GMW87 with multiplication triple preprocessing. Additionally, we implement the
Boolean part of the ABY2.0 protocol.

## Secure Multi-Party Computation

In secure multi-party computation (MPC), there are n parties, each with their private input x_i. Given a public function
f(x_1, ..., x_n), the parties execute a protocol π that correctly and securely realizes the functionality f. In other
words, at the end of the protocol, the parties know the output of f, but have no information about the input of the
other parties other than what is revealed by the output itself. Currently, SEEC is limited to the n = 2 party case, also
known as secure two-party computation. We hope to extend this in the future to n parties.

### Security

The two most prevalent security models are

- semi-honest security, where an attacker can corrupt parties, but they follow the protocol as specified.
- malicious security, where corrupted parties can arbitrarily deviate from the protocol.

SEEC currently only implements semi-honestly secure protocols (GMW, ABY2.0).

## Using SEEC

SEEC can be used as a library by adding it to the `Cargo.toml` file of an existing project.

```toml
seec = { }
```

## Documentation

Documentation for the main branch is hosted [here](https://encryptogroup.github.io/SEEC/seec/).

## Development

### Installing Rust

The project is implemented in the [Rust](https://www.rust-lang.org/) programming language. To compile it, the latest stable toolchain is needed (older toolchains might work but are not guaranteed). The recommended way to install it, is via the toolchain manager [rustup](https://rustup.rs/).
The project is implemented in the [Rust](https://www.rust-lang.org/) programming language. To compile it, the latest
stable toolchain is needed (older toolchains might work but are not guaranteed). The recommended way to install it, is
via the toolchain manager [rustup](https://rustup.rs/).

One way of installing `rustup`:

```shell
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
```

As a starting point to learn Rust, have a look at the superb
official [learning material](https://www.rust-lang.org/learn). To quickly look up syntax and idioms, we
recommend https://cheats.rs/.

### Checking for compilation errors

To simply check the code for error and warnings, execute:
Expand All @@ -27,10 +66,11 @@ cargo check
The tests can be run with the following command:

```shell
cargo test [--release]
cargo test [--release] [--all-features]
```

The `--release` flag is optional, but can decrease the runtime of the tests, at the cost of increased compilation time.
The `--all-features` flag enables all optional features.

### Formatting

Expand All @@ -41,26 +81,75 @@ cargo fmt
```

## ARM Support
SEEC has (WIP) ARM support. Because we use the unstable `std::simd` feature of Rust for portable SIMD transport, a recent nightly toolchain is needed. The easiest way to install this is via `rustup` (https://rustup.rs/).

SEEC has (WIP) ARM support. Because we use the unstable `std::simd` feature of Rust for portable SIMD transport, a
recent nightly toolchain is needed. The easiest way to install this is via `rustup` (https://rustup.rs/).

```shell
rustup toolchain install nightly
```

Then set the toolchain to use for this project to nightly.

```shell
rustup override set nightly
```

And verify that nightly is used.

```shell
cargo --version
# output should include nightly
```

If on an ARM platform, building and testing all crates in this repository won't work, as some (
e.g. `crates/bitpolymul`), require x86_64 intrinsics. Offending packages can be `--exclude`d or you can simply change
into the main `crates/seec` directory and run cargo there.

## Silent-OT
Our OT library [ZappOT](./crates/zappot) has optional support for Silent-OT.
Using the quasi-cyclic code (https://eprint.iacr.org/2019/1159.pdf) requires an x86-64 CPU with AVX2 support. ZappOT has WIP support for newer codes offered by libOTe (https://github.com/osu-crypto/libOTe). For these, we build and link to the code implementations in libOTe. These should work on other architectures, e.g., ARM, but we currently do not test this in CI.
Concretely, via libOTe, we support

Our OT library [ZappOT](./crates/zappot) has optional support for Silent-OT.
Using the quasi-cyclic code (https://eprint.iacr.org/2019/1159.pdf) requires an x86-64 CPU with AVX2 support. ZappOT has
WIP support for newer codes offered by libOTe (https://github.com/osu-crypto/libOTe). For these, we build and link to
the code implementations in libOTe. These should work on other architectures, e.g., ARM, but we currently do not test
this in CI.
Concretely, via libOTe, we support

- Silver (INSECURE! https://eprint.iacr.org/2021/1150, see https://eprint.iacr.org/2023/882 for attack)
- ExpandAccumulate (https://eprint.iacr.org/2022/1014)
- ExpandConvolute (https://eprint.iacr.org/2023/882).

SEEC currently supports generating Boolean MTs with Silent-OT when enabling the `silent-ot` feature.
SEEC currently supports generating Boolean MTs with Silent-OT when enabling the `silent-ot` feature.

> [!NOTE]
> Silent-OT with the quasi-cyclic code (`--feature silent-ot-quasi-cyclic` in SEEC) only works on x86_64 linux with AVX2
> support. The libOTe codes (`--feature silent-ot`) currently work on x86_64 linux and aarch64 ARM (M1 Macs). Other
> targets might work, but are not tested.
## Organization

This project is organized as a Cargo workspace with multiple crates in the `crates/` directory. The main crate is
located at `crates/seec` and it depends on most of the other crates.

Also of interest is the `crates/zappot` library, which implements several oblivious transfer (OT) protocols. These are
used by SEEC to compute setup data such as Beaver multiplication triples, but they can also be used independently.

Main Crates:

- seec: The main library which implements several MPC protocols.
- seec-macros: Offers the `#[sub_circuit]` proc-macro that turns functions into reusable sub-circuits.
- seec-channel: A convenient wrapper over a fork of [remoc](https://github.com/ENQT-GmbH/remoc).
- seec-bitmatrix: A bitmatrix implementation including portable SIMD matrix transpose (needs Rust nightly).
- zappot: Our OT library, including support for Silent-OT.

We also provide an additional library at `libs/libote-rs` which builds and provides bindings to the codes used in libOTe
for its implementation of Silent-OT. These can be optionally used by ZappOT.

### Architecture

The figure below shows a simplified version of the main traits and types of SEEC.
![](figures/architecture.svg)

## Benchmarking

Alongside SEEC, we're developing an MPC [benchmarking tool](https://github.com/encryptogroup/mpc-bench).
2 changes: 2 additions & 0 deletions crates/aligned-vec/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
name = "aligned-vec"
version = "0.1.0"
edition = "2021"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
2 changes: 2 additions & 0 deletions crates/bitpolymul-sys/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@ name = "bitpolymul-sys"
version = "0.1.0"
edition = "2021"
links = "bitpolymul"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
2 changes: 2 additions & 0 deletions crates/bitpolymul/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
name = "bitpolymul"
version = "0.1.0"
edition = "2021"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
2 changes: 2 additions & 0 deletions crates/seec-bitmatrix/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
name = "seec-bitmatrix"
version = "0.1.0"
edition = "2021"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
2 changes: 2 additions & 0 deletions crates/seec-bitmatrix/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -197,6 +197,8 @@ where
self.cols, rhs.rows,
"Illegal dimensions for matrix multiplication"
);
// TODO this can likely be heavily optimized. One option is to use the raw_rows iterator
// if possible to do the dotp on the raw elements. This should be significantly faster.
let dotp = |l_row: &BitSlice<T>, r_row| -> bool {
let and = l_row.to_bitvec() & r_row;
and.iter().by_vals().reduce(BitXor::bitxor).unwrap()
Expand Down
2 changes: 2 additions & 0 deletions crates/seec-channel-macros/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
name = "seec-channel-macros"
version = "0.1.0"
edition = "2021"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
2 changes: 2 additions & 0 deletions crates/seec-channel/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
name = "seec-channel"
version = "0.1.0"
edition = "2021"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
2 changes: 2 additions & 0 deletions crates/seec-macros/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@
name = "seec-macros"
version = "0.1.0"
edition = "2021"
license = "MIT"
authors = ["Robin Hundt"]

# See more keys and their definitions at https://doc.rust-lang.org/cargo/reference/manifest.html

Expand Down
Loading

0 comments on commit 314ef32

Please sign in to comment.