GithubHelp home page GithubHelp logo

rettpop / indy-crypto Goto Github PK

View Code? Open in Web Editor NEW

This project forked from hyperledger-archives/indy-crypto

0.0 1.0 0.0 3.56 MB

Home Page: https://wiki.hyperledger.org/display/indy

License: Apache License 2.0

Rust 92.99% Shell 0.25% Python 2.35% Makefile 0.05% C 0.20% Groovy 1.43% Dockerfile 0.13% HTML 2.02% JavaScript 0.58% CSS 0.01%

indy-crypto's Introduction

Before you Continue

If you haven't done so already, please visit the main resource for all things "Indy" to get acquainted with the code base, helpful resources, and up-to-date information: Hyperledger Wiki-Indy.

Indy Crypto

This is the shared crypto library for Hyperledger Indy components.

Hyperledger Indy provides a distributed-ledger-based foundation for self-sovereign identity.

The major artifacts of the Indy Crypto are:

  • С-callable library interface
  • Rust сrate
  • Python wrapper

All bugs, stories, and backlog for this project are managed through Hyperledger's Jira in project IS (note that regular Indy tickets are in the INDY project instead...). Also, join us on Jira's Rocket.Chat at #indy-sdk to discuss.

Building Indy Crypto

Ubuntu 16.04

  1. Install Rust and rustup (https://www.rust-lang.org/install.html).

  2. Install pre-requirements:

    For Ubuntu 16.04

    apt-get update && \
    apt-get install -y \
    build-essential \
    pkg-config \
    cmake \
    libssl-dev

    For Windows

    • Download the prebuilt dependencies here
    • Extract them into the folder C:\BIN\x64. Note it really doesn't matter where you put these as long as you remember where so you can set the environment variables to this path
    • Point path to this directory using environment variables:
      • set OPENSSL_DIR=C:\BIN\x64
      • set PATH=C:\BIN\x64\lib;%PATH%
  3. Checkout and build the library:

    git clone https://github.com/hyperledger/indy-crypto.git
    cd ./indy-crypto/libindy-crypto
    cargo build
    cd ..
  4. Run tests

    cd libindy-crypto
    cargo test

Note: By default cargo build produce debug artifacts with a large amount of run-time checks. It's good for development, but this build can be in 100+ times slower for some math calculation. If you would like to analyse CPU performance of libindy-crypto for your use case, you have to use release artifacts (cargo build --release).

API Documentation

API documentation is now available as rust doc in code. See:

Wrappers documentation

Binaries

Note: Binaries creation is in progress now!!!

Builded binaries can be downloaded from https://repo.sovrin.org:

  • sdk/lib/apt/xenial/{master,stable,rc} - Ubuntu deb packages
  • windows/libindy_crypto/{master,stable,rc} - Windows zip-archive with all required DLLs (include libindy itself) and headers
  • ios/libindy_crypto/stable/ - Pods for iOS
  • rhel/libindy_crypto/{master,stable,rc} - RHEL rpms

Also Ubundu deb packages can be installed from APT repository:

apt-key adv --keyserver keyserver.ubuntu.com --recv-keys 68DB5E88
sudo add-apt-repository "deb https://repo.sovrin.org/sdk/deb xenial stable"
sudo apt-get update
sudo apt-get install -y libindy-crypto

indy-crypto's People

Contributors

artemkaaas avatar jovfer avatar aknuds1 avatar mikelodder7 avatar lovesh avatar andkononykhin avatar ashcherbakov avatar dependabot[bot] avatar axelnennker avatar ryjones avatar brentzundel avatar haoxuan40404 avatar techwritingwhiz avatar

Watchers

James Cloos 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.