blob: 3ea436948d7604eb6692bc8539039b19f808edf5 [file] [log] [blame] [view]
This is a general description of what is contained in each crate and how it should be used.
```ukey2```:
-
- Contains the state machine required to run the handshake
- A new state type is return on each message exchanged with this state machine
- Current status: Wire-compatible with existing implementations of UKEY2 using the HandshakeImplementation::PublicKeyInProtobuf value.
- TODO: Improve error handling
```ukey2-connections```:
-
- Convenient wrapper around the ```ukey2``` crate for running the handshake, located in ```d2d_handshake_context.rs```.
- Creates a connection context encoding/decoding messages to/from the peer, located in ```d2d_connection_context_v1.rs```.
- Current status: Fully wire-compatible with existing implementations of UKEY2.
- TODO: Improve error handling
```ukey2-jni```:
-
- Houses a JNI wrapper for the ````ukey2-connections```` crate
- Includes a small Java test applet to test throwing exceptions and an example of how to use the library
- Automatically uses the ```HandshakeImplementation::PublicKeyInProtobuf``` implementation for compatibility with existing implementations.
- Current status: Working with the driver code in ```ukey2-jni/java```
```ukey2-c-ffi```:
-
- Houses a C interface for the Rust library
- Includes a header that can be used to link against the library
- Automatically uses the ```HandshakeImplementation::PublicKeyInProtobuf``` implementation for compatibility with existing implementations.
- Current status: Handshake and message exchange working with the ```ukey2-c-ffi/cpp/``` test binary
- To build the test binary, first build the FFI library with Cargo (only works on Linux) and then from ukey2-c-ffi: ```bazel (or blaze) build //cpp:ukey2```
- TODO: Improve error handling
```ukey2-shell```:
-
- A small shell application written very similarly to the C++ one used for testing against the Java implementation
- Current status: Working, tested against the Java implementation.