A wrapper around libntru using NIFs.
WARNING: This is a work in progress and shall not be used in production projects yet.
NTRU is a patented and open source public-key cryptosystem that uses lattice-based cryptography to encrypt and decrypt data. It consists of two algorithms: NTRUEncrypt, which is used for encryption, and NTRUSign, which is used for digital signatures. Unlike other popular public-key cryptosystems, it is resistant to attacks using Shor's algorithm and its performance has been shown to be significantly better
Add :ntru_elixir to your deps.
def deps do
  [
    {:ntru_elixir, "~> 0.0.0"}
  ]
endPlease visit hexdocs.pm/ntru_elixir for complete documentations.
In NTRU each private key can have multiple public keys. However to decrypt the encrypted data the same public key which data was encrypted with is necessarry.
To Create a KeyPair:
NtruElixir.generate_key_pair(pub_count, ntru_params(optional))
{:ok,
 [%NtruElixir.KeyPair{ntru_params: :NTRU_DEFAULT_PARAMS_128_BITS,
   priv_key: <<...>>,
   pub_key: <<...>>}, ...]}Note that if you specify pub_count you will get multiple KeyPair structs.
Binaries can be encrypted with a keypair having the public key
NtruElixir.encrypt(key_pair, binary_to_encrypt)
{:ok, encrypted_binary}Encrypted binaries can be decrypted with a keypair having BOTH public key and private key. Note that the public key should be the same as encryption public key.
NtruElixir.decrypt(key_pair, binary_to_decrypt)
{:ok, decrypted_binary}The ntru_elixir project is licensed under GNU GPLv3 however
it uses another libraries with different licenses.
libntru is licensed under BSD-3-Clause