Giter Site home page Giter Site logo

crypto-tk-rs's Introduction

OpenSSE's Rust Cryptographic Toolkit

Searchable encryption protocols, like other cryptographic protocols, rely on high level cryptographic features such as pseudo-random functions, hash functions, or encryption schemes. This toolkit provides interfaces and implementations of these features in Rust.

Why a new crypto library

A lot of great crypto libraries exist out there (e.g. libsodium). Unfortunately, they do not offer the level of abstraction needed to implement searchable encryption schemes easily. Indeed, cryptographic objects such as pseudo-random functions, trapdoor permutations, pseudo-random generators, etc, are building blocks of such constructions, and OpenSSL, Rust-Crypto, libsodium bindings in Rust do not offer interfaces to such objects.

This library provides these APIs so that any implementer of a cryptographic algorithm/protocol has a consistent and secure high-level crypto interface to these primitives and does not have to care about their implementation.

It is a Rust counterpart of OpenSSE's crypto-tk library.

Disclaimer

This is code for a research project. It should not be used in production: the code lacks good Rust security practice, and it has never been externally reviewed.

Contributors

Unless otherwise stated, this code has been written by Raphael Bost.

Licensing

This code is licensed under the GNU Affero General Public License v3.

AGPL

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.