Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/centrifuge/tinlake

Smart contracts for Tinlake, the on-chain securitization protocol for real-world assets
https://github.com/centrifuge/tinlake

ethereum rwa solidity

Last synced: 2 months ago
JSON representation

Smart contracts for Tinlake, the on-chain securitization protocol for real-world assets

Awesome Lists containing this project

README

        

# Tinlake Contracts

Open source implementation of Tinlake in Solidity. This repository contains the core contracts of Tinlake.

Tinlake is a set of smart contracts that allows companies and individuals to use tokenized non-fungible real-world assets as collateral to obtain liquidity.

For learning more about how Tinlake works, you can visit the [Tinlake documentation](https://developer.centrifuge.io/tinlake/overview/introduction/).

## Getting started

Tinlake uses [foundry](https://github.com/foundry-rs/foundry) for development. Please install the [foundry client](https://getfoundry.sh/). Then, run the following command to install the dependencies:

```bash
forge update
```

## Testing

The tests for Tinlake are written in Solidity

### Run all tests

```bash
forge test
```

### Run specific tests

A regular expression can be used to only run specific tests.

```bash
forge test -m
forge test -m testName
forge test -m ':ContractName\.'
```

## Deployment

To deploy Tinlake, you need to set up a `.env` file with the deployment parameters. A sample file can be found in `.env.example`.

To confirm that the `.env` file is set up correctly, run:
```bash
./bin/env-check.sh
```

Once you've double checked all the environment variables, the deployment can be started:
```bash
forge script script/deploy.s.sol:DeployScript --rpc-url $RPC_URL --private-key $PRIVATE_KEY --broadcast --verify --etherscan-api-key $ETHERSCAN_KEY -vvvv
```

When the deployment is complete, you can print the list of deployed contracts:
```bash
ROOT_CONTRACT=0x0 forge script script/print_contracts.s.sol:PrintContractsScript --rpc-url $RPC_URL -vvvv
```

And you can also run the set of RPC tests against the newly deployed pool:
```bash
ROOT_CONTRACT=0x0 MAKER_RPC_TESTS=false forge script script/run-rpc-tests.s.sol:RunRPCTests --rpc-url $RPC_URL
```

## Community

Join our public Discord: [Centrifuge Discord](https://centrifuge.io/discord/).