xmrwallet.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427
  1. #!/usr/bin/env python3
  2. #
  3. # mmgen = Multi-Mode GENerator, a command-line cryptocurrency wallet
  4. # Copyright (C)2013-2023 The MMGen Project <mmgen@tuta.io>
  5. # Licensed under the GNU General Public License, Version 3:
  6. # https://www.gnu.org/licenses
  7. # Public project repositories:
  8. # https://github.com/mmgen/mmgen
  9. # https://gitlab.com/mmgen/mmgen
  10. """
  11. help.xmrwallet: xmrwallet help notes for MMGen suite
  12. """
  13. def help(proto,cfg):
  14. return """
  15. Many operations take an optional ‘wallets’ argument: one or more address
  16. indexes (expressed as a comma-separated list and/or hyphenated range) in
  17. the default or specified key-address file, each corresponding to a Monero
  18. wallet with the same index. If the argument is omitted, all wallets are
  19. operated upon.
  20. All operations except for ‘relay’ require a running Monero daemon (monerod).
  21. Unless --daemon is specified, the daemon is assumed to be listening on
  22. localhost at the default RPC port.
  23. If --tx-relay-daemon is specified, the monerod at HOST:PORT will be used to
  24. relay any created transactions. PROXY_HOST:PROXY_PORT, if specified, may
  25. point to a SOCKS proxy, in which case HOST may be a Tor onion address.
  26. All communications use the RPC protocol via SSL (HTTPS) or Tor. RPC over
  27. plain HTTP is not supported.
  28. SUPPORTED OPERATIONS
  29. create - create wallets for all or specified addresses in key-address file
  30. sync - sync wallets for all or specified addresses in key-address file
  31. list - same as ‘sync’, but also list detailed address info for accounts
  32. label - set a label for an address
  33. new - create a new account in a wallet, or a new address in an account
  34. transfer - transfer specified XMR amount from specified wallet:account to
  35. specified address
  36. sweep - sweep funds in specified wallet:account to new address in same
  37. account or new account in another wallet
  38. relay - relay a transaction from a transaction file created using ‘sweep’
  39. or ‘transfer’ with the --no-relay option
  40. submit - submit an autosigned transaction to a wallet and the network
  41. txview - display detailed information about a transaction file or files
  42. txlist - same as above, but display terse information in tabular format
  43. dump - produce JSON dumps of wallet metadata (accounts, addresses and
  44. labels) for a list or range of wallets
  45. restore - same as ‘create’, but additionally restore wallet metadata from
  46. the corresponding JSON dump files created with ‘dump’
  47. export-outputs - export outputs of watch-only wallets for later import
  48. into their corresponding offline wallets
  49. import-key-images - import key images signed by offline wallets into their
  50. corresponding watch-only wallets
  51. ‘LABEL’ OPERATION NOTES
  52. This operation takes a LABEL_SPEC arg with the following format:
  53. WALLET:ACCOUNT:ADDRESS,"label text"
  54. where WALLET is a wallet number, ACCOUNT an account index, and ADDRESS an
  55. address index.
  56. ‘NEW’ OPERATION NOTES
  57. This operation takes a NEW_ADDRESS_SPEC arg with the following format:
  58. WALLET[:ACCOUNT][,"label text"]
  59. where WALLET is a wallet number and ACCOUNT an account index. If ACCOUNT is
  60. omitted, a new account will be created in the wallet, otherwise a new address
  61. will be created in the specified account. An optional label text may be
  62. appended to the spec following a comma.
  63. ‘TRANSFER’ OPERATION NOTES
  64. The transfer operation takes a TRANSFER_SPEC arg with the following format:
  65. SOURCE:ACCOUNT:ADDRESS,AMOUNT
  66. where SOURCE is a wallet number; ACCOUNT the source account index; and ADDRESS
  67. and AMOUNT the destination Monero address and XMR amount, respectively.
  68. ‘SWEEP’ OPERATION NOTES
  69. The sweep operation takes a SWEEP_SPEC arg with the following format:
  70. SOURCE:ACCOUNT[,DEST]
  71. where SOURCE and DEST are wallet numbers and ACCOUNT an account index.
  72. If DEST is omitted, a new address will be created in ACCOUNT of SOURCE and
  73. all funds from ACCOUNT of SOURCE will be swept into it.
  74. If DEST is included, all funds from ACCOUNT of SOURCE will be swept into a
  75. newly created account in DEST, or the last existing account, if requested
  76. by the user.
  77. The user is prompted before addresses are created or funds are transferred.
  78. Note that multiple sweep operations may be required to sweep all the funds
  79. in an account.
  80. ‘SUBMIT’ AND ‘RELAY’ OPERATION NOTES
  81. By default, transactions are relayed to a monerod running on localhost at the
  82. default RPC port. To relay transactions to a remote or non-default monerod
  83. via optional SOCKS proxy, use the --tx-relay-daemon option described above.
  84. When ‘submit’ is used with --autosign, the transaction filename must be
  85. omitted.
  86. ‘DUMP’ AND ‘RESTORE’ OPERATION NOTES
  87. These commands produce and read JSON wallet dump files with the same
  88. filenames as their source wallets, plus a .dump extension.
  89. It’s highly advisable to make regular dumps of your Monero wallets and back
  90. up the dump files, which can be used to easily regenerate the wallets using
  91. the ‘restore’ operation, should the need arise. For watch-only autosigning
  92. wallets, creating the dumps is as easy as executing ‘mmgen-xmrwallet
  93. --autosign dump’ from your wallet directory. The dump files are formatted
  94. JSON and thus suitable for efficient incremental backup using git.
  95. ‘TXVIEW’ AND ‘TXLIST’ OPERATION NOTES
  96. Transactions are displayed in chronological order based on submit time or
  97. creation time. With --autosign, submitted transactions on the removable
  98. device are displayed.
  99. SECURITY WARNING
  100. If you have an existing MMGen Monero hot wallet setup, you’re strongly
  101. advised to migrate to offline autosigning to avoid further exposing your
  102. private keys on your network-connected machine. See OFFLINE AUTOSIGNING
  103. and ‘Replacing Existing Hot Wallets with Watch-Only Wallets’ below.
  104. EXAMPLES
  105. Note that the transacting examples in this section apply for a hot wallet
  106. setup, which is now deprecated. See OFFLINE AUTOSIGNING below.
  107. Generate an XMR key-address file with 5 addresses from your default wallet:
  108. $ mmgen-keygen --coin=xmr 1-5
  109. Create 3 Monero wallets from the key-address file:
  110. $ mmgen-xmrwallet create *.akeys.mmenc 1-3
  111. After updating the blockchain, sync wallets 1 and 2:
  112. $ mmgen-xmrwallet sync *.akeys.mmenc 1,2
  113. Sweep all funds from account #0 of wallet 1 to a new address:
  114. $ mmgen-xmrwallet sweep *.akeys.mmenc 1:0
  115. Same as above, but use a TX relay on the Tor network:
  116. $ mmgen-xmrwallet --tx-relay-daemon=abcdefghijklmnop.onion:127.0.0.1:9050 sweep *.akeys.mmenc 1:0
  117. Sweep all funds from account #0 of wallet 1 to wallet 2:
  118. $ mmgen-xmrwallet sweep *.akeys.mmenc 1:0,2
  119. Send 0.1 XMR from account #0 of wallet 2 to an external address:
  120. $ mmgen-xmrwallet transfer *.akeys.mmenc 2:0:<monero address>,0.1
  121. Sweep all funds from account #0 of wallet 2 to a new address, saving the
  122. transaction to a file:
  123. $ mmgen-xmrwallet --no-relay sweep *.akeys.mmenc 2:0
  124. Relay the created sweep transaction via a host on the Tor network:
  125. $ mmgen-xmrwallet --tx-relay-daemon=abcdefghijklmnop.onion:127.0.0.1:9050 relay *XMR*.sigtx
  126. Create a new account in wallet 2:
  127. $ mmgen-xmrwallet new *.akeys.mmenc 2
  128. Create a new address in account 1 of wallet 2, with label:
  129. $ mmgen-xmrwallet new *.akeys.mmenc 2:1,"from ABC exchange"
  130. View all the XMR transaction files in the current directory, sending output
  131. to pager:
  132. $ mmgen-xmrwallet --pager txview *XMR*.sigtx
  133. OFFLINE AUTOSIGNING
  134. Tutorial
  135. Master the basic concepts of the MMGen wallet system and the processes of
  136. wallet creation, conversion and backup described in the Getting Started
  137. guide. Optionally create a default MMGen wallet on your offline machine
  138. using ‘mmgen-walletgen’. If you choose not to do this, you’ll be prompted
  139. for a seed phrase at the start of each signing session.
  140. Familiarize yourself with the autosigning setup process as described in
  141. ‘mmgen-autosign --help’. Prepare your removable device and set up the
  142. mountpoints on your offline and online machines according to the instructions
  143. therein. Install ‘monero-wallet-rpc’ on your offline machine and the Monero
  144. CLI wallet and daemon binaries on your online machine.
  145. On the offline machine, insert the removable device and execute:
  146. $ mmgen-autosign --xmrwallets=1-2,7 setup
  147. This will create 3 Monero signing wallets with indexes 1, 2 and 7 and primary
  148. addresses matching your seed’s Monero addresses with the same indexes. (Note
  149. that these particular indexes are arbitrary, for purposes of illustration
  150. only. Feel free to choose your own list and/or range – or perhaps just the
  151. number ‘1’ if one wallet is all you require).
  152. These signing wallets are written to volatile memory and exist only for the
  153. duration of the signing session, just like the temporary MMGen signing wallet
  154. they’re generated from (see ‘mmgen-autosign --help’).
  155. A viewkey-address file for the 3 addresses will also be written to the
  156. removable device. The data in this file will be used to create and access
  157. watch-only wallets on your online machine that match the signing wallets
  158. you’ve just created.
  159. When the setup operation completes, extract the removable device and restart
  160. the autosign script in wait mode:
  161. $ mmgen-autosign --coins=xmr --stealth-led wait
  162. Your only further physical interaction with the offline signing machine now
  163. (assuming everything goes as planned) will be inserting and extracting the
  164. removable device on it. And this is the whole point of autosigning: to make
  165. cold signing as convenient as possible, almost like transacting with a hot
  166. wallet.
  167. If your signing machine is an SoC with MMGen LED support (see ‘mmgen-autosign
  168. --help’), a quickly flashing LED will indicate that signing is in progress, a
  169. slowly flashing LED an error condition, and no LED that the program is idle
  170. and waiting for device insertion.
  171. On your online machine, start monerod, wait until it’s fully synced with the
  172. network, insert the removable device and execute:
  173. $ mmgen-xmrwallet --autosign --restore-height=current create
  174. This will create 3 watch-only wallets matching your 3 offline signing wallets
  175. and write them to the current directory (an alternate wallet directory may be
  176. specified with the --wallet-dir option).
  177. Note that --restore-height=current is required to prevent a time-consuming
  178. full sync of the wallets from the Genesis block, a meaningless waste of time
  179. in this case since the wallets contain no funds.
  180. Also make note of the --autosign option, a requirement for ALL autosigning
  181. operations with ‘mmgen-xmrwallet’.
  182. Now list your newly created wallets:
  183. $ mmgen-xmrwallet --autosign list
  184. Note that you can also use the ‘sync’ operation here, which produces more
  185. abbreviated output than ‘list’.
  186. Send some XMR (preferably a tiny amount) to the primary address of wallet #7.
  187. Once the transaction has confirmed, invoke ‘sync’ or ‘list’ again to verify
  188. the funds have arrived.
  189. Since offline wallet #7 has no knowledge of the funds received by its online
  190. counterpart, we need to update its state. Export the outputs of watch-only
  191. wallet #7 as follows:
  192. $ mmgen-xmrwallet --autosign export-outputs 7
  193. The outputs are now saved to the removable device and will be imported into
  194. offline wallet #7 when you sign your first transaction.
  195. Now you’re ready to begin transacting. Let’s start by sweeping your funds in
  196. wallet #7’s primary address (account 0) to a new address in the same account:
  197. $ mmgen-xmrwallet --autosign sweep 7:0
  198. This operation creates an unsigned sweep transaction and saves it to the
  199. removable device.
  200. Now extract the removable device and insert it on the offline machine. Wait
  201. for the quick LED flashing to stop (or the blue ‘safe to extract’ message, in
  202. the absence of LED support), signalling that signing is complete.
  203. Note that the offline wallet has performed two operations in one go here:
  204. an import of wallet outputs from the previous step and the signing of your
  205. just-created sweep transaction.
  206. Extract the removable device, insert it on your online machine and submit the
  207. signed sweep transaction to the watch-only wallet, which will broadcast it to
  208. the network:
  209. $ mmgen-xmrwallet --autosign submit
  210. Note that you may also relay the transaction to a remote daemon, optionally
  211. via a Tor proxy, using the --tx-relay-daemon option documented above.
  212. Once your transaction has confirmed, invoke ‘list’ or ‘sync’ to view your
  213. wallets’ balances.
  214. Congratulations, you’ve performed your first autosigned Monero transaction!
  215. For other examples, consult the EXAMPLES section above, noting the following
  216. differences that apply to autosigning:
  217. 1) The --autosign option must always be included.
  218. 2) The key-address file argument must always be omitted.
  219. 3) The ‘relay’ operation is replaced by ‘submit’, with TX filename omitted.
  220. 4) Always remember to sign your transactions after a ‘sweep’ or ‘transfer’
  221. operation.
  222. 5) Always remember to export a wallet’s outputs when it has received funds
  223. from an outside source.
  224. Exporting Outputs
  225. Exporting outputs from a watch-only wallet is generally required in only
  226. two cases:
  227. a) at the start of each signing session (after ‘mmgen-autosign setup’); and
  228. b) after the wallet has received funds from an outside source or another
  229. wallet.
  230. You might also need to do it, however, if an offline wallet is unable to sign
  231. a transaction due to missing outputs.
  232. Export outputs from a wallet as follows:
  233. $ mmgen-xmrwallet --autosign export-outputs <wallet index>
  234. At the start of a new signing session, you must export outputs from ALL
  235. wallets you intend to transact with. This is necessary because the offline
  236. signing wallets have just been created and know nothing about the state of
  237. their watch-only counterparts.
  238. Then insert the removable device on the offline machine to import the outputs
  239. into the corresponding signing wallet(s) (and optionally redo any failed
  240. transaction signing operation). The signing wallet(s) will also create
  241. signed key images.
  242. Replacing Existing Hot Wallets with Watch-Only Wallets
  243. If you have an existing MMGen Monero hot wallet setup, you can migrate to
  244. offline transaction signing by ‘cloning’ your existing hot wallets as
  245. watch-only ones via the ‘dump’ and ‘restore’ operations described below.
  246. For additional security, it’s also wise to create new watch-only wallets that
  247. have never had keys exposed on an online machine and gradually transfer all
  248. funds from your ‘cloned’ wallets to them. The creation of new wallets is
  249. explained in the Tutorial above.
  250. Start the cloning process by making dump files of your hot wallets’ metadata
  251. (accounts, subaddresses and labels). ‘cd’ to the wallet directory (or use
  252. --wallet-dir) and execute:
  253. $ mmgen-xmrwallet dump /path/to/key-address-file.akeys{.mmenc}
  254. If you’ve been transacting with the wallets, you know where their key-address
  255. file is along with its encryption password, if any. Supply an additional
  256. index range and/or list at the end of the command line if the key-address
  257. file contains more wallets than exist on disk or there are wallets you wish
  258. to ignore.
  259. Do a directory listing to verify that the dump files are present alongside
  260. their source wallet files ending with ‘MoneroWallet’. Then execute:
  261. $ mmgen-xmrwallet --watch-only restore /path/to/key-address-file.akeys{.mmenc}
  262. This will create watch-only wallets that “mirror” the old hot wallets and
  263. populate them with the metadata saved in the dump files.
  264. Note that watch-only wallet filenames end with ‘MoneroWatchOnlyWallet’. Your
  265. old hot wallets will be ignored from here on. Eventually, you’ll want to
  266. destroy them.
  267. Your new wallets must now be synced with the blockchain. Begin by starting
  268. monerod and synchronizing with the network.
  269. Mount ‘/mnt/mmgen_autosign’ and locate the file in the ‘xmr’ directory with
  270. the .vkeys extension, which contains the passwords you’ll need to log into
  271. the wallets. This is a plain text file viewable with ‘cat’, ‘less’ or your
  272. favorite text editor.
  273. Then log into each watch-only wallet in turn as follows:
  274. $ monero-wallet-cli --wallet <wallet filename>
  275. Upon login, each wallet will begin syncing, a process which can take more
  276. than an hour depending on your hardware. Note, however, that the process
  277. is interruptible: you may exit ‘monero-wallet-cli’ at any point, log back
  278. in again and resume where you left off.
  279. Once your watch-only wallets are synced, you need to export their outputs:
  280. $ mmgen-xmrwallet --autosign export-outputs
  281. Now insert the removable device on the offline machine and wait until the LED
  282. stops flashing (or ‘safe to extract’). The wallet outputs are now imported
  283. into the signing wallets and corresponding signed key images have been
  284. written to the removable device.
  285. Insert the removable device on your online machine and import the key images
  286. into your watch-only wallets:
  287. $ mmgen-xmrwallet --autosign import-key-images
  288. Congratulations, your watch-only wallets are now complete and you may begin
  289. transacting! First perform a ‘sync’ or ‘list’ to ensure that your balances
  290. are correct. Then you might try sweeping some funds as described in the
  291. Tutorial above.
  292. Once you’ve gained proficiency with the autosigning process and feel ready
  293. to delete your old hot wallets, make sure to do so securely using ‘shred’,
  294. ‘wipe’ or some other secure deletion utility.
  295. """.strip()