altcoin.py 27 KB

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