not approved
Scarab - a cardano-node client implementation in functional Scala
Current Project Status
Unfunded
Amount
Received
₳0
Amount
Requested
₳500,000
Percentage
Received
0.00%
Solution

This proposal is to fund development of a cardano-node client in functional Scala (a JVM language) in order to address client and platform diversity of Cardano while maintaining the rigor of Haskell.

Problem

As a network aiming for complete decentralization, a single node client developed by one entity is limiting. Diversity in node choice improves the robustness of the network for all participants.

Feasibility
Value for money
Impact / Alignment

Team

1 member

Scarab - a cardano-node client implementation in functional Scala

Please describe your proposed solution.

  • The eventual goal of Scarab is to provide an alternative block-producing node implementation to improve upon the decentralization and security of the Cardano network. As noted in SoK: A Stratified Approach to Blockchain Decentralization, a network's resilience to implementation bugs and maintainer malfeasance is reduced when there exists only a limited number of full block-producing node implementations.
  • Scarab does not seek to replace the Haskell cardano-node implementation or to fork the Cardano network, but rather to be a compatible and complementary alternative for stake-pool operators and enterprise organizations. Additionally, development of such a block-producing node would necessitate community-led specifications of functionalities (CIPs) and provide further insight regarding the implementation details within the application.
  • As a first step to a block-producing node this work proposes creation of a client node, written in functional Scala, that can interact with network peers via the node-to-node protocols and users via the node-to-client protocols, maintain and extend the block history via bootstrapping and block validation, and update ledger state via transaction execution throughout each era.
  • Such a node will be able to act as a backend for user wallets and be capable of being bundled with complex off-chain applications that benefit from direct exposure to the blockchain state.

How does your proposed solution address the challenge and what benefits will this bring to the Cardano ecosystem?

  • Development of a Scala-based client node would directly address the “Development & Infrastructure” challenge in several ways:
  • Alternative node benefits
  • Increase overall decentralization of the Cardano network by developing an open-source node application independent of IOG.
  • Provide a route for community-led development of a complete set of formal, language agnostic specifications to facilitate interoperability between Scarab, cardano-node, and other applications / libraries.
  • Explore innovation on the design of node sub-systems such as storage.
  • Functional Scala benefits
  • Offers high concurrency, scalability, performance, robust static typing, and expressive syntax.
  • Part of a mature JVM ecosystem with extensive libraries, IDEs, debuggers, and opens up a vast pool of resources, tools, and developers.
  • Interoperability with JVM languages like Java, Kotlin, and Clojure increases its accessibility for node integrations and enterprise adoption.
  • Code can run on any platform that supports JVM and additional cross-platform support is possible via GraalVM or Scala Native.
  • Promotes safe and reliable code through features such as immutability and side-effect free operations.

How do you intend to measure the success of your project?

  • A successful proposal would result in diversification of operating client-nodes on the Cardano network via adoption of the Scarab binary for use in a decentralized application or wallet. Achieving even 1% market penetration by year-end 2024 with the client node implementation would be a considerable achievement given the current monopoly of the Haskell implementation.
  • In the short-term, an alternative client will provide a means of expanding the reach of Cardano to the JVM ecosystem. While in the long-term, building on this work to create a block-producing node will contribute to trust in the resiliency and decentralization of the network.

Please describe your plans to share the outputs and results of your project?

  • All code will be open-sourced and available via Github for comment and review
  • The project will run on a two-week sprint cadence so progress reports will be compiled, posted to Github, and shared via Twitter and Discord following each sprint.

What is your capability to deliver your project with high levels of trust and accountability?

I have extensive experience developing blockchain applications in Scala having previously developed a full blockchain application in Scala based on the Akka actor model, led the research and evaluation of an Ouroboros derivative to improve block production guarantees, and spearheaded development of a greenfield functional Scala blockchain project that implemented Nakamoto proof-of-stake and an extended-utxo ledger functionality. Furthermore, several of the interfaces and implementations from my previous open-source project, such as the network mini-protocols, multiplexer, and storage design, may be ported to Scarab as they were originally inspired by Cardano specifications and design constraints. Finally, this proposal will also seek to leverage Scalus, another Fund10 open-source proposal, for implementation of the Plutus runtime within the ledger layer. Scalus is an independent effort by Alexander Nemish to provide “a Scala implementation of Cardano Plutus, PlutusTx, including UPLC evaluation machine”. From these starting points, a Scala client implementation is feasible and imminently achievable in the proposed time frame.

What are the main goals for the project and how will you validate if your approach is feasible?

  • The primary objective is to develop a client node implementation in functional Scala that is robust, performant, and compatible with the Haskell cardano-node. Compatibility will be evaluated along several axes including (1) network communication and data transfer, (2) chain extension and header / block validation, (3) transaction execution and utxo state management, (4) integration in multi-client testnet environments.
  • A secondary goal will be to ensure Scarab is capable of processing transactions and blocks efficiently and reliably. This will be measured by compiling performance metrics such as transaction throughput, block verification time, sync speed, and resource usage (CPU, memory).
  • A tertiary goal is the development of language agnostic formal specifications for aiding the development of future alternative node implementations.

