This repository contains the core smart contracts for the Swaplace Protocol; The lightest Swap protocol in the market.
- Contracts cannot be upgraded.
- Contracts have no ownership.
- Contracts don't charge fees.
- There are no external contract dependencies.
- The protocol operates using available allowances.
This repository is subjected to incentives for the community to contribute to the project. The incentive distribution and amount are being discussed but the eligibility has already started.
- Create Swaps: A Swap has an
owner
and anallowed
address. Theowner
is the one that can cancel the swap while theallowed
address is the one that can execute the swap but anyone can accept if it's set as the Zero Address. A Swap also has anexpiry
period in seconds. The Swap can only be executed before the expiry period is reached. TheAsset
type represents on one hand the bidding assets and on the other hand the asking assets.
struct Swap {
address owner;
address allowed;
uint256 expiry;
Asset[] biding;
Asset[] asking;
}
-
Accept Swaps: You can accept swaps that have an
allowed
address equal to your or theZero Address
. As long as you provide the asked assets. -
Cancel Swaps: You can cancel swaps that haven't been
expired
. -
Swap Factory: Aids new swap creations to be used on Swaplace. Check
contracts/SwapFactory.sol
.
You should install the dependencies using Yarn (used in the project) or npm to deploy this code. The project uses Hardhat as a development environment. Which relies on Node.js (Recommended version v18.16.0).
To make sure that NodeJS is installed correctly, open the integrated terminal and run the following command:
node -v
Install Yarn globally and check if the version appears:
npm install --global yarn
yarn --version
Install the dependencies using Yarn:
yarn install
Install the dependencies using npm:
npm install
The project comes with a .env.example
file. You should rename it to .env
and fill the variables with your values. Most RPC providers offer free testnet nodes. You can use Alchemy or Infura to get a free node.
WARNING: The private keys used in the .env
file are from hardhat accounts. They are not meant to be used in production.
Run the tests in localhost
or try the contracts in a desired network by specifying the network name in hardhat.config.js
.
yarn test
yarn testnet <network>
Deploy the contracts in the desired network according to the networks available in hardhat.config.js
.
yarn deploy <network>
- To know more about how you can contribute see our notion page.