#e-voting #crypto

rust_ev_crypto_primitives

Crypto Primitives necessary for E-Voting Applications

16 unstable releases (6 breaking)

new 0.7.0 Jan 1, 2025
0.6.4 Dec 24, 2024
0.6.2 Oct 12, 2024
0.5.4 May 9, 2024
0.5.0 Mar 30, 2024

#941 in Cryptography

Download history 156/week @ 2024-09-11 34/week @ 2024-09-18 197/week @ 2024-09-25 33/week @ 2024-10-02 158/week @ 2024-10-09 28/week @ 2024-10-16 15/week @ 2024-10-23 12/week @ 2024-10-30 5/week @ 2024-11-06 2/week @ 2024-11-13 5/week @ 2024-11-20 6/week @ 2024-11-27 95/week @ 2024-12-04 43/week @ 2024-12-11 216/week @ 2024-12-18 96/week @ 2024-12-25

453 downloads per month
Used in 2 crates

LGPL-3.0+

9MB
9K SLoC

E-Voting Crypto Primitives in Rust

Introduction

This crate implements functionalities of the crpyto primitives for the E-Voting system of Swiss Post. It is based on the specifications of Swiss Post, according to the following document version:

It implements only the functionalities that are necessary for the implementation of the Verifier.

See API Documentation for details

Development guide

The crate is tested with the version of Rust defined in Cargo.toml.

Installation

The crate uses the crate openssl to wrap the functions of the library openssl for the basic cryptographic functions. Please check the installation guide of the crate.

The crate uses the crate rug to wrap the functions of the library GMP for the performant big integers. Please check the installation guide of the crate.

In particular the build on Windows must be perfomerd with MSYS2 (see windows for details).

Licence

Rug is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. See the full text of the GNU LGPL for details.

Third party

See THIRD_PARTY

Dependencies

~29MB
~679K SLoC