Please provide a detailed breakdown of your project’s milestones and each of the main tasks or activities to reach the milestone plus the expected timeline for the delivery.

  • The following milestone total a 50 week or approx. 12 month project duration.
  • Milestone 1: Network layer functionality
  • Projected timeline: 8 weeks
  • Components
  • Mini-protocols & state machines - 2 weeks
  • Over-the-wire serialization - 1 week
  • Node-to-client & node-to-node protocols - 3 weeks
  • Multiplexer - 1 week
  • Peer connection manager - 1 week
  • Milestone 2: Storage (on-disk and in-memory data structures / interfaces)
  • Projected timeline: 8 weeks
  • Components
  • On-disk serialization - 1 week
  • Consensus database(s) - 3 weeks
  • Ledger database - 2 weeks
  • Mempool - 1 week
  • Candidate chain & garbage collection - 1 week
  • Milestone 3: Consensus layer functionality
  • Projected timeline: 12 weeks
  • Components
  • Header & block validation - 2 weeks
  • Chain extension & ledger interface - 2 weeks
  • Chain selection & rollbacks - 2 weeks
  • Epoch management - 2 weeks
  • Bootstrapping - 2 weeks
  • Hard fork combinator - 2 weeks
  • Milestone 4: Ledger layer functionality
  • Projected timeline: 10 weeks
  • Components
  • Chain state & UTxO management - 4 weeks
  • Virtual machine integration - 2 weeks
  • Transaction execution & validation - 4 weeks
  • Milestone 5: Application packaging and testing
  • Projected timeline: 12 weeks
  • Components
  • Configuration - 2 weeks
  • Logging & monitoring - 2 weeks
  • Integration testing - 4 weeks
  • Network integration & benchmarking - 3 weeks
  • Command-line interface - 1 week

Please describe the deliverables, outputs and intended outcomes of each milestone.

  • This project will be managed via a Kanban methodology on a two-week sprint cadence. Sprint reports will be compiled at the conclusion of each sprint and published to Github.
  • Code modules will be considered complete if there are accompanying unit and integration tests that demonstrate compatibility with published specifications and test vectors.
  • Milestone 1: Network layer compatibility
  • Deliverable: A set of network libraries, unit tests, and integration tests will be published to Github which are compatible with the protocols as specified in the Shelley network specification.
  • Milestone 2: Storage
  • Deliverable: A set of storage libraries, unit tests, and integration tests will be published to Github which present a compatible interface for Consensus and Ledger operations as outlined in the Consensus and Storage report
  • Milestone 3: Consensus layer functionality
  • Deliverable: A set of consensus libraries, unit tests, and integration tests will be published to Github which allows for block fetching, header validation, and bootstrapping of a new node.
  • Milestone 4: Ledger layer functionality
  • Deliverable: A set of ledger libraries, unit tests, and integration tests will be published to Github which implement the transaction execution and ledger update mechanisms across the Byron, Shelley, Mary, Alonzo, and Babbage eras.
  • Milestone 5: Application packaging and testing
  • Deliverable: A packaged binary will be published to Github that is compatible with the Haskell cardano-node implementation demonstrated by engaging in multiple rounds of testnets.

Please provide a detailed budget breakdown of the proposed work and resources.

Projected work hours (50 weeks @ 40 hours / week) - 2000 hours

Hourly rate (inclusive of taxes and other expenses) – $75 / hour

Approximate Ada price for conversion ————— $0.30 / Ada

Total budget —————————————– 500,000 Ada

Who is in the project team and what are their roles?

2023—Headshot-a22822.jpg

Dr. James Aman is a web3 practitioner, researcher, and educator. Since his introduction to blockchain in 2015, he has developed several decentralized applications across various blockchain networks and architected protocols such as Ouroboros Taktikos, a regularized Nakamoto proof-of-stake protocol. James currently serves as a faculty member at Rice University where he teaches an introductory blockchain course for undergraduate and graduate students that combines the technical and business impacts of decentralized ledger technologies. James also co-founded Topl, a novel layer-one protocol for building sustainable and inclusive communities. While at Topl, he led the teams responsible for the engineering and research efforts in implementing the Topl protocol including novel implementations of the key-evolving signature scheme and verifiable random functions required by the Ouroboros protocol.

How does the cost of the project represent value for money for the Cardano ecosystem?

This is an ambitious project for a single developer and is only feasible given the high-level of code that may be integrated or reused, the similarity of functional Scala and Haskell, and my own close familiarity with the Cardano ecosystem. Even with those caveats, this proposal is projected to be a full-time year long endeavor but one which is of great importance to achieve the targeted goal of community ownership and decentralization.

I believe this proposal offers excellent value for the investment considering the expertise involved, tax and self-employment overhead, and the current volatility of cryptocurrency markets.

close

Playlist

  • EP2: epoch_length

    Authored by: Darlington Kofa

    3m 24s
    Darlington Kofa
  • EP1: 'd' parameter

    Authored by: Darlington Kofa

    4m 3s
    Darlington Kofa
  • EP3: key_deposit

    Authored by: Darlington Kofa

    3m 48s
    Darlington Kofa
  • EP4: epoch_no

    Authored by: Darlington Kofa

    2m 16s
    Darlington Kofa
  • EP5: max_block_size

    Authored by: Darlington Kofa

    3m 14s
    Darlington Kofa
  • EP6: pool_deposit

    Authored by: Darlington Kofa

    3m 19s
    Darlington Kofa
  • EP7: max_tx_size

    Authored by: Darlington Kofa

    4m 59s
    Darlington Kofa
0:00
/
~0:00