Skip to content

Latest commit

 

History

History

py

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 

Kyber-Py

This repository contains the reference implementation of the Kyber key encapsulation mechanism, Post Quantum Cryptography algorithms usable through Python Native Interface wrappers.

Build

If you use Windows you should install MSYS2 and make several commands:

pacman -S --needed base-devel mingw-w64-i686-toolchain
pacman -S mingw-w64-i686-cmake
pacman -S mingw-w64-x86_64-python3

mkdir build
cd build
cmake .. -G "MSYS Makefiles"
make

For make a Python wrapper in Linux you should use cmake:

mkdir build
cd build
cmake ..
make

The build result will be available in the /build directory. Or you can just open the project in Visual Studio and build it inside the IDE.

Usage

To use the Kyber functions in a PYTHON project, you must use shared libraries located in the /build directory. Insert Python module into your application and use necessary functions. Shared libraries should located in the same directory. For example:

import ctypes
import pykyber_90s;
...
a = ''
b = ''
c = POINTER(a);
d = POINTER(b);

pykyber.pqcrystals_kyber512_ref_keypair(c, d)
print(a)
print(b)
}

The necessary shared libraries are placed in /build directory. It is not necessary to use all classes (with _90s and without). Just choose what you want to use.