Prerequisites for a coin to be compatible with Komodo DeFi Framework
Before a coin can be listed in Komodo DeFi Framework, it needs to be confirmed for compatibility, and present within the Komodo Platform coins repository.
The information below details the requirements for creating a working coins configuration file and submitting a successful pull request to the coins repository. Please contact our support team in the #dev-support channel on the Komodo Platorm Discord if you have any questions or need assistance with performing a test swap.
Different platforms & protocols vary slightly in what data is required. Review the parameter descriptions and examples below to understand what information is needed to list your coin.
| Parameter | Type | Description | 
|---|---|---|
| coin | string | Ticker of the coin/token. If the coin is a token, please use COIN-PROTOCOLas ticker, egUSDC-BEP20. | 
| name | string | This is the value which is expected to be default data directory name for that coin - e.g. if coin's name is litecointhen it's expected data directory on~/.litecoin/on Linux,~/Library/Applications Support/Litecoin/on Mac,%AppData%\Litecoinon Windows. Please keep this key's value in small letters only. | 
| fname | string | The full name of the coin/token. | 
| mm2 | integer | Indicates trading compatibility with Komodo DeFi Framework API. 1is compatible,0is not compatible. Non-compatible coins may still be listed aswallet onlyin Komodo DeFi Framework apps. | 
| required_confirmations | integer | Defaults to 1. The number of confirmations Komodo DeFi Framework will wait for during the swap. WARNING, this setting affects the security of the atomic swap. 51% attacks (double spending) are a threat and have been succesfully conducted in the past. You can find a collection of coins and the theoretical cost of a 51% attack here. Please be aware that some of the coins supported by Komodo DeFi Framework may be vulnerable to such attacks, so consider using higher confirmation values for them, especially when dealing with large amounts. | 
| requires_notarization | boolean | Defaults to false. For coins protected by dPoW can be set totruewait for a notarization when sending transactions during a swap. Iftrue,"required_confirmations"must be set to2or higher. | 
| decimals | integer | Defines the number of digits after the decimal point that should be used to display the orderbook amounts, balance, and the value of inputs to be used in the case of order creation or a withdrawtransaction. The default value used for a UTXO type coin (Bitcoin Protocol) is8and the default value used for a ERC20 Token is18. It is very important for this value to be set correctly. For example, if this value was set as9for BTC, a command to withdraw1 BTCtries to withdraw10^9satoshis of Bitcoin, i.e.,10 BTC | 
| protocol | string | Contains the coin protocol "type"(UTXO, ETH, etc.) and specific protocol configuration -"protocol_data"object that can have arbitrary format. | 
| orderbook_ticker | string | If set, coins with the same value will share the same orderbook. For example, if BTC-SegwitandBTC-BEP20are set with"orderbook_ticker":"BTC"the same orderbook is returned for KMD/BTC, KMD/BTC-BEP20 and KMD/BTC-Segwit pairs. | 
| sign_message_prefix | string | Optional, required to allow for message signing in Komodo DeFi Framework API. Can normally be found within a projects github repository [example] and follows a standard format like "Komodo Signed Message:\n" | 
The following rpc methods should be available.
estimatefee
getblock
getblockhash
getinfo
getrawtransaction
gettxout
importaddress
listunspent
listreceivedbyaddress
listtransactions
sendrawtransaction
| Parameter | Type | Description | 
|---|---|---|
| name | string | This is the value which is expected to be default data directory name for that coin - e.g. if coin's name is litecointhen it's expected data directory on~/.litecoin/on Linux,~/Library/Applications Support/Litecoin/on Mac,%AppData%\Litecoinon Windows. Please keep this key's value in small letters only. | 
| rpcport | integer | The coin's default RPC port. It is expected that it doesn't conflict with any existing coin in the coins db. | 
| pubtype | integer | This information can be found in source code of a coin project in files like src/init.cpp,src/base58.h, andsrc/chainparamsbase.hif the project is following the bitcoin source code directory/files structure. If unsure, then please have these confirmed by that coin/project's developers to ensure it is correct. | 
| p2shtype | integer | This information can be found in source code of a coin project in files like src/init.cpp,src/base58.h, andsrc/chainparamsbase.hif the project is following the bitcoin source code directory/files structure. If unsure, then please have these confirmed by that coin/project's developers to ensure it is correct. | 
| wiftype | integer | This information can be found in source code of a coin project in files like src/init.cpp,src/base58.h, andsrc/chainparamsbase.hif the project is following the bitcoin source code directory/files structure. If unsure, then please have these confirmed by that coin/project's developers to ensure it is correct. | 
| txfee | integer | The default transaction fee (in satoshi). Komodo DeFi Framework uses this as the default transaction fee value when making atomic swap transactions. If set to 0, Komodo DeFi Framework will use a dynamic fee based on output fromestimatesmartfee. | 
| overwintered | integer | Must be 1if Overwinter upgrade was activated for the coin. Defaults to0. | 
| taddr | integer | Optional. Is only relevant for coins that forked the Zcash protocol and have both transparent addresses and z-addresses. The value to be set for this key can be found from the file src/chainparams.cppof the coin's source code and it is the first value present in bothbase58Prefixes[PUBKEY_ADDRESS]andbase58Prefixes[SCRIPT_ADDRESS]. But it has to be converted to decimal from HEX. So ifbase58Prefixes[PUBKEY_ADDRESS]={0x1C,0xB8}, thetaddris0x1Ccoverted to decimal. As 0x1C in HEX = 28 in decimal, the entry in the json would be"taddr" : 28 | 
| force_min_relay_fee | boolean | If truefor coins with dynamic fees, when a new transaction is generated, Komodo DeFi Framework  will check whether the total fee set (sat * tx size) is lower than relay fee and will use the relay fee instead. Defaults tofalse. | 
| mtp_block_count | integer | Optional. Number of blocks to be used for the calculation of median time past. Must be greater than0. Default value is11. While this parameter is applicable only in the case of KMD reward calculation for now, it will be used for calculating locktimes to be set for the atomic swap refund transactions. | 
| estimate_fee_mode | string | Sets the fee mode for the estimatesmartfeecall. Supported values are:ECONOMICAL,CONSERVATIVE,UNSET. Please note that some coins may not support some of these modes. Makes no effect for coins that do not have theestimatesmartfeeRPC. | 
| address_format | object | Optional. Overwrites the address format from coins file, if set. A standard AddressFormat object. | 
| isPoS | integer | Optional, defaults to 0. A value of1indicates the coin uses proof of stake, so transactions created will have thenTimefield. | 
| segwit | Boolean | If true, Komodo DeFi Framework  will use toP2SHsegwit addresses. | 
| version_group_id | integer | Optional, used by Zcash (and its forks') transactions. | 
| consensus_branch_id | integer | Optional, used in Zcash (and its forks') transactions' signature hash calculation. | 
| mature_confirmations | integer | Number of blockchain confirmations required for coinbase output to be considered mature (spendable). | 
| gas_fee_estimator | string | Optional. Set as providerto source fee market information via Infura or Blocknative. Set tosimpleto source fee information from native nodes on the network. Refer to the EVM fee mManagement section for more information. | 
{
  "coin": "LTC",
  "name": "litecoin",
  "fname": "Litecoin",
  "rpcport": 9332,
  "pubtype": 48,
  "p2shtype": 50,
  "wiftype": 176,
  "txfee": 0,
  "dust": 5460,
  "segwit": true,
  "mm2": 1,
  "required_confirmations": 2,
  "avg_blocktime": 2.5,
  "protocol": {
    "type": "UTXO"
  }
}
{
  "coin": "MCL",
  "asset": "MCL",
  "fname": "MarmaraCreditLoops",
  "rpcport": 33825,
  "txversion": 4,
  "overwintered": 1,
  "mm2": 1,
  "required_confirmations": 5,
  "requires_notarization": false,
  "avg_blocktime": 1,
  "protocol": {
    "type": "UTXO"
  }
}
The token's contract must have approve and transferFrom methods. Additionally, the transfer and transferFrom methods must return a boolean value (true/false) indicating whether a transfer was successful. This requirement is actually a part of the ERC20 standard, but many tokens seem to not follow it.
- chain_id- ID of the chain, see Chainlist
- Protocol "type"field:"ETH"or"ERC20"
- Protocol "protocol_data"field (ERC20 only):"platform"-"ETH","ETC"or other Ethereum forks."contract_address"- ERC20 token checksummed smart contract address.
| Parameter | Type | Description | 
|---|---|---|
| chain_id | integer | To find the EVM chain ID, see Chainlist | 
| gas_limit | object | Optional, required for tokens only. Defines more precise gas prices for swap or transaction operations. Some tokens are called over proxy contracts which often require more gas, though users may be able to choose higher/lower values than the default where required. See the Gas Limit Optionstable below for more information. | 
| protocol.type | string | Platform / protocol - e.g ETHfor Ethereum,ERC20for ERC20 tokens on the Ethereum network | 
| protocol.protocol_data | object | Required for tokens only. | 
| protocol.protocol_data.platform | string | The parent coin of the token's platform - e.g MATICfor PLG20 tokens | 
| protocol.protocol_data.contract_address | string | Must be mixed case The identifying hex string for the token's contract. Can be found on sites like EthScan, BscScan & PolygonScan | 
| Parameter | Type | Description | 
|---|---|---|
| eth_send_coins | integer | Gas limit for sending coins. | 
| eth_send_erc20 | integer | Gas limit for sending ERC20 tokens. | 
| eth_payment | integer | Gas limit for swap payment tx with coins. | 
| erc20_payment | integer | Gas limit for swap payment tx with ERC20 tokens. | 
| eth_receiver_spend | integer | Gas limit for swap receiver spend tx with coins. | 
| erc20_receiver_spend | integer | Gas limit for swap receiver spend tx with ERC20 tokens. | 
| eth_sender_refund | integer | Gas limit for swap refund tx with coins. | 
| erc20_sender_refund | integer | Gas limit for swap refund tx with with ERC20 tokens. | 
| eth_max_trade_gas | integer | Gas limit for other operations. | 
{
  "coin": "USDC-ERC20",
  "name": "usdc_erc20",
  "fname": "USD Coin",
  "rpcport": 80,
  "mm2": 1,
  "chain_id": 1,
  "required_confirmations": 3,
  "avg_blocktime": 0.25,
  "protocol": {
    "type": "ERC20",
    "protocol_data": {
      "platform": "ETH",
      "contract_address": "0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"
    }
  },
  "gas_fee_estimator": "Provider",
  "gas_limit": {
    "eth_send_coins": 21000,
    "eth_send_erc20": 65000,
    "eth_payment": 75000,
    "erc20_payment": 120000,
    "eth_receiver_spend": 55000,
    "erc20_receiver_spend": 130000,
    "eth_sender_refund": 110000,
    "erc20_sender_refund": 110000,
    "eth_max_trade_gas": 150000
  }
}
        {
                "coin": "USDC-BEP20",
                "name": "usdc_bep20",
                "fname": "USD Coin",
                "rpcport": 80,
                "mm2": 1,
                "chain_id": 56,
                "avg_blocktime": 0.05,
                "required_confirmations": 3,
                "protocol": {
                        "type": "ERC20",
                        "protocol_data": {
                                "platform": "BNB",
                                "contract_address": "0x8AC76a51cc950d9822D68b83fE1Ad97B32Cd580d"
                        }
                }
        },
QTUM & QRC20 tokens are a special case which also support all fields of UTXO specific config.
{
  "coin": "QC-QRC20",
  "name": "qtum",
  "fname": "Qcash",
  "rpcport": 3889,
  "pubtype": 58,
  "p2shtype": 50,
  "wiftype": 128,
  "segwit": true,
  "txfee": 0,
  "mm2": 1,
  "required_confirmations": 3,
  "mature_confirmations": 500,
  "avg_blocktime": 2.133,
  "protocol": {
    "type": "QRC20",
    "protocol_data": {
      "platform": "QTUM",
      "contract_address": "0xf2033ede578e17fa6231047265010445bca8cf1c"
    }
  }
}
- The icon file is required.
- Icon must be a .png format file.
- Dimensions of icon file is at least 128x128 pixels.
- Icon file name MUST be the coin/token ticker in small letters without protocl suffix - e.g. for KMD or KMD-BEP20, use kmd.png.
- Icon file location is icons_original folder.
- Tokens do not need this data, they will use the values for their parent coin.
- Explorer file name must be coin's ticker name in all capital letters.
- Explorer file name must not have any file extension. It is a file without any .extension.
- It must have a valid JSON array with at least one Explorer URL in it. Multiple explorer URLs are recommended - e.g. ["https://komodod.com/","https://kmd.explorer.dexstats.info/"]
- Add the path suffixes for the explorer's address and transaction URLs in explorer_paths.json
- Electrum file name must be coin's ticker name in all capital letters.
- Electrum file name must not have any file extension. It is a file without any .extension.
- It must be a valid JSON format as shown in the following example:
- Details of at least 2 Electrum servers must be provided.
- The address and port of electrum server are required. The address of electrum server can either be a DNS or an IP address.
- Protocol can be "SSL" or "TCP". For WebDEX (wasm) listings, SSL is required.
- Contact information must be provided in case the server admin needs to be contacted in emergency situations. Failing servers will result in an automatic delisting of your coin upon the next release of the Komodo DeFi Framework apps.
- The status of currently listed ElectrumX servers is monitored via a public API and Dashboard. For help setting up Telegram or Discord alerts for your servers, join the #dev-supportchannel in the Komodo Platform Discord.
[
  {
    "url": "nmc.bitcoins.sk:50002",
    "protocol": "SSL",
    "disable_cert_verification": true,
    "contact": [
      { "email": "electrum1_admin_email@example.com" },
      { "matrix": "@electrum1_admin:matrix.org" },
      { "skype": "example_username" },
      { "twitter": "example_username" },
      { "reddit": "example_username" },
      { "github": "example_username" },
      { "keybaseio": "example_username" }
    ]
  },
  {
    "url": "electrum-nmc.le-space.de:50002",
    "protocol": "SSL",
    "disable_cert_verification": false,
    "contact": [{ "email": "electrum2_admin_email@example.com" }]
  }
]
The disable_cert_verification field is optional and defaults to false. If set to true, the SSL certificate verification will be disabled.
This can be used when the server has a self-signed certificate, but it is not recommended for production use.
To avoid SSL certificate validation issues, it is highly recommended to use EFF's Certbot to generate SSL certificates for ElectrumX servers.
- Ethereum file name must be coin's ticker name in all capital letters.
- Ethereum file name must not have any file extension. It is a file without any .extension.
- Swap contract address must be the address of etomic swap smart contract deployed to ETH network, example.
- At least minimum 2 or more URLs of RPC nodes must be provided.
- Contact information must be provided in case the server admin needs to be contacted in urgent cases. It can be any contact information out of the examples provided.
- The RPC node URL can either be a DNS or an IP address with port.
- It must be a valid JSON format as shown in the following example:
{
  "swap_contract_address": "0x8500AFc0bc5214728082163326C2FF0C73f4a871",
  "rpc_nodes": [
    {
      "url": "http://ethnode.com:8545",
      "contact": [
        { "email": "ethnode_admin_email@example.com" },
        { "matrix": "@ethnode_admin:matrix.org" },
        { "skype": "example_username" },
        { "twitter": "example_username" },
        { "reddit": "example_username" },
        { "github": "example_username" },
        { "keybaseio": "example_username" }
      ]
    },
    {
      "url": "http://ethnode2.com:8545",
      "contact": [{ "email": "ethnode2_admin_email@example.com" }]
    }
  ]
}
The API IDs are stored in json files within the /api_ids folder, and used to source price and chart date in Komodo DeFi Framework apps.
For CoinGecko it is conveniently displayed on the right had side of a coins page as below -
For CoinPaprika it is the same as displayed in a coin's URL -
For For Forex the API ID is the same as the ISO 4217 currency code.
Add these IDs to their respective json file within the /api_ids folder in the format "TICKER": "API_ID"
The BIP44 derivation path is now required to ensure Hierarchical deterministic wallet functionality. The best source for this data is via Satoshi Labs SLP-044
For Trezor compatibility, this field is required. You can find this value at https://trezor.io/coins. Not all coins are listed on this page by default, but if compatible can be found by searching the supported coins. The value is the name of the coin in larger black text (not the grey text in brackets). E.g. for the image below, the Trezor coin name would be Qtum.
The coin must have participated in a successful Atomic Swap using Komodo DeFi Framework
When submitting your coin addition request, please submit the URLs of the 5 transactions (takerfee sent, maker payment, taker payment and taker payment spent, maker payment spent) produced by successful swap in a new file inside the swaps directory- here's an example for KMD-ETH. This means that, before going through the further steps and submitting the information to this coins database repo, you would have performed a successful atomic swap. The further steps explain the expected files/values to be submitted.
You can learn about performing an atomic swap from our documentation at this link
Activating a coin at this link
Walkthrough at this link
If you have any questions, please ask in the #support channel in our Discord server or you can get help from the team at coinintegration@komodoplatform.com or partners@komodplatform.com .