Hyperledger Ursa integration into Hyperledger Iroha

TitleHyperledger Ursa integration into Hyperledger Iroha
Status

PROJECT COMPLETED

Difficulty

MEDIUM  

Description 

We have an amazing new project Hyperledger Ursa, that is a secure cryptography library for different projects. As the main idea of Hyperledger is to make projects interoperable it would be great to integrate Ursa cryptography into Iroha or/and maybe include Iroha's cryptography into Ursa.

Dictionary

Additional Information

https://www.hyperledger.org/blog/2018/12/04/welcome-hyperledger-ursa - introduction to Ursa

https://github.com/hyperledger/ursa - Ursa repository, https://github.com/hyperledger/iroha - Iroha repository

https://github.com/hyperledger/iroha/tree/master/shared_model/cryptography - Cryptography in Iroha

https://iroha.readthedocs.io/en/master/ - Iroha Documentation

Learning Objectives

The intern will get guided by Iroha maintainers and contributors, that are ready to share their extensive knowledge obtained over years of research in cryptography and blockchain

They will be able to create a link between different projects that reflects the global tendency of cooperation and focus on interoperability including the idea of open-source development

Expected Outcome

Ursa library can be used in Iroha or Iroha cryptography could be included into Ursa libraries

Relation to Hyperledger 

Hyperledger Iroha, Hyperledger Ursa

Education Level

Any.

Skills

Basic engineering skills, C++ and Rust experience. 

Future plans

Continue integrating Ursa into other projects and use it in Iroha

Preferred Hours and Length of Internship

Part-time (full-time is also possible with some additional tasks).

Mentor(s) Names and Contact Info

Andrei Lebedevandrei@soramitsu.co.jp, Soramitsu

Mentee Name and Contact Info

Alexander Matson, Alexander Matson, City College of New York, alex@alexmatson.com

Project Plan

Deliverables

  • Integrate Ursa with the Iroha build system
  • Interface with Ursa's ed25519 signing functions
    • Edit docs for Ursa FFI and memory bug fix
    • Wrap Ursa calls in an Iroha crypto provider (expose same interface)
  • Integrate Multihash library
  • Automatically switch crypto providers depending on public key value

Milestones

  • First Quarter: June 3rd, 2019  
    • Begin researching integration plans
    • Test Ursa's C interface over FFI
    • Update docs for Ursa's C interface, remedying memory leak bugs
    • Add Ursa as a cmake module within Iroha's cmake system, with build commands
  • Second Quarter: July 15th, 2019  
    • Add a CryptoProvider for Ursa
    • Set value of DefaultCryptoAlgorithmType according to the build flag during compilation
    • Update crypto-related test cases to point to DefaultCryptoAlgorithmType
    • Update Ursa C interface with a memory-safe string destructor
    • Research approaches for multihash integration
  • Third Quarter: August 26th, 2019  
    • Select and integrate a multihash library, plus dependencies
    • Attempt one of integrating multihash with Iroha/Ursa keys – didn't work out
    • Attempt two of integrating multihash with Iroha/Ursa keys – simplified implementation
    • Change the CryptoVerifier to select between CryptoProviders depending on the public key's multihash encoding
  • Fourth Quarter: October 7th, 2019  
    • Check the loaded keypair is in the ledger
    • First pass at making block signing configurable: add a config file option
    • Second pass simplified the code changes; instead of config file option, automatically sign with the multihash type of the public key
    • Create slides for summary report presentation

Outcomes

  1. The ability for Iroha to re-use a common, well-maintained crypto library.
  2. Tighter integration in the Hyperledger ecosystem.

Summary Report