forked from LF-Decentralized-Trust-labs/paladin
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request LF-Decentralized-Trust-labs#369 from LF-Decentrali…
…zed-Trust-labs/docs-migration Working branch for docs
- Loading branch information
Showing
58 changed files
with
684 additions
and
155 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,79 +1,46 @@ | ||
# Paladin | ||
|
||
Paladin is a privacy preserving transaction manager for Ethereum. | ||
|
||
## Architecture overview | ||
|
||
<big>**⚠ WORK IN PROGRESS ⚠**</big> | ||
|
||
data:image/s3,"s3://crabby-images/59d1c/59d1c0280195508d450857b5ada7e476f8c408e3" alt="Paladin Architecture Overview" | ||
|
||
- Paladin is a sidecar process that runs alongside a Hyperledger Besu node | ||
- Learn more about [Runtime Architecture](./architecture/runtime_architecture.md) | ||
- Paladin provides **secure channels** of communication to other Paladins over which it can selectively disclose private data | ||
- Learn more about [Private Data Transports & Endpoint Registry](./architecture/data_and_registry.md) | ||
- Paladin supports Privacy Preserving Smart Contracts, and provides samples out-of-the-box | ||
- Each smart contract has a part of that runs as a EVM smart contract on an **unmodified** EVM blockchain, and a part that runs as part of Paladin | ||
- Learn more about [ledger layers](./architecture/ledger_layers.md) | ||
- _Some_ implement `tokens backed by Zero-knowledge Proofs` | ||
- Learn more about [Zeto](./architecture/zeto.md) | ||
- _Some_ implement `tokens backed by Notary Certificates` (issuer/signatory endorsed tokens) | ||
- Learn more about [Noto](./architecture/noto.md) | ||
- _Some_ implement domains of `EVM Private Smart Contracts` running in `Privacy Groups` | ||
- Learn more about [Pente](./architecture/pente.md) | ||
> Provides function similar to that provided by the [Tessera](https://github.com/consensys/tessera) project (successor to [Constellation](https://github.com/Consensys/constellation)) with additional interoperability and other enhancements | ||
- _All_ use the EVM base ledger as the source of truth for order and finality of transactions | ||
- _All_ are `atomically interoperable` via the base EVM ledger | ||
- Learn more about [Atomic interop of privacy preserving smart contracts](./architecture/atomic_interop.md) | ||
- _All_ store state in the EVM base ledger in a securely masked format preserving | ||
- **Confidentiality**: the data is protected via cryptography, and selectively disclosed on a need to know basis | ||
- **Anonymity**: the parties involved in a transaction, or set of transactions, cannot be determined without access to the confidential data | ||
- Learn more about [Privacy](./privacy.md) | ||
- Paladin provides a high performance transaction manager that coordinates transaction assembly, submission and confirmation across Paladin runtimes | ||
- To any EVM smart contract directly on the **base EVM ledger** | ||
- To EVM Private Smart Contracts in **privacy groups**, backed by privacy preserving smart contracts | ||
- To Privacy Preserving Smart Contracts that use **UTXO models** for highly scalable private tokens | ||
- For atomic swaps between privacy preserving smart contracts | ||
- Learn more about [Distributed transaction management](./architecture/transaction_manager.md) | ||
- Paladin provides enterprise grade key management integration | ||
- Managing many keys/identities within a single Paladin runtime | ||
- With modular integration of remote HSM-backed key management systems | ||
- Supporting native Ethereum, EIP-712, and ZKP compatible cryptography | ||
- Learn more about [Signing and Key Management](./architecture/key_management.md) | ||
- Paladin provides a development, configuration, and deployment pipeline for privacy preserving smart contracts | ||
- Definition of the smart contract functions, inputs and events | ||
- Supporting EVM programmable private smart contracts and UTXO based token models | ||
- A set of gRPC code plug points for private lifecycle coordination and state management | ||
- Programming wallet functions - coin/state selection | ||
- Programming endorsement coordination / signature collection / sequencer selection | ||
- Programming transaction verification & proof generation | ||
- Support for `Java` and `WebAssembly` high performance code modules | ||
- Learn more about the [Paladin programming model](./architecture/programming_model.md) | ||
|
||
## Dev environment setup | ||
Paladin brings true programmable privacy to the world's most popular smart contract platform. | ||
|
||
data:image/s3,"s3://crabby-images/c2ae7/c2ae773ded930fb517bed2ebb30d55d2b8a0393a" alt="Paladin" | ||
|
||
## Documentation | ||
|
||
Learn more about Paladin here: | ||
|
||
- https://lf-decentralized-trust-labs.github.io/paladin/head | ||
|
||
data:image/s3,"s3://crabby-images/711e0/711e098b0a1834db714c9ef27ed111b59c4be1bc" alt="Paladin" | ||
|
||
## Getting started with Paladin | ||
|
||
Get a 3-node Paladin network running with Besu on your laptop: | ||
|
||
- https://lf-decentralized-trust-labs.github.io/paladin/head/getting-started | ||
|
||
data:image/s3,"s3://crabby-images/8dced/8dced5432776961ed13edc1cde52560024918de4" alt="Paladin" | ||
|
||
## Getting set up for development of Paladin | ||
|
||
Welcome! | ||
|
||
### Building locally | ||
|
||
Install the following pre-reqs: | ||
- JDK [version 21](https://jdk.java.net/archive/) which is compatible with [Gradle version 8.4](./gradle/wrapper/gradle-wrapper.properties) | ||
- install [protoc](https://grpc.io/docs/protoc-installation/) | ||
- install [docker with compose plugin](https://docs.docker.com/compose/install/) | ||
- install npm | ||
- JDK - https://adoptium.net/download/ | ||
- Protoc - https://grpc.io/docs/protoc-installation/ | ||
- Docker - https://docs.docker.com/compose/install/ | ||
- NodeJS - https://nodejs.org/en/download/package-manager | ||
|
||
|
||
Run the following command to build Paladin: | ||
Then the following command to build Paladin via Gradle: | ||
|
||
```shell | ||
./gradlew build | ||
``` | ||
|
||
## How to run Paladin | ||
|
||
TBD | ||
|
||
### Build Paladin docker image | ||
### Running a full development environment | ||
|
||
TBD | ||
Check out the operator readme: | ||
|
||
## Repo structure | ||
This is a [Monorepo](https://en.wikipedia.org/wiki/Monorepo). To avoid overcomplicating monorepo setup, you should adhere to the following practices: | ||
1. One folder per repo. (a "repo" contains a set of code that could be separated into a standalone Github repo) | ||
2. You can use folders to group repos, however, nested repos are not allowed. | ||
- [operator/README.md](operator/README.md) |
Binary file not shown.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
data:image/s3,"s3://crabby-images/d2157/d2157e2592629b1618e183240c30c4db18399674" alt="Domain API lifecycle" | ||
|
||
> Work in progress docs page |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
# Paladin | ||
|
||
Paladin is a privacy preserving transaction manager for Ethereum. | ||
|
||
## Architecture overview | ||
|
||
data:image/s3,"s3://crabby-images/2a590/2a590b2a897bcdc8c8d77f35e105eac1005f5bd1" alt="Paladin Architecture Overview" | ||
|
||
- Paladin is a sidecar process that runs alongside a Hyperledger Besu node | ||
- Learn more about [Runtime Architecture](./runtime_architecture.md) | ||
- Paladin provides **secure channels** of communication to other Paladins over which it can selectively disclose private data | ||
- Learn more about [Private Data Transports & Endpoint Registry](./data_and_registry.md) | ||
- Paladin supports Privacy Preserving Smart Contracts, and provides samples out-of-the-box | ||
- Each smart contract has a part of that runs as a EVM smart contract on an **unmodified** EVM blockchain, and a part that runs as part of Paladin | ||
- Learn more about [ledger layers](./ledger_layers.md) | ||
- _Some_ implement `tokens backed by Zero-knowledge Proofs` | ||
- Learn more about [Zeto](./zeto.md) | ||
- _Some_ implement `tokens backed by Notary Certificates` (issuer/signatory endorsed tokens) | ||
- Learn more about [Noto](./noto.md) | ||
- _Some_ implement domains of `EVM Private Smart Contracts` running in `Privacy Groups` | ||
- Learn more about [Pente](./pente.md) | ||
> Provides function similar to that provided by the [Tessera](https://github.com/consensys/tessera) project (successor to [Constellation](https://github.com/Consensys/constellation)) with additional interoperability and other enhancements | ||
- _All_ use the EVM base ledger as the source of truth for order and finality of transactions | ||
- _All_ are `atomically interoperable` via the base EVM ledger | ||
- Learn more about [Atomic interop of privacy preserving smart contracts](./atomic_interop.md) | ||
- _All_ store state in the EVM base ledger in a securely masked format preserving | ||
- **Confidentiality**: the data is protected via cryptography, and selectively disclosed on a need to know basis | ||
- **Anonymity**: the parties involved in a transaction, or set of transactions, cannot be determined without access to the confidential data | ||
- Learn more about [Privacy](./privacy.md) | ||
- Paladin provides a high performance transaction manager that coordinates transaction assembly, submission and confirmation across Paladin runtimes | ||
- To any EVM smart contract directly on the **base EVM ledger** | ||
- To EVM Private Smart Contracts in **privacy groups**, backed by privacy preserving smart contracts | ||
- To Privacy Preserving Smart Contracts that use **UTXO models** for highly scalable private tokens | ||
- For atomic swaps between privacy preserving smart contracts | ||
- Learn more about [Distributed transaction management](./transaction_manager.md) | ||
- Paladin provides enterprise grade key management integration | ||
- Managing many keys/identities within a single Paladin runtime | ||
- With modular integration of remote HSM-backed key management systems | ||
- Supporting native Ethereum, EIP-712, and ZKP compatible cryptography | ||
- Learn more about [Signing and Key Management](./key_management.md) | ||
- Paladin provides a development, configuration, and deployment pipeline for privacy preserving smart contracts | ||
- Definition of the smart contract functions, inputs and events | ||
- Supporting EVM programmable private smart contracts and UTXO based token models | ||
- A set of gRPC code plug points for private lifecycle coordination and state management | ||
- Programming wallet functions - coin/state selection | ||
- Programming endorsement coordination / signature collection / sequencer selection | ||
- Programming transaction verification & proof generation | ||
- Support for `Java` and `WebAssembly` high performance code modules | ||
- Learn more about the [Paladin programming model](./programming_model.md) | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.