What are token lists? Uniswap Token Lists is a specification for lists of token metadata (e.g. address, decimals, ...) that can be used by any dApp interfaces that needs one or more lists of tokens. Anyone can create and maintain a token list, as long as they follow the specification. Specifically an instance of a token list is aJSONblob that contains a list ofERC20token metadata for use in dApp user interfaces. Token list JSON must validate against theJSON schemain order to be used in the Uniswap Interface. Tokens on token lists, and token lists themselves, are tagged so that users can easily find tokens. JSON Schema $id The JSON schema ID ishttps://uniswap.org/tokenlist.schema.json Validating token lists This package does not include code for token list validation. You can easily do this by including a library such asajvto perform the validation against the JSON schema. The schema is exported from the package for ease of use. Authoring token lists Manual The best way to manually author token lists is to use an editor that supports JSON schema validation. Most popular code editors do, such asIntelliJorVSCode. Other editors can be foundhere. The schema is registered in theSchemaStore, and any file that matches the pattern*.tokenlist.jsonshouldautomatically utilizethe JSON schema for thesupported text editors. In order for your token list to be able to be used, it must pass all JSON schema validation. Automated If you want to automate token listing, e.g. by pulling from a smart contract, or other sources, you can use this npm package to take advantage of the JSON schema for validation and the TypeScript types. Otherwise, you are simply working with JSON. All the usual tools apply, e.g.: import { TokenList, schema } from '@uniswap/token-lists' // generate your token list however you like. const myList: TokenList = generateMyTokenList(); // use a tool like `ajv` to validate your generated token list validateMyTokenList(myList, schema); // print the resulting JSON to stdout process.stdout.write(JSON.stringify(myList)); Semantic versioning Lists include aversionfield, which followssemantic versioning. List versions must follow the rules: Increment major version when tokens are removed Increment minor version when tokens are added Increment patch version when tokens already on the list have minor details changed (name, symbol, logo URL, decimals) Changing a token address or chain ID is considered both a remove and an add, and should be a major version update. Note that list versioning is used to improve the user experience, but not for security, i.e. list versions are not meant to provide protection against malicious updates to a token list; i.e. the list semver is used as a lossy compression of the diff of list updates. List updates may still be diffed in the client dApp. Deploying your list Once you have authored the list, you can make it available at any URI. Prefer pinning your list to IPFS (e.g. viapinata.cloud) and referencing the list by an ENS name that resolves to thecontenthash. If hosted on HTTPS, make sure the endpoint is configured to send an access-control-allow-origin header to avoid CORS errors. Linking an ENS name to the list An ENS name can be assigned to an IPFS hash via thecontenthashtext record. This is the preferred way of referencing your list. Examples You can find a simple example of a token list intest/schema/example.tokenlist.json. A snapshot of the Uniswap default list encoded as a token list is found intest/schema/bigexample.tokenlist.json
Stars
1
Forks
0
Watchers
1
Open Issues
0
Overall repository health assessment
No language data available
No package.json found
This might not be a Node.js project
1
commits