diff options
Diffstat (limited to 'libs/libaxolotl/README.md')
-rw-r--r-- | libs/libaxolotl/README.md | 99 |
1 files changed, 52 insertions, 47 deletions
diff --git a/libs/libaxolotl/README.md b/libs/libaxolotl/README.md index 09a954f434..a4467448e6 100644 --- a/libs/libaxolotl/README.md +++ b/libs/libaxolotl/README.md @@ -1,16 +1,16 @@ # Overview This is a ratcheting forward secrecy protocol that works in synchronous and asynchronous messaging -environments. See the [Java library](https://github.com/whispersystems/libaxolotl-java) for more details. +environments. See the [Java library](https://github.com/whispersystems/libsignal-protocol-java) for more details. -# Building libaxolotl-c +# Building libsignal-protocol-c ## Development host setup ### Build dependencies -* [CMake](http://www.cmake.org/) 2.8.4 or higher -* [Check *1](http://check.sourceforge.net/) +* [CMake](https://cmake.org/) 2.8.4 or higher +* [Check *1](https://libcheck.github.io/check/) * [OpenSSL *1](https://www.openssl.org/) 1.0 or higher * [LCOV *2](http://ltp.sourceforge.net/coverage/lcov.php) @@ -22,7 +22,7 @@ Items marked with *1 are required for tests, with *2 are additionally required f ### Setting up a fresh source tree - $ cd /path/to/libaxolotl-c + $ cd /path/to/libsignal-protocol-c $ mkdir build $ cd build $ cmake -DCMAKE_BUILD_TYPE=Debug .. @@ -30,23 +30,26 @@ Items marked with *1 are required for tests, with *2 are additionally required f ### Running the unit tests - $ cd /path/to/libaxolotl-c/build + $ cd /path/to/libsignal-protocol-c/build $ cmake -DCMAKE_BUILD_TYPE=Debug -DBUILD_TESTING=1 .. + $ cd tests + $ make + $ cd .. $ ctest ### Creating the code coverage report - $ cd /path/to/libaxolotl-c/build + $ cd /path/to/libsignal-protocol-c/build $ cmake -DCMAKE_BUILD_TYPE=Debug -DBUILD_TESTING=1 -DCOVERAGE=1 .. $ make coverage The generated code coverage report can be found in: -`/path/to/libaxolotl-c/build/coverage` +`/path/to/libsignal-protocol-c/build/coverage` ### Eclipse project setup CMake provides a tutorial on Eclipse project setup here: -http://www.cmake.org/Wiki/CMake:Eclipse_UNIX_Tutorial +https://cmake.org/Wiki/CMake:Eclipse_UNIX_Tutorial It is recommended to follow the more manual "Option 2," since the Eclipse project generator built into CMake tends to be outdated and leads you toward @@ -54,7 +57,7 @@ a very awkward and occasionally broken project configuration. ### Protocol Buffers compiler -This project uses serialization code based on [Protocol Buffers](https://code.google.com/p/protobuf/). +This project uses serialization code based on [Protocol Buffers](https://github.com/google/protobuf). Since the official library does not support C, the [protobuf-c](https://github.com/protobuf-c/protobuf-c) generator is used instead. For the sake of convenience, the generated code and its dependencies are included in the source tree. The generated code can be regenerated at any time by installing the two @@ -64,40 +67,40 @@ mentioned packages and running "make" in the "protobuf/" subdirectory. CMake toolchain files have been included from the following sources: -* [iOS](https://code.google.com/p/ios-cmake/) +* [iOS](https://code.google.com/archive/p/ios-cmake) * [BlackBerry 10](https://github.com/blackberry/OGRE/blob/master/src/CMake/toolchain/blackberry.toolchain.cmake) -# Using libaxolotl-c +# Using libsignal-protocol-c ## Library initialization -Before using the library, a libaxolotl-c client needs to initialize a global +Before using the library, a libsignal-protocol-c client needs to initialize a global context. This global context is used to provide callbacks for implementations of functions used across the library that need client-specific implementations. -Refer to "axolotl.h" for detailed documentation on these functions, and the unit +Refer to "signal_protocol.h" for detailed documentation on these functions, and the unit tests for example implementations. - axolotl_context *global_context; - axolotl_context_create(&global_context, user_data); - axolotl_context_set_crypto_provider(global_context, &provider); - axolotl_context_set_locking_functions(global_context, lock_function, unlock_function); + signal_context *global_context; + signal_context_create(&global_context, user_data); + signal_context_set_crypto_provider(global_context, &provider); + signal_context_set_locking_functions(global_context, lock_function, unlock_function); ## Client install time -At install time, a libaxolotl-c client needs to generate its identity keys, +At install time, a libsignal-protocol-c client needs to generate its identity keys, registration id, and prekeys. ratchet_identity_key_pair *identity_key_pair; uint32_t registration_id; - axolotl_key_helper_pre_key_list_node *pre_keys_head; + signal_protocol_key_helper_pre_key_list_node *pre_keys_head; session_pre_key *last_resort_key; session_signed_pre_key *signed_pre_key; - axolotl_key_helper_generate_identity_key_pair(&identity_key_pair, global_context); - axolotl_key_helper_generate_registration_id(®istration_id, 0, global_context); - axolotl_key_helper_generate_pre_keys(&pre_keys_head, start_id, 100, global_context); - axolotl_key_helper_generate_last_resort_pre_key(&last_resort_key, global_context); - axolotl_key_helper_generate_signed_pre_key(&signed_pre_key, identity_key_pair, 5, timestamp, global_context); + signal_protocol_key_helper_generate_identity_key_pair(&identity_key_pair, global_context); + signal_protocol_key_helper_generate_registration_id(®istration_id, 0, global_context); + signal_protocol_key_helper_generate_pre_keys(&pre_keys_head, start_id, 100, global_context); + signal_protocol_key_helper_generate_last_resort_pre_key(&last_resort_key, global_context); + signal_protocol_key_helper_generate_signed_pre_key(&signed_pre_key, identity_key_pair, 5, timestamp, global_context); /* Store identity_key_pair somewhere durable and safe. */ /* Store registration_id somewhere durable and safe. */ @@ -113,9 +116,9 @@ be used as appropriate. ## Building a session -A libaxolotl-c client needs to implement four data store callback interfaces: -`axolotl_identity_key_store`, `axolotl_pre_key_store`, -`axolotl_signed_pre_key_store`, and `axolotl_session_store`. +A libsignal-protocol-c client needs to implement four data store callback interfaces: +`signal_protocol_identity_key_store`, `signal_protocol_pre_key_store`, +`signal_protocol_signed_pre_key_store`, and `signal_protocol_session_store`. These will manage loading and storing of identity, prekeys, signed prekeys, and session state. @@ -124,21 +127,21 @@ all data flowing through them as opaque binary blobs. Anything necessary for referencing that data will be provided as separate function arguments to those callbacks. If it is ever necessary for clients to directly access stored data in terms of library data structures, they should use the accessor functions -declared in "axolotl.h" for these data stores. +declared in "signal_protocol.h" for these data stores. Once the callbacks for these data stores are implemented, building a session is fairly straightforward: /* Create the data store context, and add all the callbacks to it */ - axolotl_store_context *store_context; - axolotl_store_context_create(&store_context, context); - axolotl_store_context_set_session_store(store_context, &session_store); - axolotl_store_context_set_pre_key_store(store_context, &pre_key_store); - axolotl_store_context_set_signed_pre_key_store(store_context, &signed_pre_key_store); - axolotl_store_context_set_identity_key_store(store_context, &identity_key_store); + signal_protocol_store_context *store_context; + signal_protocol_store_context_create(&store_context, context); + signal_protocol_store_context_set_session_store(store_context, &session_store); + signal_protocol_store_context_set_pre_key_store(store_context, &pre_key_store); + signal_protocol_store_context_set_signed_pre_key_store(store_context, &signed_pre_key_store); + signal_protocol_store_context_set_identity_key_store(store_context, &identity_key_store); /* Instantiate a session_builder for a recipient address. */ - axolotl_address address = { + signal_protocol_address address = { "+14159998888", 12, 1 }; session_builder *builder; @@ -155,36 +158,36 @@ is fairly straightforward: session_cipher_encrypt(cipher, message, message_len, &encrypted_message); /* Get the serialized content and deliver it */ - axolotl_buffer *serialized = ciphertext_message_get_serialized(encrypted_message); + signal_buffer *serialized = ciphertext_message_get_serialized(encrypted_message); - deliver(axolotl_buffer_data(serialized), axolotl_buffer_len(serialized)); + deliver(signal_buffer_data(serialized), signal_buffer_len(serialized)); /* Cleanup */ - AXOLOTL_UNREF(encrypted_message); + SIGNAL_UNREF(encrypted_message); session_cipher_free(cipher); session_builder_free(builder); - axolotl_store_context_destroy(store_context); + signal_protocol_store_context_destroy(store_context); The above example is simplified for the sake of clarity. All of these functions return errors on failure, and those errors should be checked for in real usage. ## Memory management notes -For every custom data type that the libaxolotl-c library can allocate and +For every custom data type that the libsignal-protocol-c library can allocate and return, a corresponding way of deallocating an instance of that data type is provided. The more basic and higher level data types provide a type-specific free or -destroy function. These types include `axolotl_context`, -`axolotl_store_context`, `axolotl_buffer`, `axolotl_buffer_list`, -`axolotl_int_list`, `axolotl_key_helper_pre_key_list_node`, `session_builder`, +destroy function. These types include `signal_context`, +`signal_protocol_store_context`, `signal_buffer`, `signal_buffer_list`, +`signal_int_list`, `signal_protocol_key_helper_pre_key_list_node`, `session_builder`, `session_cipher`, `group_session_builder`, `group_cipher`, and `fingerprint_generator`. Most of the other data types, including everything internal, use a reference counting mechanism. If you are going to hold onto a reference to one of these -types, use the `AXOLOTL_REF(x)` macro to increment its count. If you are done -with a reference, use `AXOLOTL_UNREF(x)` to decrement its count. When the count +types, use the `SIGNAL_REF(x)` macro to increment its count. If you are done +with a reference, use `SIGNAL_UNREF(x)` to decrement its count. When the count reaches 0, the type's destructor function is called. # Legal things @@ -199,7 +202,9 @@ The form and manner of this distribution makes it eligible for export under the ## License -Copyright 2015 Open Whisper Systems +Copyright 2015-2016 Open Whisper Systems Licensed under the GPLv3: http://www.gnu.org/licenses/gpl-3.0.html +Additional Permissions For Submission to Apple App Store: Provided that you are otherwise in compliance with the GPLv3 for each covered work you convey (including without limitation making the Corresponding Source available in compliance with Section 6 of the GPLv3), Open Whisper Systems also grants you the additional permission to convey through the Apple App Store non-source executable versions of the Program as incorporated into each applicable covered work as Executable Versions only under the Mozilla Public License version 2.0 (https://www.mozilla.org/en-US/MPL/2.0/). + |