Lime
LIME is an end-to-end encryption library for one-to-one and group instant messaging, allowing users to exchange messages privately and asynchronously.
LIME is composed of a portable client library coupled with a public key server developed by Belledonne Communications to allow end-to-end encryption for messaging, without having to exchange cryptographic keys simultaneously.
The library exposes a C++ API for easy integration in mobile and desktop environments.
LIME supports multiple devices per user and multiple users per device.
For additional information, please visit LIME's page on linphone.org
License
LIME library is dual-licensed and can be distributed either under a GNU GPLv3 license (open source, see LICENSE.txt) or under a proprietary license (closed source).
Copyright © Belledonne Communications SARL
The public key server (LIME server) is not part of this software package but can be found on the lime server repository
Dependencies
- bctoolbox[1] : portability layer, built with Elliptic Curve Cryptography
- soci-sqlite[2] : Db access
- postquantumcryptoengine[3] : abstraction layer to Kyber and MLKEM
Build instructions
cmake -DCMAKE_INSTALL_PREFIX=<install_prefix> -DCMAKE_PREFIX_PATH=<search_prefix> <path_to_source>
make
make install
Alternatively, LIME library is integrated in linphone-sdk meta project, which provides a convenient way to build it for various targets.
Documentation
To generate the Doxygen documentation files (having ran the cmake command with ENABLE_DOC On):
make doc
Comprehensive documentation on implementation choices and built-in protocols in lime.pdf
To generate this document from the LaTeX source, run in this folder(to use the archived version of msc.sty):
latexmk -pdf -synctex=1 lime.tex
Testing
To test on local machine, you must run a local X3DH server.
- A nodejs/sqlite version of UNSECURE X3DH server is provided in tester/server/nodejs See README from this directory for instructions.
If a local X3DH server is running with default parameter just run
make test
To launch a particular test suite, use ctest, running:
ctest -R <Test suite name> [--verbose]
Test suite names are
- crypto: Test the crypto primitives
- double_ratchet: Specific to the Double Ratchet protocol
- hello_world: Basic Lime test, mostly a demo code. Requires a live X3DH server on localhost
- lime: Complete testing of all features provided by the library. Requires a live X3DH server on localhost
- multidomains: Tests specific to the server multidomain management. Requires a live X3DH server on localhost, does not work with the nodejs server provided with the library.
- server: Tests some server configuration(resource usage limitation). Requires a live X3DH server on localhost, does not work with the nodejs server provided with the library.
Library settings
Some mostly harmless settings are available in src/lime_settings.hpp
Library APIs
The C++17 API is available in include/lime/lime.hpp
Options
-
CMAKE_INSTALL_PREFIX=<string>
: installation prefix -
CMAKE_PREFIX_PATH=<string>
: prefix where depedencies are installed -
ENABLE_UNIT_TESTS
: compile non-regression tests (default YES) -
ENABLE_STRICT
: build with strict complier flags e.g.-Wall -Werror
(default YES) -
ENABLE_CURVE25519
: Enable support of Curve 25519 (default YES) -
ENABLE_CURVE448
: Enable support of Curve 448 (default YES) - `ENABLE_PQCRYPTO' : Enable Post Quantum Cryptography key agreements algorithms(default NO)
-
ENABLE_PROFILING
: Enable code profiling for GCC (default NO) -
ENABLE_DOC
: Enable documenation generation, requires Doxygen (default NO)
- [1] bctoolbox: https://gitlab.linphone.org/BC/public/bctoolbox.git
- [2] soci: https://gitlab.linphone.org/BC/public/external/soci
- [3] postquantumcryptoengine: https://gitlab.linphone.org/BC/public/postquantumcryptoengine