Skip to content

Latest commit

 

History

History
90 lines (61 loc) · 2.74 KB

README.md

File metadata and controls

90 lines (61 loc) · 2.74 KB

Bruja

Bruja network is a decentralized platform which connects users enabling them to share their unused computing power or access resources as needed. Bruja leverages a substrate based blockchain as a settlement layer, ink smart contract to facilitate job requests, and libp2p allow communication between requesters and workers.

Architecture

The bruja network leverges a substrate blockchain and ink smart contract as data backends and settlement layer. Requesters submit job request extrinsics to the Catalog smart contract. The contract emits a job request event which Workers will respond to. If the workers choose the job request, the will send a propagate a message through the network until the requester is reached. The requester will then send a raw wasm code to the worker so that it can execute it via Wasmtime.

Development

This project levereges mise to manage dev tools. Follow the directions here to install.

Install project dependencies

mise install

Install Cargo Make

cargo install --no-default-features cargo-make

Install Dev Dependencies

cargo make install-dev-dependencies

You will need to install proto. To install on macOs run the following command:

brew install protobuf

Build

Run the following command to build bruja project:

cargo make cargo-build

Run Locally

Start a local substrate node in one terminal:

cargo make local-node

In a seperate terminal, instantiate catalog contract with the following command:

export CONTRACT_ADDRESS=$(cargo run -p scripts instantiate --suri //Alice --file target/ink/catalog/catalog.contract)

In another seperate terminal, start the worker:

cargo run -p worker start --address <contract address>

In the same terminal which you used to instantiate the contract, run the following command to submit a job to the network:

cargo run -p requester submit-job --address $CONTRACT_ADDRESS --code-path crates/integration_tests/tests/requester_worker/work_bg.wasm --parameters 10,14 --function-name add --value 100

Testing

Run the following command to run unit tests:

cargo test

Run the following command to run smart contract integration tests:

cargo make contract-tests

Run the following command to perform Requester - Worker Integration tests:

cargo make requester-worker

Run the following command to perform P2P Integration tests:

cargo make p2p-tests