FuelLabs / sway-applications

Swaypplications
https://sway-applications.vercel.app/
Apache License 2.0
1.58k stars 546 forks source link

SwayApps logo

## Overview The purpose of this repository is to contain end-to-end applications that are written in Sway in order to demonstrate what can be built. This means that a project will generally consist of a Sway contract and a user interface in order to interact with the contract however that is not a hard rule. > **Note** > Sway is a language under heavy development therefore the applications may not be the most ergonomic. Over time they should receive updates / improvements in order to demonstrate how Sway can be used in real use cases. ## Repository Structure Each project within this repository is independent of the other projects and thus every project has its own directory with all of the files required to make it work. That being said they are all under the same [CI](.github/workflows/ci.yml) so any updates to a project must make sure that the other projects continue to pass. The following is a visual sample of how the repository is structured. ``` sway-applications/ ├── Project-1 | └── P-1 Directories & files ├── Project-2 | └── P-2 Directories & files ├── LICENSE └── README.md ``` ### Projects #### Asset Management - [Airdrop](./airdrop/) is an asset distribution program where users are able to claim assets given a valid merkle proof. - [Escrow](./escrow) is a third party that keeps an asset on behalf of multiple parties. - [Non-Fungible Native Asset (NFT)](./NFT) is an asset contract which provides unique collectibles, identified and differentiated by IDs, where assets contain metadata giving them distinctive characteristics. - [Fractional Non-Fungible Token (F-NFT)](./fractional-NFT) is a token contract which issues shares or partial ownership upon locking an NFT into a vault. - [Timelock](./timelock) is a contract which restricts the execution of a transaction to a specified time range. - [Native Asset](./native-asset) is a basic asset contract that enables the use of Native Assets on Fuel using existing standards and libraries. #### Decentralized Finance - [English Auction](./english-auction) is an auction where users bid up the price of an asset until the bidding period has ended or a reserve has been met. - [Fundraiser](./fundraiser/) is a program allowing users to pledge towards a goal. - [OTC Swap Predicate](./OTC-swap-predicate) is a predicate that can be used to propose and execute an atomic swap between two parties without requiring any on-chain state. #### Governance - [Decentralized Autonomous Organization (DAO)](./DAO) is an organization where users get to vote on governance proposals using governance assets. - [Multi-Signature Wallet](./multisig-wallet) is a wallet that requires multiple signatures to execute a transaction. #### Other - [Counter-Script](./counter-script/) is a script that calls a contract to increment a counter. - [Name-Registry](./name-registry/) allows users to perform transactions with human readable names instead of addresses. - [Oracle](./oracle) is a smart contract that provides off-chain data to on-chain applications. #### Games - [TicTacToe](./TicTacToe) is a game where two players compete to align three markers in a row. #### Low maintenance The below apps are updated to the latest version, but may have broken tests or broken functionality. Use at your own discretion. - [Automated Market Maker (AMM)](./AMM) is a decentralized exchange protocol that manages liquidity pools supplied by its users and determines prices algorithmically while exchanging assets. ## Running a project If you wish to run any of the projects then clone this repository and go through the general [installation](https://fuellabs.github.io/sway/) steps required to use our tools. Any instructions related to running a specific project will be found within the README.md in the root of that project. The projects are pinned to specific versions which can be seen at the top of the README.md inside the `//project` directory and inside the `fuel-toolchain.toml`. ## Contributing Check out the [book](https://swayapps.fuel.network/book/) for more info!