Pull-mirror of github.com/Sulkta-Coop/pallas. Canonical lives on GitHub; this is a LAN-fast read-only cache.
Find a file
2021-12-08 09:49:31 -03:00
pallas chore: bump versions 2021-12-08 09:49:31 -03:00
pallas-alonzo chore: bump versions 2021-12-08 09:49:31 -03:00
pallas-blockfetch Improve cargo metadata 2021-12-02 23:06:37 -03:00
pallas-chainsync Improve cargo metadata 2021-12-02 23:06:37 -03:00
pallas-handshake Improve cargo metadata 2021-12-02 23:06:37 -03:00
pallas-localstate Improve cargo metadata 2021-12-02 23:06:37 -03:00
pallas-machines Improve cargo metadata 2021-12-02 23:06:37 -03:00
pallas-multiplexer Improve cargo metadata 2021-12-02 23:06:37 -03:00
pallas-txsubmission Improve cargo metadata 2021-12-02 23:06:37 -03:00
.gitignore Implement multiplexer and mini-protocols PoC 2021-11-20 11:33:45 -03:00
Cargo.toml Add local state query mini-protocol naive implementation 2021-11-28 16:42:51 -03:00
LICENSE Fill in place holders 2021-12-02 19:55:54 -03:00
README.md Add local state query mini-protocol naive implementation 2021-11-28 16:42:51 -03:00
rustfmt.toml Implement multiplexer and mini-protocols PoC 2021-11-20 11:33:45 -03:00

Pallas

Rust-native building blocks for the Cardano blockchain ecosystem.

Introduction

Pallas is an expanding collection of modules that re-implements common Cardano logic in native Rust. This crate doesn't provide any particular application, it is meant to be used as a base layer to facilitate the development of higher-level use-cases, such as explorers, wallets, etc (who knows, maybe even a full node in the far away future).

Unboxing

The repository is organized as a Cargo workspace. Each Pallas "building block" lives in its own crate. The root pallas crate serves as an all-in-one dependency that re-exports all of the other modules in an hierarchically organized fashion, using Cargo features to tailor the setup for each use-case.

As already explained, Pallas aims at being an expanding set of components. The following tables describe the currently available crates, as well as the planned ones.

Ouroboros Network

Crates Description
pallas-machines A framework for implementing state machines for Ouroboros network mini-protocols
pallas-multiplexer Multithreaded Ouroboros multiplexer implementation using mpsc channels
pallas-handshake Implementation of the Ouroboros network handshake mini-protocol
pallas-blockfetch Implementation of the Ouroboros network blockfetch mini-protocol
pallas-chainsync Implementation of the Ouroboros network chainsync mini-protocol
pallas-localstate Implementation of the Ouroboros network local state query mini-protocol
pallas-txsubmission Implementation of the Ouroboros network txsubmission mini-protocol

Ouroboros Consensus

Crates Description
pallas-leadership Implementation of the slot leadership selection algorithm
pallas-selection Implementation of the consensus chain-selection algorithm

Ouroboros Ledger

Crates Description
pallas-alonzo Ledger primitives and cbor codec for the Alonzo era
pallas-ticking Time passage implementation for consensus algorithm
pallas-applying Logic for validating and applying new blocks and txs to the chain state
pallas-forecasting Ledger forecasting algorithm to be used by the consensus layer

Etymology

Pallas: (Greek mythology) goddess of wisdom and useful arts and prudent warfare;