Skip to content

Commit

Permalink
add a README and a bit of natspec
Browse files Browse the repository at this point in the history
  • Loading branch information
0age committed Oct 4, 2024
1 parent e4cd4eb commit 20b06be
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 52 deletions.
77 changes: 25 additions & 52 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,66 +1,39 @@
## Foundry
# The Compact 🤝
**Compact** *[noun]*: an agreement or covenant between two or more parties.
**Compact** *[transitive verb]*: to make up by connecting or combining.
**Compact** *[adjective]*: occupying a small volume by reason of efficient use of space.

**Foundry is a blazing fast, portable and modular toolkit for Ethereum application development written in Rust.**
> :warning: This is an early-stage contract under active development; it has not yet been properly tested, reviewed, or audited.
Foundry consists of:
## Summary
The Compact is an ownerless ERC6909 contract that facilitates the voluntary formation (and, if necessary, involuntary dissolution) of "resource locks."

- **Forge**: Ethereum testing framework (like Truffle, Hardhat and DappTools).
- **Cast**: Swiss army knife for interacting with EVM smart contracts, sending transactions and getting chain data.
- **Anvil**: Local Ethereum node, akin to Ganache, Hardhat Network.
- **Chisel**: Fast, utilitarian, and verbose solidity REPL.
Resource locks are entered into by ERC20 or native token holders. Once a resource lock has been established, holders can commit to allow interested parties to claim their tokens once an "oracle" indicated by the token holder has attested to the specified conditions.

## Documentation
These resource locks are mediated by "allocators" who are tasked with attesting to the availability of the underlying token balances and preserving the balances required for the commitments they have attested to; in other words, allocators ensure that token holders do not "double-spend," transfer, or withdraw any token balances that are already committed to a specific intent.

https://book.getfoundry.sh/
Once a token holder and their designated allocator have both committed to a claimable token condition, a "claimant" may then immediately perform the attached condition (such as delivering another token on some destination chain) and then claim the allocated tokens upon attestation from the oracle mediating that condition.

## Usage
The Compact effectively "activates" any deposited tokens to be instantly spent or swapped across arbitrary, asynchronous environments as long as:
- the claimant is confident that the allocator is sound and will not leave the resource lock underallocated,
- the token owner and the claimant are both confident that the oracle is sound and will not report erroneously, and
- the token owner is confident that the allocator will not unduly censor fully allocated requests.

### Build
Token owners have recourse from potential censorship in the form of a "forced withdrawal." When depositing tokens into a resource lock, the token owner provides a "reset period" as a parameter. Then, the token owner can initiate a forced withdrawal at any point; after the reset period has elapsed, the full token balance can be withdrawn regardless of any pending claims on their balance. In the case of cross-chain swaps, reset periods only need to be long enough for the claim to finalize (generally some multiple of the slowest blockchain involved in the swap).

```shell
$ forge build
```

### Test

```shell
$ forge test
```

### Format

```shell
$ forge fmt
```

### Gas Snapshots
Claimants must bear varying degrees of trust assumptions with regards to allocators, with the potential design space including reputation-based systems, trusted execution environments, smart-contract-based systems, or even dedicated rollups. The Compact takes a neutral stance on implementations of both allocators and oracles, and instead treats them both as a "black box" but each with a simple and consistent interface.

```shell
$ forge snapshot
## Setup
```
# install foundry if needed
$ curl -L https://foundry.paradigm.xyz | bash
### Anvil
# clone repo
$ git clone git@github.com:Uniswap/the-compact.git && cd the-compact
```shell
$ anvil
```

### Deploy

```shell
$ forge script script/Counter.s.sol:CounterScript --rpc-url <your_rpc_url> --private-key <your_private_key>
```

### Cast
# install dependencies & libraries
$ forge install
```shell
$ cast <subcommand>
```

### Help

```shell
$ forge --help
$ anvil --help
$ cast --help
# run basic tests
$ forge test
```
8 changes: 8 additions & 0 deletions src/TheCompact.sol
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,14 @@ import {
import { IOracle } from "./interfaces/IOracle.sol";
import { IAllocator } from "./interfaces/IAllocator.sol";

/**
* @title The Compact
* @custom:version 1 (early-stage proof-of-concept)
* @author 0age (0age.eth)
* @notice The Compact is an ownerless ERC6909 contract that facilitates the voluntary
* formation (and, if necessary, involuntary dissolution) of "resource locks."
* This contract has not yet been properly tested, audited, or reviewed.
*/
contract TheCompact is ERC6909 {
using IdLib for uint256;
using IdLib for address;
Expand Down

0 comments on commit 20b06be

Please sign in to comment.