Giter VIP home page Giter VIP logo

vrf's Introduction

Verifiable Random Function

DISCLAIMER: this crate is under active development and should not be used.

Implementation of the verifiable random function presented in draft-irtf-cfrg-vrf-03 using Edwards25519, SHA512, and Elligator2.

The goal of this crate is to have (at least) a compatible implementation with the VRF-03 implemented over libsodium.

Note on compatibility:

Currently, the tests pass because we are using forked curve25519-dalek crate. The implementation of the vrf over libsodium differs in the elligator2 function, which would make this crate incompatible with the libsodium generated outputs. curve25519-dalek's API does not allow us to modify the elligator2 function, which makes use rely on a fork. In particular, here we clear the sign bit, when it should be cleared only here (according to the latest standards). This does not reduce the security of the scheme, but makes it incompatible with other implementations.

We are actively working in the improvement of the vrf implementation, and this problem will be resolved soon. This crate MUST NOT be used in production until this problem is resolved.

Minimal working example

To effectively run the tests comparing the VRF implementation and the libsodium implementation, one needs to have libsodium compiled and installed. For that, run the following:

git clone https://github.com/input-output-hk/libsodium.git libsodium_vrf
cd libsodium_vrf
./autogen.sh
./configure
make
make install

Then, we can compile and run the tests of this crate:

make test

The outputs of the vrf implementation and the libsodium implementation appear in the console. We can see they are the same.

vrf's People

Contributors

iquerejeta avatar

Watchers

James Cloos avatar  avatar

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.