altcoin.py 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531
  1. #!/usr/bin/env python3
  2. #
  3. # mmgen = Multi-Mode GENerator, command-line Bitcoin cold storage solution
  4. # Copyright (C)2013-2019 The MMGen Project <mmgen@tuta.io>
  5. #
  6. # This program is free software: you can redistribute it and/or modify
  7. # it under the terms of the GNU General Public License as published by
  8. # the Free Software Foundation, either version 3 of the License, or
  9. # (at your option) any later version.
  10. #
  11. # This program is distributed in the hope that it will be useful,
  12. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. # GNU General Public License for more details.
  15. #
  16. # You should have received a copy of the GNU General Public License
  17. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  18. """
  19. altcoin.py - Coin constants for Bitcoin-derived altcoins
  20. """
  21. # Sources:
  22. # lb: https://github.com/libbitcoin/libbitcoin/wiki/Altcoin-Version-Mappings
  23. # pc: https://github.com/richardkiss/pycoin/blob/master/pycoin/networks/legacy_networks.py
  24. # vg: https://github.com/exploitagency/vanitygen-plus/blob/master/keyconv.c
  25. # wn: https://walletgenerator.net
  26. # cc: https://www.cryptocompare.com/api/data/coinlist/ (names,symbols only)
  27. # WIP:
  28. # NSR: 149/191 c/u, 63/('S'), 64/('S'|'T')
  29. # NBT: 150/191 c/u, 25/('B'), 26/('B')
  30. import sys
  31. def msg(s): sys.stderr.write(s+'\n')
  32. from collections import namedtuple
  33. ce = namedtuple('CoinInfoEntry',
  34. ['name','symbol','wif_ver_num','p2pkh_info','p2sh_info','has_segwit','trust_level'])
  35. class CoinInfo(object):
  36. coin_constants = {}
  37. coin_constants['mainnet'] = (
  38. # Trust levels: 0=untested 1=low 2=med 3=high -1=disable
  39. # Fork coins must be disabled here to prevent generation from incorrect sub-seed
  40. ce('Bitcoin', 'BTC', 0x80, (0x00,'1'), (0x05,'3'), True, -1),
  41. ce('BitcoinSegwit2X', 'B2X', 0x80, (0x00,'1'), (0x05,'3'), True, -1),
  42. ce('BitcoinGold', 'BCG', 0x80, (0x00,'1'), (0x05,'3'), True, -1),
  43. ce('Bcash', 'BCH', 0x80, (0x00,'1'), (0x05,'3'), False,-1),
  44. ce('2GiveCoin', '2GIVE', 0xa7, (0x27,('G','H')), None, False, 0),
  45. ce('42Coin', '42', 0x88, (0x08,'4'), None, False, 1),
  46. ce('ACoin', 'ACOIN', 0xe6, (0x17,'A'), None, False, 0),
  47. ce('Alphacoin', 'ALF', 0xd2, (0x52,('Z','a')), None, False, 0),
  48. ce('Anoncoin', 'ANC', 0x97, (0x17,'A'), None, False, 1),
  49. ce('Apexcoin', 'APEX', 0x97, (0x17,'A'), None, False, 0),
  50. ce('Aquariuscoin', 'ARCO', 0x97, (0x17,'A'), None, False, 0),
  51. ce('Argentum', 'ARG', 0x97, (0x17,'A'), (0x05,'3'), False, 1),
  52. ce('AsiaCoin', 'AC', 0x97, (0x17,'A'), (0x08,'4'), False, 1),
  53. ce('Auroracoin', 'AUR', 0x97, (0x17,'A'), None, False, 1),
  54. ce('BBQcoin', 'BQC', 0xd5, (0x55,'b'), None, False, 1),
  55. ce('BitcoinDark', 'BTCD', 0xbc, (0x3c,'R'), (0x55,'b'), False, 1),
  56. ce('BitcoinFast', 'BCF', 0xe0, (0x60,('f','g')), None, False, 0),
  57. ce('BitQuark', 'BTQ', 0xba, (0x3a,'Q'), None, False, 0),
  58. ce('Blackcoin', 'BLK', 0x99, (0x19,'B'), (0x55,'b'), False, 1),
  59. ce('BlackmoonCrypto', 'BMC', 0x83, (0x03,'2'), None, False, 0),
  60. ce('BlockCat', 'CAT', 0x95, (0x15,'9'), None, False, 0),
  61. ce('CanadaECoin', 'CDN', 0x9c, (0x1c,'C'), (0x05,'3'), False, 1),
  62. ce('CannabisCoin', 'CANN', 0x9c, (0x1c,'C'), None, False, 0),
  63. ce('CannaCoin', 'CCN', 0x9c, (0x1c,'C'), (0x05,'3'), False, 1),
  64. ce('Capricoin', 'CPC', 0x9c, (0x1c,'C'), None, False, 0),
  65. ce('CashCoin', 'CASH', 0xa2, (0x22,('E','F')), None, False, 0),
  66. ce('CashOut', 'CSH', 0xa2, (0x22,('E','F')), None, False, 0),
  67. ce('ChainCoin', 'CHC', 0x9c, (0x1c,'C'), None, False, 0),
  68. ce('Clams', 'CLAM', 0x85, (0x89,'x'), (0x0d,'6'), False, 1),
  69. ce('CoinMagi', 'XMG', 0x94, (0x14,'9'), None, False, 0),
  70. ce('Condensate', 'RAIN', 0xbc, (0x3c,'R'), None, False, 0),
  71. ce('CryptoBullion', 'CBX', 0x8b, (0x0b,'5'), None, False, 0),
  72. ce('Cryptonite', 'XCN', 0x80, (0x1c,'C'), None, False, 0),
  73. ce('CryptoPennies', 'CRPS', 0xc2, (0x42,'T'), None, False, 0),
  74. ce('Dash', 'DASH', 0xcc, (0x4c,'X'), (0x10,'7'), False, 1),
  75. ce('Decred', 'DCR', 0x22de, (0x073f,'D'), (0x071a,'D'), False, 1),
  76. ce('DeepOnion', 'ONION', 0x9f, (0x1f,'D'), None, False, 1),
  77. ce('Defcoin', 'DFC', 0x9e, (0x1e,'D'), (0x05,'3'), False, 1),
  78. ce('Devcoin', 'DVC', 0x80, (0x00,'1'), None, False, 1),
  79. ce('DigiByte', 'DGB', 0x80, (0x1e,'D'), (0x05,'3'), False, 1),
  80. ce('DigiCoin', 'DGC', 0x9e, (0x1e,'D'), (0x05,'3'), False, 1),
  81. ce('DogecoinDark', 'DOGED', 0x9e, (0x1e,'D'), (0x21,'E'), False, 1),
  82. ce('Dogecoin', 'DOGE', 0x9e, (0x1e,'D'), (0x16,('9','A')), False, 2),
  83. ce('DopeCoin', 'DOPE', 0x88, (0x08,'4'), (0x05,'3'), False, 1),
  84. ce('EGulden', 'EFL', 0xb0, (0x30,'L'), (0x05,'3'), False, 1),
  85. ce('Emerald', 'EMD', 0xa2, (0x22,('E','F')), None, False, 0),
  86. ce('Emercoin', 'EMC', 0x80, (0x21,'E'), (0x5c,'e'), False, 2),
  87. ce('EnergyCoin', 'ENRG', 0xdc, (0x5c,'e'), None, False, 0),
  88. ce('Espers', 'ESP', 0xa1, (0x21,'E'), None, False, 0),
  89. ce('Faircoin', 'FAI', 0xdf, (0x5f,'f'), (0x24,'F'), False, 1),
  90. ce('Fastcoin', 'FST', 0xe0, (0x60,('f','g')), None, False, 0),
  91. ce('Feathercoin', 'FTC', 0x8e, (0x0e,('6','7')), (0x05,'3'), False, 2),
  92. ce('Fibre', 'FIBRE', 0xa3, (0x23,'F'), None, False, 0),
  93. ce('FlorinCoin', 'FLO', 0xb0, (0x23,'F'), None, False, 0),
  94. ce('Fluttercoin', 'FLT', 0xa3, (0x23,'F'), None, False, 0),
  95. ce('Fuel2Coin', 'FC2', 0x80, (0x24,'F'), None, False, 0),
  96. ce('Fujicoin', 'FJC', 0xa4, (0x24,'F'), None, False, 0),
  97. ce('Fujinto', 'NTO', 0xa4, (0x24,'F'), None, False, 0),
  98. ce('GlobalBoost', 'BSTY', 0xa6, (0x26,'G'), None, False, 0),
  99. ce('GlobalCurrencyReserve', 'GCR', 0x9a, (0x26,'G'), (0x61,'g'), False, 1),
  100. ce('GoldenBird', 'XGB', 0xaf, (0x2f,('K','L')), None, False, 0),
  101. ce('Goodcoin', 'GOOD', 0xa6, (0x26,'G'), None, False, 0),
  102. ce('GridcoinResearch', 'GRC', 0xbe, (0x3e,('R','S')), None, False, 1),
  103. ce('Gulden', 'NLG', 0xa6, (0x26,'G'), None, False, 1),
  104. ce('Guncoin', 'GUN', 0xa7, (0x27,('G','H')), None, False, 1),
  105. ce('HamRadioCoin', 'HAM', 0x80, (0x00,'1'), None, False, 1),
  106. ce('HTML5Coin', 'HTML5', 0xa8, (0x28,'H'), None, False, 0),
  107. ce('HyperStake', 'HYP', 0xf5, (0x75,'p'), None, False, 0),
  108. ce('iCash', 'ICASH', 0xcc, (0x66,'i'), None, False, 0),
  109. ce('ImperiumCoin', 'IPC', 0xb0, (0x30,'L'), None, False, 0),
  110. ce('IncaKoin', 'NKA', 0xb5, (0x35,'N'), None, False, 0),
  111. ce('Influxcoin', 'INFX', 0xe6, (0x66,'i'), None, False, 0),
  112. ce('InPay', 'INPAY', 0xb7, (0x37,'P'), None, False, 0),
  113. # ce('iXcoin', 'IXC', 0x80, (0x8a,'x'), None, False, 1),
  114. ce('Judgecoin', 'JUDGE', 0xab, (0x2b,'J'), None, False, 0),
  115. ce('Jumbucks', 'JBS', 0xab, (0x2b,'J'), (0x69,'j'), False, 2),
  116. ce('Lanacoin', 'LANA', 0xb0, (0x30,'L'), None, False, 0),
  117. ce('Latium', 'LAT', 0x80, (0x17,'A'), None, False, 0),
  118. ce('Litecoin', 'LTC', 0xb0, (0x30,'L'), (0x05,'3'), True, 3),
  119. ce('LiteDoge', 'LDOGE', 0xab, (0x5a,'d'), None, False, 0),
  120. ce('LomoCoin', 'LMC', 0xb0, (0x30,'L'), None, False, 0),
  121. ce('Marscoin', 'MARS', 0xb2, (0x32,'M'), None, False, 0),
  122. ce('MarsCoin', 'MRS', 0xb2, (0x32,'M'), None, False, 0),
  123. ce('MartexCoin', 'MXT', 0xb2, (0x32,'M'), None, False, 0),
  124. ce('MasterCar', 'MCAR', 0xe6, (0x17,'A'), None, False, 0),
  125. ce('MazaCoin', 'MZC', 0xe0, (0x32,'M'), (0x09,('4','5')), False, 2),
  126. ce('MegaCoin', 'MEC', 0xb2, (0x32,'M'), None, False, 1),
  127. ce('MintCoin', 'MINT', 0xb3, (0x33,'M'), None, False, 0),
  128. ce('Mobius', 'MOBI', 0x80, (0x00,'1'), None, False, 0),
  129. ce('MonaCoin', 'MONA', 0xb0, (0x32,'M'), (0x05,'3'), False, 1),
  130. ce('MonetaryUnit', 'MUE', 0x8f, (0x0f,'7'), (0x09,('4','5')), False, 1),
  131. ce('MoonCoin', 'MOON', 0x83, (0x03,'2'), None, False, 0),
  132. ce('MyriadCoin', 'MYR', 0xb2, (0x32,'M'), (0x09,('4','5')), False, 1),
  133. ce('Myriadcoin', 'MYRIAD', 0xb2, (0x32,'M'), None, False, 1),
  134. ce('Namecoin', 'NMC', 0xb4, (0x34,('M','N')), (0x0d,'6'), False, 1),
  135. ce('Neoscoin', 'NEOS', 0xef, (0x3f,'S'), (0xbc,'2'), False, 1),
  136. ce('NevaCoin', 'NEVA', 0xb1, (0x35,'N'), None, False, 0),
  137. ce('Novacoin', 'NVC', 0x88, (0x08,'4'), (0x14,'9'), False, 1),
  138. ce('OKCash', 'OK', 0xb7, (0x37,'P'), (0x1c,'C'), False, 1),
  139. ce('Omnicoin', 'OMC', 0xf3, (0x73,'o'), None, False, 1),
  140. ce('Omni', 'OMNI', 0xf3, (0x73,'o'), None, False, 0),
  141. ce('Onix', 'ONX', 0x80, (0x8a,'x'), None, False, 0),
  142. ce('PandaCoin', 'PND', 0xb7, (0x37,'P'), (0x16,('9','A')), False, 1),
  143. ce('ParkByte', 'PKB', 0xb7, (0x37,'P'), (0x1c,'C'), False, 1),
  144. ce('Particl', 'PART', 0x6c, (0x38,'P'), None, False, 0),
  145. ce('Paycoin', 'CON', 0xb7, (0x37,'P'), None, False, 1),
  146. ce('Peercoin', 'PPC', 0xb7, (0x37,'P'), (0x75,'p'), False, 1),
  147. ce('PesetaCoin', 'PTC', 0xaf, (0x2f,('K','L')), None, False, 1),
  148. ce('PhoenixCoin', 'PXC', 0xb8, (0x38,'P'), None, False, 0),
  149. ce('PinkCoin', 'PINK', 0x83, (0x03,'2'), None, False, 1),
  150. ce('PIVX', 'PIVX', 0xd4, (0x1e,'D'), None, False, 0),
  151. ce('PokeChain', 'XPOKE', 0x9c, (0x1c,'C'), None, False, 0),
  152. ce('Potcoin', 'POT', 0xb7, (0x37,'P'), (0x05,'3'), False, 1),
  153. ce('Primecoin', 'XPM', 0x97, (0x17,'A'), (0x53,'a'), False, 1),
  154. ce('Quark', 'QRK', 0xba, (0x3a,'Q'), None, False, 0),
  155. ce('ReddCoin', 'RDD', 0xbd, (0x3d,'R'), None, False, 1),
  156. ce('Riecoin', 'RIC', 0x80, (0x3c,'R'), (0x05,'3'), False, 2),
  157. ce('Rimbit', 'RBT', 0xbc, (0x3c,'R'), None, False, 0),
  158. ce('Rubycoin', 'RBY', 0xbd, (0x3d,'R'), (0x55,'b'), False, 1),
  159. ce('ShadowCash', 'SDC', 0xbf, (0x3f,'S'), (0x7d,'s'), False, 1),
  160. ce('Sibcoin', 'SIB', 0x80, (0x3f,'S'), None, False, 0),
  161. ce('SixEleven', '611', 0x80, (0x34,('M','N')), None, False, 0),
  162. ce('SmileyCoin', 'SMLY', 0x99, (0x19,'B'), None, False, 0),
  163. ce('Songcoin', 'SONG', 0xbf, (0x3f,'S'), None, False, 0),
  164. ce('Spreadcoin', 'SPR', 0xbf, (0x3f,'S'), None, False, 1),
  165. ce('Startcoin', 'START', 0xfd, (0x7d,'s'), (0x05,'3'), False, 1),
  166. ce('StealthCoin', 'XST', 0xbe, (0x3e,('R','S')), None, False, 0),
  167. ce('SwagBucks', 'BUCKS', 0x99, (0x3f,'S'), None, False, 0),
  168. ce('SysCoin', 'SYS', 0x80, (0x00,'1'), None, False, 0),
  169. ce('TajCoin', 'TAJ', 0x6f, (0x41,'T'), None, False, 0),
  170. ce('Templecoin', 'TPC', 0xc1, (0x41,'T'), (0x05,'3'), False, 1),
  171. ce('Terracoin', 'TRC', 0x80, (0x00,'1'), None, False, 0),
  172. ce('Titcoin', 'TIT', 0x80, (0x00,'1'), None, False, 0),
  173. ce('TittieCoin', 'TTC', 0xc1, (0x41,'T'), None, False, 0),
  174. ce('Transfer', 'TX', 0x99, (0x42,'T'), None, False, 0),
  175. ce('Unobtanium', 'UNO', 0xe0, (0x82,'u'), (0x1e,'D'), False, 2),
  176. ce('Vcash', 'XVC', 0xc7, (0x47,'V'), None, False, 0),
  177. ce('Vertcoin', 'VTC', 0xc7, (0x47,'V'), (0x05,'3'), False, 1),
  178. ce('Viacoin', 'VIA', 0xc7, (0x47,'V'), (0x21,'E'), False, 2),
  179. ce('VpnCoin', 'VPN', 0xc7, (0x47,'V'), (0x05,'3'), False, 1),
  180. ce('WankCoin', 'WKC', 0x80, (0x00,'1'), None, False, 1),
  181. ce('WashingtonCoin', 'WASH', 0xc9, (0x49,'W'), None, False, 0),
  182. ce('WeAreSatoshi', 'WSX', 0x97, (0x87,'w'), None, False, 0),
  183. ce('WisdomCoin', 'WISC', 0x87, (0x49,'W'), None, False, 0),
  184. ce('WorldCoin', 'WDC', 0xc9, (0x49,'W'), None, False, 1),
  185. ce('XRealEstateDevcoin', 'XRED', 0x80, (0x00,'1'), None, False, 0),
  186. ce('ZetaCoin', 'ZET', 0xe0, (0x50,'Z'), None, False, 0),
  187. ce('ZiftrCoin', 'ZRC', 0xd0, (0x50,'Z'), (0x05,'3'), False, 1),
  188. ce('ZLiteQubit', 'ZLQ', 0xe0, (0x26,'G'), None, False, 0),
  189. ce('Zoomcoin', 'ZOOM', 0xe7, (0x67,'i'), (0x5c,'e'), False, 1),
  190. )
  191. coin_constants['testnet'] = (
  192. ce('Dash', 'DASH', 0xef, (0x8c,'y'), (0x13,('8','9')), False, 1),
  193. ce('Decred', 'DCR', 0x230e, (0x0f21,'T'), (0x0e6c,'S'), False, 1),
  194. ce('Dogecoin', 'DOGE', 0xf1, (0x71,'n'), (0xc4,'2'), False, 2),
  195. ce('Feathercoin', 'FTC', 0xc1, (0x41,'T'), (0xc4,'2'), False, 2),
  196. ce('Viacoin', 'VIA', 0xff, (0x7f,'t'), (0xc4,'2'), False, 2),
  197. ce('Emercoin', 'EMC', 0xef, (0x6f,('m','n')), (0xc4,'2'), False, 2),
  198. )
  199. coin_sources = (
  200. ('BTC', 'https://github.com/bitcoin/bitcoin/blob/master/src/chainparams.cpp'),
  201. ('EMC', 'https://github.com/emercoin/emercoin/blob/master/src/chainparams.cpp'), # checked mn,tn
  202. ('LTC', 'https://github.com/litecoin-project/litecoin/blob/master-0.10/src/chainparams.cpp'),
  203. ('DOGE', 'https://github.com/dogecoin/dogecoin/blob/master/src/chainparams.cpp'),
  204. ('RDD', 'https://github.com/reddcoin-project/reddcoin/blob/master/src/base58.h'),
  205. ('DASH', 'https://github.com/dashpay/dash/blob/master/src/chainparams.cpp'),
  206. ('PPC', 'https://github.com/belovachap/peercoin/blob/master/src/base58.h'),
  207. ('NMC', 'https://github.com/domob1812/namecore/blob/master/src/chainparams.cpp'),
  208. ('FTC', 'https://github.com/FeatherCoin/Feathercoin/blob/master-0.8/src/base58.h'),
  209. ('BLK', 'https://github.com/rat4/blackcoin/blob/master/src/chainparams.cpp'),
  210. ('NSR', 'https://nubits.com/nushares/introduction'),
  211. ('NBT', 'https://bitbucket.org/JordanLeePeershares/nubit/NuBit / src /base58.h'),
  212. ('MZC', 'https://github.com/MazaCoin/MazaCoin/blob/master/src/chainparams.cpp'),
  213. ('VIA', 'https://github.com/viacoin/viacoin/blob/master/src/chainparams.cpp'),
  214. ('RBY', 'https://github.com/rubycoinorg/rubycoin/blob/master/src/base58.h'),
  215. ('GRS', 'https://github.com/GroestlCoin/groestlcoin/blob/master/src/groestlcoin.cpp'),
  216. ('DGC', 'https://github.com/DGCDev/digitalcoin/blob/master/src/chainparams.cpp'),
  217. ('CCN', 'https://github.com/Cannacoin-Project/Cannacoin/blob/Proof-of-Stake/src/base58.h'),
  218. ('DGB', 'https://github.com/digibyte/digibyte/blob/master/src/chainparams.cpp'),
  219. ('MONA', 'https://github.com/monacoinproject/monacoin/blob/master-0.10/src/chainparams.cpp'),
  220. ('CLAM', 'https://github.com/nochowderforyou/clams/blob/master/src/chainparams.cpp'),
  221. ('XPM', 'https://github.com/primecoin/primecoin/blob/master/src/base58.h'),
  222. ('NEOS', 'https://github.com/bellacoin/neoscoin/blob/master/src/chainparams.cpp'),
  223. ('JBS', 'https://github.com/jyap808/jumbucks/blob/master/src/base58.h'),
  224. ('ZRC', 'https://github.com/ZiftrCOIN/ziftrcoin/blob/master/src/chainparams.cpp'),
  225. ('VTC', 'https://github.com/vertcoin/vertcoin/blob/master/src/base58.h'),
  226. ('NXT', 'https://bitbucket.org/JeanLucPicard/nxt/src and unofficial at https://github.com/Blackcomb/nxt'),
  227. ('MUE', 'https://github.com/MonetaryUnit/MUE-Src/blob/master/src/chainparams.cpp'),
  228. ('ZOOM', 'https://github.com/zoom-c/zoom/blob/master/src/base58.h'),
  229. ('VPN', 'https://github.com/Bit-Net/VpnCoin/blob/master/src/base58.h'),
  230. ('CDN', 'https://github.com/ThisIsOurCoin/canadaecoin/blob/master/src/base58.h'),
  231. ('SDC', 'https://github.com/ShadowProject/shadow/blob/master/src/chainparams.cpp'),
  232. ('PKB', 'https://github.com/parkbyte/ParkByte/blob/master/src/base58.h'),
  233. ('PND', 'https://github.com/coinkeeper/2015-04-19_21-22_pandacoin/blob/master/src/base58.h'),
  234. ('START', 'https://github.com/startcoin-project/startcoin/blob/master/src/base58.h'),
  235. ('GCR', 'https://github.com/globalcurrencyreserve/gcr/blob/master/src/chainparams.cpp'),
  236. ('NVC', 'https://github.com/novacoin-project/novacoin/blob/master/src/base58.h'),
  237. ('AC', 'https://github.com/AsiaCoin/AsiaCoinFix/blob/master/src/base58.h'),
  238. ('BTCD', 'https://github.com/jl777/btcd/blob/master/src/base58.h'),
  239. ('DOPE', 'https://github.com/dopecoin-dev/DopeCoinV3/blob/master/src/base58.h'),
  240. ('TPC', 'https://github.com/9cat/templecoin/blob/templecoin/src/base58.h'),
  241. ('OK', 'https://github.com/okcashpro/okcash/blob/master/src/chainparams.cpp'),
  242. ('DOGED', 'https://github.com/doged/dogedsource/blob/master/src/base58.h'),
  243. ('EFL', 'https://github.com/Electronic-Gulden-Foundation/egulden/blob/master/src/base58.h'),
  244. ('POT', 'https://github.com/potcoin/Potcoin/blob/master/src/base58.h'),
  245. )
  246. # Sources (see above) that are in agreement for these coins
  247. # No check for segwit, p2sh check skipped if source doesn't support it
  248. cross_checks = {
  249. '2GIVE': ['wn'],
  250. '42': ['vg','wn'],
  251. '611': ['wn'],
  252. 'AC': ['lb','vg'],
  253. 'ACOIN': ['wn'],
  254. 'ALF': ['wn'],
  255. 'ANC': ['vg','wn'],
  256. 'APEX': ['wn'],
  257. 'ARCO': ['wn'],
  258. 'ARG': ['pc'],
  259. 'AUR': ['vg','wn'],
  260. 'BCH': ['wn'],
  261. 'BLK': ['lb','vg','wn'],
  262. 'BQC': ['vg','wn'],
  263. 'BSTY': ['wn'],
  264. 'BTC': ['lb','vg','wn'],
  265. 'BTCD': ['lb','vg','wn'],
  266. 'BUCKS': ['wn'],
  267. 'CASH': ['wn'],
  268. 'CBX': ['wn'],
  269. 'CCN': ['lb','vg','wn'],
  270. 'CDN': ['lb','vg','wn'],
  271. 'CHC': ['wn'],
  272. 'CLAM': ['lb','vg'],
  273. 'CON': ['vg','wn'],
  274. 'CPC': ['wn'],
  275. 'DASH': ['lb','pc','vg','wn'],
  276. 'DCR': ['pc'],
  277. 'DFC': ['pc'],
  278. 'DGB': ['lb','vg'],
  279. 'DGC': ['lb','vg','wn'],
  280. 'DOGE': ['lb','pc','vg','wn'],
  281. 'DOGED': ['lb','vg','wn'],
  282. 'DOPE': ['lb','vg'],
  283. 'DVC': ['vg','wn'],
  284. 'EFL': ['lb','vg','wn'],
  285. 'EMC': ['vg'],
  286. 'EMD': ['wn'],
  287. 'ESP': ['wn'],
  288. 'FAI': ['pc'],
  289. 'FC2': ['wn'],
  290. 'FIBRE': ['wn'],
  291. 'FJC': ['wn'],
  292. 'FLO': ['wn'],
  293. 'FLT': ['wn'],
  294. 'FST': ['wn'],
  295. 'FTC': ['lb','pc','vg','wn'],
  296. 'GCR': ['lb','vg'],
  297. 'GOOD': ['wn'],
  298. 'GRC': ['vg','wn'],
  299. 'GUN': ['vg','wn'],
  300. 'HAM': ['vg','wn'],
  301. 'HTML5': ['wn'],
  302. 'HYP': ['wn'],
  303. 'ICASH': ['wn'],
  304. 'INFX': ['wn'],
  305. 'IPC': ['wn'],
  306. 'JBS': ['lb','pc','vg','wn'],
  307. 'JUDGE': ['wn'],
  308. 'LANA': ['wn'],
  309. 'LAT': ['wn'],
  310. 'LDOGE': ['wn'],
  311. 'LMC': ['wn'],
  312. 'LTC': ['lb','vg','wn'],
  313. 'MARS': ['wn'],
  314. 'MEC': ['pc','wn'],
  315. 'MINT': ['wn'],
  316. 'MOBI': ['wn'],
  317. 'MONA': ['lb','vg'],
  318. 'MOON': ['wn'],
  319. 'MUE': ['lb','vg'],
  320. 'MXT': ['wn'],
  321. 'MYR': ['pc'],
  322. 'MYRIAD': ['vg','wn'],
  323. 'MZC': ['lb','pc','vg','wn'],
  324. 'NEOS': ['lb','vg'],
  325. 'NEVA': ['wn'],
  326. 'NKA': ['wn'],
  327. 'NLG': ['vg','wn'],
  328. 'NMC': ['lb','vg'],
  329. 'NVC': ['lb','vg','wn'],
  330. 'OK': ['lb','vg'],
  331. 'OMC': ['vg','wn'],
  332. 'ONION': ['vg','wn'],
  333. 'PART': ['wn'],
  334. 'PINK': ['vg','wn'],
  335. 'PIVX': ['wn'],
  336. 'PKB': ['lb','vg','wn'],
  337. 'PND': ['lb','vg','wn'],
  338. 'POT': ['lb','vg','wn'],
  339. 'PPC': ['lb','vg','wn'],
  340. 'PTC': ['vg','wn'],
  341. 'PXC': ['wn'],
  342. 'QRK': ['wn'],
  343. 'RAIN': ['wn'],
  344. 'RBT': ['wn'],
  345. 'RBY': ['lb','vg'],
  346. 'RDD': ['vg','wn'],
  347. 'RIC': ['pc','vg','wn'],
  348. 'SDC': ['lb','vg'],
  349. 'SIB': ['wn'],
  350. 'SMLY': ['wn'],
  351. 'SONG': ['wn'],
  352. 'SPR': ['vg','wn'],
  353. 'START': ['lb','vg'],
  354. 'SYS': ['wn'],
  355. 'TAJ': ['wn'],
  356. 'TIT': ['wn'],
  357. 'TPC': ['lb','vg'],
  358. 'TRC': ['wn'],
  359. 'TTC': ['wn'],
  360. 'TX': ['wn'],
  361. 'UNO': ['pc','vg','wn'],
  362. 'VIA': ['lb','pc','vg','wn'],
  363. 'VPN': ['lb','vg'],
  364. 'VTC': ['lb','vg','wn'],
  365. 'WDC': ['vg','wn'],
  366. 'WISC': ['wn'],
  367. 'WKC': ['vg','wn'],
  368. 'WSX': ['wn'],
  369. 'XCN': ['wn'],
  370. 'XGB': ['wn'],
  371. 'XPM': ['lb','vg','wn'],
  372. 'XST': ['wn'],
  373. 'XVC': ['wn'],
  374. 'ZET': ['wn'],
  375. 'ZOOM': ['lb','vg'],
  376. 'ZRC': ['lb','vg']
  377. }
  378. # Data is one of the coin_constants lists above. Normalize ints to hex of correct width, add
  379. # missing leading letters, set trust level from external_tests.
  380. # Insert a coin entry from outside source, set version info leading letters to '?' and trust level
  381. # to 0, then run CoinInfo.fix_table(data). 'has_segwit' field is updated manually for now.
  382. @classmethod
  383. def fix_table(cls,data):
  384. import re
  385. def myhex(n):
  386. return '0x{:0{}x}'.format(n,2 if n < 256 else 4)
  387. def fix_ver_info(e,k):
  388. e[k] = list(e[k])
  389. e[k][0] = myhex(e[k][0])
  390. s1 = cls.find_addr_leading_symbol(int(e[k][0][2:],16))
  391. m = 'Fixing leading address letter for coin {} ({!r} --> {})'.format(e['symbol'],e[k][1],s1)
  392. if e[k][1] != '?':
  393. assert s1 == e[k][1],'First letters do not match! {}'.format(m)
  394. else:
  395. msg(m)
  396. e[k][1] = s1
  397. e[k] = tuple(e[k])
  398. old_sym = None
  399. for sym in sorted([e.symbol for e in data]):
  400. if sym == old_sym:
  401. msg("'{}': duplicate coin symbol in data!".format(sym))
  402. sys.exit(2)
  403. old_sym = sym
  404. tt = cls.create_trust_table()
  405. name_w = max(len(e.name) for e in data)
  406. fs = '\t({:%s} {:10} {:7} {:17} {:17} {:6} {}),' % (name_w+3)
  407. for e in data:
  408. e = e._asdict()
  409. e['wif_ver_num'] = myhex(e['wif_ver_num'])
  410. sym,trust = e['symbol'],e['trust_level']
  411. fix_ver_info(e,'p2pkh_info')
  412. if type(e['p2sh_info']) == tuple:
  413. fix_ver_info(e,'p2sh_info')
  414. for k in e.keys():
  415. e[k] = repr(e[k])
  416. e[k] = re.sub(r"'0x(..)'",r'0x\1',e[k])
  417. e[k] = re.sub(r"'0x(....)'",r'0x\1',e[k])
  418. e[k] = re.sub(r' ',r'',e[k]) + ('',',')[k != 'trust_level']
  419. if trust != -1:
  420. if sym in tt:
  421. src = tt[sym]
  422. if src != trust:
  423. msg("Updating trust for coin '{}': {} -> {}".format(sym,trust,src))
  424. e['trust_level'] = src
  425. else:
  426. if trust != 0:
  427. msg("Downgrading trust for coin '{}': {} -> {}".format(sym,trust,0))
  428. e['trust_level'] = 0
  429. if sym in cls.cross_checks:
  430. if int(e['trust_level']) == 0 and len(cls.cross_checks[sym]) > 1:
  431. msg("Upgrading trust for coin '{}': {} -> {}".format(sym,e['trust_level'],1))
  432. e['trust_level'] = 1
  433. print(fs.format(*e.values()))
  434. msg('Processed {} entries'.format(len(data)))
  435. @classmethod
  436. def find_addr_leading_symbol(cls,ver_num,verbose=False):
  437. def phash2addr(ver_num,pk_hash):
  438. from mmgen.protocol import _b58chk_encode
  439. return _b58chk_encode('{:0{}x}'.format(ver_num,2 if ver_num < 256 else 4) + pk_hash)
  440. low = phash2addr(ver_num,'00'*20)
  441. high = phash2addr(ver_num,'ff'*20)
  442. if verbose:
  443. print('low address: ' + low)
  444. print('high address: ' + high)
  445. l1,h1 = low[0],high[0]
  446. return (l1,h1) if l1 != h1 else l1
  447. @classmethod
  448. def print_symbols(cls,include_names=False,reverse=False):
  449. for e in cls.coin_constants['mainnet']:
  450. if reverse:
  451. print('{:6} {}'.format(e.symbol,e.name))
  452. else:
  453. name_w = max(len(e.name) for e in cls.coin_constants['mainnet'])
  454. print(('{:{}} '.format(e.name,name_w) if include_names else '') + e.symbol)
  455. @classmethod
  456. def create_trust_table(cls):
  457. tt = {}
  458. mn = cls.external_tests['mainnet']
  459. for ext_prog in mn:
  460. assert len(set(mn[ext_prog])) == len(mn[ext_prog]),"Duplicate entry in '{}'!".format(ext_prog)
  461. for coin in mn[ext_prog]:
  462. if coin in tt:
  463. tt[coin] += 1
  464. else:
  465. tt[coin] = 1
  466. for k in cls.trust_override:
  467. tt[k] = cls.trust_override[k]
  468. return tt
  469. trust_override = {'BTC':3,'BCH':3,'LTC':3,'DASH':1,'EMC':2}
  470. external_tests = {
  471. 'mainnet': {
  472. 'moneropy': ('XMR',),
  473. 'pycoin': (
  474. # broken: DASH - only compressed, LTC segwit old fmt
  475. 'BTC','LTC','VIA','FTC','DOGE','MEC',
  476. 'JBS','MZC','RIC','DFC','FAI','ARG','ZEC','DCR'),
  477. 'ethkey': ('ETH','ETC'),
  478. 'zcash_mini': ('ZEC',),
  479. 'keyconv': ( # all supported by vanitygen-plus 'keyconv' util
  480. # broken: PIVX
  481. '42','AC','AIB','ANC','ARS','ATMOS','AUR','BLK','BQC','BTC','TEST','BTCD','CCC','CCN','CDN',
  482. 'CLAM','CNC','CNOTE','CON','CRW','DEEPONION','DGB','DGC','DMD','DOGED','DOGE','DOPE',
  483. 'DVC','EFL','EMC','EXCL','FAIR','FLOZ','FTC','GAME','GAP','GCR','GRC','GRS','GUN','HAM','HODL',
  484. 'IXC','JBS','LBRY','LEAF','LTC','MMC','MONA','MUE','MYRIAD','MZC','NEOS','NLG','NMC','NVC',
  485. 'NYAN','OK','OMC','PIGGY','PINK','PKB','PND','POT','PPC','PTC','PTS','QTUM','RBY','RDD',
  486. 'RIC','SCA','SDC','SKC','SPR','START','SXC','TPC','UIS','UNO','VIA','VPN','VTC','WDC','WKC',
  487. 'WUBS', 'XC', 'XPM', 'YAC', 'ZOOM', 'ZRC')
  488. },
  489. 'testnet': {
  490. 'pycoin': {
  491. # broken: DASH - only compressed { 'DASH':'tDASH' }
  492. 'BTC':'XTN','LTC':'XLT','VIA':'TVI','FTC':'FTX','DOGE':'XDT','DCR':'DCRT'
  493. },
  494. 'ethkey': {},
  495. 'keyconv': {}
  496. }
  497. }
  498. external_tests_segwit_compressed = {
  499. 'segwit': ('BTC'),
  500. 'compressed': (
  501. 'BTC','LTC','VIA','FTC','DOGE','DASH','MEC','MYR','UNO',
  502. 'JBS','MZC','RIC','DFC','FAI','ARG','ZEC','DCR','ZEC'),
  503. }