This repository contains multiple sub-projects implementing different flavors of the FA2 token standard.
shared directory contains common code shared by all sub-project. The FA2-related LIGO artifacts are:
- shared/fa2 - FA2 interface and standard errors definition.
- shared/fa2/lib - Helpers, various bits and pieces
used by the FA2 implementation.
- shared/fa2/lib/fa2_operator_lib.mligo - helper functions to manage and validate FA2 operators.
- shared/fa2/lib/fa2_owner_hook_lib.mligo - helper functions to support sender/receiver hooks.
- shared/fa2_modules - modules implementing additional contract
functionality to be mixed into the final FA2 contract.
- shared/fa2_modules/simple_admin.mligo - implementation of the admin entry points that let to pause/unpause the contract and change the admin.
- shared/fa2_modules/token_admin.mligo - implementation of the admin entry points that let change the admin and pause/unpause transfers per individual tokens.
- shared/fa2_clients - FA2 client contracts used for testing.
The sub-projects symlink shared code into their respective directories. Each
sub-project has ligo
directory that contains all LIGO-related files:
- symlinked shared common code.
src
directory with the LIGO implementation of the particular FA2 contract(s).out
directory with the contracts compiled to Michelson.
The design of each FA2 contract follows the same pattern and consists of the following source files:
fa2_xxx_token.mligo
- implementation of the FA2 entry points and FA2 core logic.token_manager.mligo
- implementation of mint, burn, create token(s) entry points.fa2_xxx_asset.mligo
- assembly of different modules into a complete FA2 contract. The assembly includes FA2 entry points and core logic (fa2_xxx_token.mligo
), mint/burn entry points (token_manager.mligo
) and the administrator entry points (shared/fa2_modules/simple_admin.mligo).
fa2_single_asset.mligo implementation of the FA2 contract that supports single fungible tokens (a.k.a ERC-20).
fa2_single_asset_with_hooks.mligo implementation of the FA2 contract that supports single fungible tokens (a.k.a ERC-20) and sender/receiver hooks.
fa12_lorentz.tz implementation of the FA1.2 contract that supports single fungible tokens (a.k.a. ERC-20).
fa2_multi_asset.mligo implementation of the FA2 contract that supports multiple fungible tokens (a.k.a. ERC-1155).
fa2_granular_multi_asset.mligo implementation of the FA2 contract that supports multiple fungible tokens (a.k.a. ERC-1155) that allows pausing/un-pausing transfers on individual tokens.
fa2_multi_asset.mligo implementation of the FA2 contract that supports multiple fungible tokens (a.k.a. ERC-1155) and sender/receiver hooks.
fa2_nft_asset.mligo implementation of the NFT FA2 contract (a.k.a. ERC-721). The contract supports multiple "families" of NFT tokens that share the same token metadata.
fa2_fixed_collection_asset.mligo implementation of the fixed collection of NFT tokens (a.k.a. ERC-721). The FA2 contract is originated with the predefined set of NFT tokens. Tokens cannot be minted or burned.
fractional_dao.mligo implementation of DAO that manages fractional ownership of NFT tokens. The DAO is the owner of an NFT token in the corresponding FA2 NFT contract and also manages fractional ownership fungible token for each owned NFT. Holders of the linked ownership fungible tokens can vote (directly or using signed permit) on transfer of the NFT token to some other address.