Trust on decentralized systems requires verifiable credentials. A generally available identity wallet for Cardano doesn't yet exist, and even if one did, a healthy ecosystem requires options.
The Blocktrust Identity Wallet products for Android and iOS will be developed, and they will help dApps and enterprise projects accelerate, since they help build trust through verifiable credentials.
This is the total amount allocated to BLOCKTRUST Identity Wallet (PRISM) v1.0 for Android and iOS.
Björn Sandmann
We are aiming to align with the currently available version of the PRISM v2 specification (https://github.com/input-output-hk/prism-did-method-spec). Our objective is to create a solution that can work seamlessly between Blocktrust and the PRISM components.
We will contract for an external code security review.
We will engage an attorney for helping with our Terms of Use and Privacy Policy.
There is an additional dependency on Microsoft’s .NET Multi-platform App UI (.NET MAUI), which is already released, but will undergo further changes we will need in the .NET 8 release scheduled for November 2023.
Project will be fully open source. The compiling of the source may depend on external components that are available only in binary form.
This Android and iOS products will implement the same use cases as described in the proposal “BLOCKTRUST Identity Wallet (PRISM) - Browser Extension and Shared Features, v1.0”, with some UI design and implementation elements that are unique to smartphones and their operating system. The Android and iOS wallet products will be built on the shared features described in that “base” proposal.
Vote for this Android and iOS proposal only if you also have voted for the base proposal.
The Wallet operates on the principles of self-sovereign identity (SSI) and utilizes Atala PRISM technology. Self-sovereign identity lets you have multiple digital identities (personas), composed of a decentralized identifier (DID) and a collection of verifiable claims, or Verifiable Credentials, about you.
These Verifiable Credentials (VCs) are generated by entities called Issuers. The VCs contain information about you (you're the Subject), and you hold them (making you the Holder). You can then present these verifiable claims to another entity called a Verifier.
Our Wallet not only receives these VCs from Issuers but also supports the roles of a Holder and a Verifier. It essentially lets you collect, store, and present your verifiable credentials.
The VCs are of type W3C JSON-JWT, and additional types will be added in the future. The communication protocols between agents (e.g. issuer-to-holder, holder-to-verifier) are based on Hyperledger Aries, and make use of a DIDComm v2 Mediator service, which the user can specify, one of those being Blocktrust's.
Additionally, our Wallet also uses DIDComm and a Mediator to implement secure, end-to-end encrypted chat messaging between you and another Wallet user or with any other compliant identity agent.
Specific implementation and differences for targeting Android and iOS (when compared with the browser extension product) include:
Using decentralized identity wallets and agents such as Blocktrust's, developers of decentralized applications (DApps) or centralized solutions interfacing with the Cardano ecosystem will be better equipped to fulfill their goals. These often involve establishing trust between different parties and ensuring regulatory compliance. Without the availability of Blocktrust's wallet, developers could face increased risks. They may find their progress impeded or become overly reliant on another provider's identity wallet solution, limiting their flexibility.
We plan to gather user feedback through a specific Discord channel dedicated to this purpose. Additionally, we'll keep track of the number of times our product is downloaded from the Chrome Web Store after it's released for beta testing and when it's made generally available. These download numbers will give us tangible data about our product's reach. We're also currently investigating potential ways to generate revenue from the product in the future.
Blocktrust will keep the Cardano community informed about our progress by providing updates as we achieve each of our milestones, typically on a monthly basis. We'll be communicating through Catalyst progress reports, our dedicated Discord channel, and videos showcasing the latest features of our product.
Occasionally, we may interact with the community in real-time during the Catalyst After Town Hall sessions. These sessions will give us an opportunity to show our progress and collect immediate feedback.
For Android, we’ll have Beta and Generally Available releases and distribution via the Google Play Store. For the iOS releases, they will be via Apple App Store.
Blocktrust is committed to the vision of widely implementing top-notch Self-Sovereign Identity (SSI) solutions for the Cardano ecosystem.
Our team currently comprises two seasoned software engineers, both of whom have an track record of successfully delivered projects (as seen on our website). Throughout our Fund 9 projects, we've demonstrated an excellent collaborative spirit. To further boost our productivity during this project, we plan to bring on board an additional full-stack C# developer.
Our robust performance in the Fund 9 and earlier projects, as evidenced by our accepted milestone reports and informative videos, underscores our capacity to deliver high-quality results. We've also established good relationships with key members of the Atala PRISM team and several early adopters within the Atala Astros group.
In our nearly concluded Fund 9 wallet project, expected to complete by October 2023, we've surmounted unexpected challenges and exceeded our initial project scope. Notably, we began the project on the PRISM v1 infrastructure. However, after IOG discontinued its support for v1 following the launch of v2, we adapted. Our Fund 10 wallet and its underlying infrastructure will align with the publicly released PRISM v2 specification. Beyond the original scope of Fund 9, we've introduced additional features like DIDComm - a safe, decentralized, and encrypted peer-to-peer communication protocol.
As we proceed with the Fund 10 project, we anticipate encountering similar challenges and opportunities for enhancement. We are ready to tackle these head-on, with tenacity to ensure we deliver a product of substantial value.
*Implement the wallet's features, leveraging the progress made on the Fund 9 browser extension and Fund 10 browser extension code that can be leveraged for Android and iOS as shared code. Deliver public releases (including Beta and General Availability).
*Continue to expand and preserve our wallet's interoperability with W3C Verifiable Credentials (JSON-JWT), the Atala PRISM v2 specification for on-chain transaction metadata, DIDComm v2-based communications, and the Hyperledger Aries credential exchange protocol.
*Test and showcase the above-mentioned interoperability with other identity agents compatible with our system.
*Facilitate the resolution of significant, comprehensive use cases involving decentralized identifiers and verifiable credentials, which would be beneficial for the dApp developers community.
*Promote discussions with other Cardano teams that require DIDs and verifiable credentials, and be prepared to advise on how our features can be integrated into their workflows.
Our approach's validation will be gauged through feedback from the DApp teams. We anticipate this feedback to be based on their experience with our Beta and Generally Available releases, as well as their ability to incorporate these into workflows that help them address their end-to-end use cases and business scenarios.
The implementations of the wallet for Android and iOS will be developed in .NET C# Blazor as a Mixed-Native WASM application.
This project’s tasks and milestones will follow after most of the shared work on those components common to browser, iOS, and Android is complete. This Android- and iOS-specific project is planned to start in earnest beginning February 2024.
Milestone 1:
Activities:
Finish: March 1, 2024
Milestone 2:
Finish: April 1, 2024
Milestone 3:
Finish: May 1, 2024
Milestone 4:
Finish: June 1, 2024
Milestone 5:
Finish: July 1, 2024
Milestone 6:
Finish: August 1, 2024
Milestone 7:
Finish: September 1, 2024
Milestone 8:
Finish: October 1, 2024
Milestone 9:
Finish: November 1, 2024
Project team: (architecture, design, software development, testing, DevOps, community, project management, documentation)
Third party products and services:
This project brings direct value in accelerating the implementation of many use cases involving trust for many participants in the Cardano ecosystem, especially for holders and verifiers of credentials. Without good identity wallets like Blocktrust's, the completion and adoption of many dApps and enterprise solutions will be slowed. That's a large opportunity cost to the Cardano ecosystem, which far exceeds this project's cost.
We computed effort, in hours, and multiplied that by a below-market rate of US$70 per hour (in both Germany and USA) for the expertise of our team. Then we devided this by a recent price of Ada, US$/ada = 0.28. By doing the, the team is taking a downside risk if the price of Ada drops from that point.
Ed Eykholt
20+ years of software product and engineering team leadership. C# developer. Focused on blockchain and identity projects and products since 2015. Atala ASTRO. Implemented much of the blocktrust identity wallet user experience.
LinkedIn: https://www.linkedin.com/in/edeykholt/
Github: https://github.com/edeykholt
Ed will manage the Identity Wallet product overall and focus on developing the user experience.
Björn Sandmann
10+ years of full-stack development with the .net Stack. Focused on identity and privacy solutions. PRISM Pioneer, Atala ASTRO, Plutus Pioneer, already funded proposals. Implemented all aspects of the working demo of the blocktrust identity wallet.
LinkedIn: https://www.linkedin.com/in/codedata/
Project history and technical skills: https://www.gulp.de/gulp2/g/spezialisten/profil/bsandmann
Björn will develop some of the services layer in the Identity Wallet, including protocols and their use of an SDK that interfaces to hosted services provided by another Blocktrust project.
New Team Member
Blocktrust might hire or contract with an experienced full-stack C# developer to augment Ed and Björn's contributions. The project can still be successful without this additional person.