diff --git a/docs/interacting/monero-wallet-rpc-reference.md b/docs/interacting/monero-wallet-rpc-reference.md index bc0c9e5..155b160 100644 --- a/docs/interacting/monero-wallet-rpc-reference.md +++ b/docs/interacting/monero-wallet-rpc-reference.md @@ -113,141 +113,314 @@ Note: "atomic units" refer to the smallest fraction of 1 XMR according to the mo ## JSON RPC Methods: -### **get_balance** -Return the wallet's balance. -Alias: _getbalance_. -Inputs: +### **add_address_book** -- _account_index_ - unsigned int; Return balance for this account. -- _address_indices_ - array of unsigned int; (Optional) Return balance detail for those subaddresses. - -Outputs: - -- _balance_ - unsigned int; The total balance of the current monero-wallet-rpc in session. -- _unlocked_balance_ - unsigned int; Unlocked funds are those funds that are sufficiently deep enough in the Monero blockchain to be considered safe to spend. -- _multisig_import_needed_ - boolean; True if importing multisig data is needed for returning a correct balance. -- _per_subaddress_ - array of subaddress information; Balance information for each subaddress in an account. - - _address_index_ - unsigned int; Index of the subaddress in the account. - - _address_ - string; Address at this index. Base58 representation of the public keys. - - _balance_ - unsigned int; Balance for the subaddress (locked or unlocked). - - _unlocked_balance_ - unsigned int; Unlocked balance for the subaddress. - - _label_ - string; Label for the subaddress. - - _num_unspent_outputs_ - unsigned int; Number of unspent outputs available for the subaddress. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_balance","params":{"account_index":0,"address_indices":[0,1]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "balance": 157443303037455077, - "multisig_import_needed": false, - "per_subaddress": [{ - "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", - "address_index": 0, - "balance": 157360317826255077, - "label": "Primary account", - "num_unspent_outputs": 5281, - "unlocked_balance": 157360317826255077 - },{ - "address": "7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o", - "address_index": 1, - "balance": 59985211200000, - "label": "", - "num_unspent_outputs": 1, - "unlocked_balance": 59985211200000 - }], - "unlocked_balance": 157443303037455077 - } -} - -``` ---- - -### **get_address** - -Return the wallet's addresses for an account. Optionally filter for specific set of subaddresses. - -Alias: _getaddress_. - -Inputs: - -- _account_index_ - unsigned int; Return subaddresses for this account. -- _address_index_ - array of unsigned int; (Optional) List of subaddresses to return from an account. - -Outputs: - -- _address_ - string; The 95-character hex address string of the monero-wallet-rpc in session. -- _addresses_ array of addresses informations - - _address_ string; The 95-character hex (sub)address string. - - _label_ string; Label of the (sub)address - - _address_index_ unsigned int; index of the subaddress - - _used_ boolean; states if the (sub)address has already received funds - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_address","params":{"account_index":0,"address_index":[0,1,4]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", - "addresses": [{ - "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", - "address_index": 0, - "label": "Primary account", - "used": true - },{ - "address": "7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o", - "address_index": 1, - "label": "", - "used": true - },{ - "address": "77xa6Dha7kzCQuvmd8iB5VYoMkdenwCNRU9khGhExXQ8KLL3z1N1ZATBD1sFPenyHWT9cm4fVFnCAUApY53peuoZFtwZiw5", - "address_index": 4, - "label": "test2", - "used": true - }] - } -} - -``` ---- - -### **get_address_index** - -Get account and address indexes from a specific (sub)address +Add an entry to the address book. Alias: _None_. Inputs: -- _address_ - String; (sub)address to look for. +- _address_ - string; +- _payment_id_ - (optional) string, defaults to "0000000000000000000000000000000000000000000000000000000000000000"; +- _description_ - (optional) string, defaults to ""; Outputs: -- _index_ - subaddress informations - - _major_ unsigned int; Account index. - - _minor_ unsigned int; Address index. +- _index_ - unsigned int; The index of the address book entry. Example: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_address_index","params":{"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"add_address_book","params":{"address":"78P16M3XmFRGcWFCcsgt1WcTntA1jzcq31seQX1Eg92j8VQ99NPivmdKam4J5CKNAD7KuNWcq5xUPgoWczChzdba5WLwQ4j","description":"Third account"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "index": { - "major": 0, - "minor": 1 - } + "index": 1 + } +} + +``` +--- + +### **change_wallet_password** + +Change a wallet password. + +Alias: _None_. + +Inputs: + +- _old_password_ - string; (Optional) Current wallet password, if defined. +- _new_password_ - string; (Optional) New wallet password, if not blank. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"change_wallet_password","params":{"old_password":"theCurrentSecretPassPhrase","new_password":"theNewSecretPassPhrase"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **check_reserve_proof** + +Proves a wallet has a disposable reserve using a signature. + +Alias: _None_. + +Inputs: + +- _address_ - string; Public address of the wallet. +- _message_ - string; (Optional) Should be the same message used in `get_reserve_proof`. +- _signature_ - string; reserve signature to confirm. + +Outputs: + +- _good_ - boolean; States if the inputs proves the reserve. + +In the example below, the reserve has been proven: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_reserve_proof","params":{"address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","signature":"ReserveProofV11BZ23sBt9sZJeGccf84mzyAmNCP3KzYbE1111112VKmH111118NfCYJQjZ6c46gT2kXgcHCaSSZeL8sRdzqjqx7i1e7FQfQGu2o113UYFVdwzHQi3iENDPa76Kn1BvywbKz3bMkXdZkBEEhBSF4kjjGaiMJ1ucKb6wvMVC4A8sA4nZEdL2Mk3wBucJCYTZwKqA8i1M113kqakDkG25FrjiDqdQTCYz2wDBmfKxF3eQiV5FWzZ6HmAyxnqTWUiMWukP9A3Edy3ZXqjP1b23dhz7Mbj39bBxe3ZeDNu9HnTSqYvHNRyqCkeUMJpHyQweqjGUJ1DSfFYr33J1E7MkhMnEi1o7trqWjVix32XLetYfePG73yvHbS24837L7Q64i5n1LSpd9yMiQZ3Dyaysi5y6jPx7TpAvnSqBFtuCciKoNzaXoA3dqt9cuVFZTXzdXKqdt3cXcVJMNxY8RvKPVQHhUur94Lpo1nSpxf7BN5a5rHrbZFqoZszsZmiWikYPkLX72XUdw6NWjLrTBxSy7KuPYH86c6udPEXLo2xgN6XHMBMBJzt8FqqK7EcpNUBkuHm2AtpGkf9CABY3oSjDQoRF5n4vNLd3qUaxNsG4XJ12L9gJ7GrK273BxkfEA8fDdxPrb1gpespbgEnCTuZHqj1A"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "good": true, + "spent": 0, + "total": 100000000000 + } +} + +``` + +In the example below, all wallet reserve has been proven: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_reserve_proof","params":{"address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","message":"I have 10 at least","signature":"...signature..."}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "good": true, + "spent": 0, + "total": 164113855714662789 + } +} + +``` + +In the example below, the wrong message is used, avoiding the reserve to be proved: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"wrong message","signature":"SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "good": false + } +} + +``` +--- + +### **check_spend_proof** + +Prove a spend using a signature. Unlike proving a transaction, it does not requires the destination public address. + +Alias: _None_. + +Inputs: + +- _txid_ - string; transaction id. +- _message_ - string; (Optional) Should be the same message used in `get_spend_proof`. +- _signature_ - string; spend signature to confirm. + +Outputs: + +- _good_ - boolean; States if the inputs proves the spend. + +In the example below, the spend has been proven: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"this is my transaction","signature":"SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "good": true + } +} + +``` + +In the example below, the wrong message is used, avoiding the spend to be proved: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"wrong message","signature":"SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "good": false + } +} + +``` +--- + +### **check_tx_key** + +Check a transaction in the blockchain with its secret key. + +Alias: _None_. + +Inputs: + +- _txid_ - string; transaction id. +- _tx_key_ - string; transaction secret key. +- _address_ - string; destination public address of the transaction. + +Outputs: + +- _confirmations_ - unsigned int; Number of block mined after the one with the transaction. +- _in_pool_ - boolean; States if the transaction is still in pool or has been added to a block. +- _received_ - unsigned int; Amount of the transaction. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_tx_key","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","tx_key":"feba662cf8fb6d0d0da18fc9b70ab28e01cc76311278fdd7fe7ab16360762b06","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "confirmations": 0, + "in_pool": false, + "received": 1000000000000 + } +} + +``` +--- + +### **check_tx_proof** + +Prove a transaction by checking its signature. + +Alias: _None_. + +Inputs: + +- _txid_ - string; transaction id. +- _address_ - string; destination public address of the transaction. +- _message_ - string; (Optional) Should be the same message used in `get_tx_proof`. +- _signature_ - string; transaction signature to confirm. + +Outputs: + +- _confirmations_ - unsigned int; Number of block mined after the one with the transaction. +- _good_ - boolean; States if the inputs proves the transaction. +- _in_pool_ - boolean; States if the transaction is still in pool or has been added to a block. +- _received_ - unsigned int; Amount of the transaction. + +In the example below, the transaction has been proven: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_tx_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o","message":"this is my transaction","signature":"InProofV13vqBCT6dpSAXkypZmSEMPGVnNRFDX2vscUYeVS4WnSVnV5BwLs31T9q6Etfj9Wts6tAxSAS4gkMeSYzzLS7Gt4vvCSQRh9niGJMUDJsB5hTzb2XJiCkUzWkkcjLFBBRVD5QZ"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "confirmations": 482, + "good": true, + "in_pool": false, + "received": 1000000000000 + } +} + +``` + +In the example below, the wrong message is used, avoiding the transaction to be proved: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_tx_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o","message":"wrong message","signature":"InProofV13vqBCT6dpSAXkypZmSEMPGVnNRFDX2vscUYeVS4WnSVnV5BwLs31T9q6Etfj9Wts6tAxSAS4gkMeSYzzLS7Gt4vvCSQRh9niGJMUDJsB5hTzb2XJiCkUzWkkcjLFBBRVD5QZ"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "confirmations": 0, + "good": false, + "in_pool": false, + "received": 0 + } +} + +``` +--- + +### **close_wallet** + +Close the currently opened wallet, after trying to save it. + +Alias: _None_. + +Inputs: _None_. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"close_wallet"}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **create_account** + +Create a new account with an optional label. + +Alias: _None_. + +Inputs: + +- _label_ - string; (Optional) Label for the account. + +Outputs: + +- _account_index_ - unsigned int; Index of the new account. +- _address_ - string; Address for this account. Base58 representation of the public keys. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"create_account","params":{"label":"Secondary account"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "account_index": 1, + "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp" } } @@ -286,25 +459,24 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **label_address** +### **create_wallet** -Label an address. +Create a new wallet. You need to have set the argument "–wallet-dir" when launching monero-wallet-rpc to make this work. Alias: _None_. Inputs: -- _index_ - subaddress index; JSON Object containing the major & minor address index: - - _major_ - unsigned int; Account index for the subaddress. - - _minor_ - unsigned int; Index of the subaddress in the account. -- _label_ - string; Label for the address. +- _filename_ - string; Wallet file name. +- _password_ - string; (Optional) password to protect the wallet. +- _language_ - string; Language for your wallets' seed. Outputs: _None_. Example: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"label_address","params":{"index":{"major":0,"minor":5},"label":"myLabel"}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"create_wallet","params":{"filename":"mytestwallet","password":"mytestpassword","language":"English"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", @@ -315,6 +487,185 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- +### **delete_address_book** + +Delete an entry from the address book. + +Alias: _None_. + +Inputs: + +- _index_ - unsigned int; The index of the address book entry. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"delete_address_book","params":{"index":1}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **export_key_images** + +Export a signed set of key images. + +Alias: _None_. + +Inputs: _None_. + +Outputs: + +- _signed_key_images_ - array of signed key images: + - _key_image_ - string; + - _signature_ - string; + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"export_key_images"}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "signed_key_images": [{ + "key_image": "cd35239b72a35e26a57ed17400c0b66944a55de9d5bda0f21190fed17f8ea876", + "signature": "c9d736869355da2538ab4af188279f84138c958edbae3c5caf388a63cd8e780b8c5a1aed850bd79657df659422c463608ea4e0c730ba9b662c906ae933816d00" + },{ + "key_image": "65158a8ee5a3b32009b85a307d85b375175870e560e08de313531c7dbbe6fc19", + "signature": "c96e40d09dfc45cfc5ed0b76bfd7ca793469588bb0cf2b4d7b45ef23d40fd4036057b397828062e31700dc0c2da364f50cd142295a8405b9fe97418b4b745d0c" + },...] + } +} + +``` +--- + +### **export_multisig_info** + +Export multisig info for other participants. + +Alias: _None_. + +Inputs: _None_. + +Outputs: + +- _info_ - string; Multisig info in hex format for other participants. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"export_multisig_info"}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "info": "4d6f6e65726f206d756c7469736967206578706f72740105cf6442b09b75f5eca9d846771fe1a879c9a97ab0553ffbcec64b1148eb7832b51e7898d7944c41cee000415c5a98f4f80dc0efdae379a98805bb6eacae743446f6f421cd03e129eb5b27d6e3b73eb6929201507c1ae706c1a9ecd26ac8601932415b0b6f49cbbfd712e47d01262c59980a8f9a8be776f2bf585f1477a6df63d6364614d941ecfdcb6e958a390eb9aa7c87f056673d73bc7c5f0ab1f74a682e902e48a3322c0413bb7f6fd67404f13fb8e313f70a0ce568c853206751a334ef490068d3c8ca0e" + } +} + +``` +--- + +### **export_outputs** + +Export all outputs in hex format. + +Alias: _None_. + +Inputs: _None_. + +Outputs: + +- _outputs_data_hex_ - string; wallet outputs in hex format. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"export_outputs"}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "outputs_data_hex": "...outputs..." + } +} + +``` +--- + +### **finalize_multisig** + +Turn this wallet into a multisig wallet, extra step for N-1/N wallets. + +Alias: _None_. + +Inputs: + +- _multisig_info_ - array of string; List of multisig string from peers. +- _password_ - string; Wallet password + +Outputs: + +- _address_ - string; multisig wallet address. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"finalize_multisig","params":{"multisig_info":["MultisigxV1JNC6Ja2oBt5Sqea9LN2YEF7WYZCpHqr2EKvPG89Trf3X4E8RWkLaGRf29fJ3stU471MELKxwufNYeigP7LoE4tn2McPr4SbL9q15xNvZT5uwC9YRr7UwjXqSZHmTWN9PBuZEKVAQ4HPPyQciSCdNjgwsuFRBzrskMdMUwNMgKst1debYfm37i6PSzDoS2tk4kYTYj83kkAdR7kdshet1axQPd6HQ","MultisigxV1Unma7Ko4zdd8Ps3Af4oZwtj2JdWKzwNfP6s2G9ZvXhMoSscwn5g7PyCfcBc1V4ffRHY3Kxqq6VocSCUTncpVeUskMcPr4SbL9q15xNvZT5uwC9YRr7UwjXqSZHmTWN9PBuZE1LTpWxLoC3vPMSrqVVcjnmL9LYfdCZz3fECjNZbCEDq3PHDiUuY5jurQTcNoGhDTio5WM9xaAdim9YByiS5KyqF4"]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "address": "5B9gZUTDuHTcGGuY3nL3t8K2tDnEHeRVHSBQgLZUTQxtFYVLnho5JJjWJyFp5YZgZRQ44RiviJi1sPHgLVMbckRsDqDx1gV" + } +} + +``` +--- + +### **get_account_tags** + +Get a list of user-defined account tags. + +Alias: _None_. + +Inputs: _None_. + +Outputs: + +- _account_tags_ - array of account tag information: + - _tag_ - string; Filter tag. + - _label_ - string; Label for the tag. + - _accounts_ - array of int; List of tagged account indices. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_account_tags","params":""}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "account_tags": [{ + "accounts": [0], + "label": "Test tag", + "tag": "myTag" + }] + } +} + +``` +--- + ### **get_accounts** Get all accounts for a wallet. Optionally filter accounts by tag. @@ -368,62 +719,50 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **create_account** +### **get_address** -Create a new account with an optional label. +Return the wallet's addresses for an account. Optionally filter for specific set of subaddresses. -Alias: _None_. +Alias: _getaddress_. Inputs: -- _label_ - string; (Optional) Label for the account. +- _account_index_ - unsigned int; Return subaddresses for this account. +- _address_index_ - array of unsigned int; (Optional) List of subaddresses to return from an account. Outputs: -- _account_index_ - unsigned int; Index of the new account. -- _address_ - string; Address for this account. Base58 representation of the public keys. +- _address_ - string; The 95-character hex address string of the monero-wallet-rpc in session. +- _addresses_ array of addresses informations + - _address_ string; The 95-character hex (sub)address string. + - _label_ string; Label of the (sub)address + - _address_index_ unsigned int; index of the subaddress + - _used_ boolean; states if the (sub)address has already received funds Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"create_account","params":{"label":"Secondary account"}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_address","params":{"account_index":0,"address_index":[0,1,4]}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "account_index": 1, - "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp" - } -} - -``` ---- - -### **label_account** - -Label an account. - -Alias: _None_. - -Inputs: - -- _account_index_ - unsigned int; Apply label to account at this index. -- _label_ - string; Label for the account. - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"label_account","params":{"account_index":0,"label":"Primary account"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "account_tags": [{ - "accounts": [0,1], + "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", + "addresses": [{ + "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", + "address_index": 0, + "label": "Primary account", + "used": true + },{ + "address": "7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o", + "address_index": 1, "label": "", - "tag": "myTag" + "used": true + },{ + "address": "77xa6Dha7kzCQuvmd8iB5VYoMkdenwCNRU9khGhExXQ8KLL3z1N1ZATBD1sFPenyHWT9cm4fVFnCAUApY53peuoZFtwZiw5", + "address_index": 4, + "label": "test2", + "used": true }] } } @@ -431,33 +770,42 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **get_account_tags** +### **get_address_book** -Get a list of user-defined account tags. +Retrieves entries from the address book. Alias: _None_. -Inputs: _None_. +Inputs: + +- _entries_ - array of unsigned int; indices of the requested address book entries Outputs: -- _account_tags_ - array of account tag information: - - _tag_ - string; Filter tag. - - _label_ - string; Label for the tag. - - _accounts_ - array of int; List of tagged account indices. +- _entries_ - array of entries: + - _address_ - string; Public address of the entry + - _description_ - string; Description of this address entry + - _index_ - unsigned int; + - _payment_id_ - string; Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_account_tags","params":""}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_address_book","params":{"entries":[0,1]}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "account_tags": [{ - "accounts": [0], - "label": "Test tag", - "tag": "myTag" + "entries": [{ + "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp", + "description": "Second account", + "index": 0, + "payment_id": "0000000000000000000000000000000000000000000000000000000000000000" + },{ + "address": "78P16M3XmFRGcWFCcsgt1WcTntA1jzcq31seQX1Eg92j8VQ99NPivmdKam4J5CKNAD7KuNWcq5xUPgoWczChzdba5WLwQ4j", + "description": "Third account", + "index": 1, + "payment_id": "0000000000000000000000000000000000000000000000000000000000000000" }] } } @@ -465,80 +813,113 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **tag_accounts** +### **get_address_index** -Apply a filtering tag to a list of accounts. +Get account and address indexes from a specific (sub)address Alias: _None_. Inputs: -- _tag_ - string; Tag for the accounts. -- _accounts_ - array of unsigned int; Tag this list of accounts. +- _address_ - String; (sub)address to look for. -Outputs: _None_. +Outputs: + +- _index_ - subaddress informations + - _major_ unsigned int; Account index. + - _minor_ unsigned int; Address index. Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"tag_accounts","params":{"tag":"myTag","accounts":[0,1]}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_address_index","params":{"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { + "index": { + "major": 0, + "minor": 1 + } } } ``` --- -### **untag_accounts** +### **get_attribute** -Remove filtering tag from a list of accounts. +Get attribute value by name. Alias: _None_. Inputs: -- _accounts_ - array of unsigned int; Remove tag from this list of accounts. +- _key_ - string; attribute name -Outputs: _None_. +Outputs: + +- _value_ - string; attribute value Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"untag_accounts","params":{"accounts":[1]}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_attribute","params":{"key":"my_attribute"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { + "value": "my_value" } } ``` --- -### **set_account_tag_description** +### **get_bulk_payments** -Set description for an account tag. +Get a list of incoming payments using a given payment id, or a list of payments ids, from a given height. This method is the preferred method over `get_payments`because it has the same functionality but is more extendable. Either is fine for looking up transactions by a single payment ID. Alias: _None_. Inputs: -- _tag_ - string; Set a description for this tag. -- _description_ - string; Description for the tag. +- _payment_ids_ - array of: string; Payment IDs used to find the payments (16 characters hex). +- _min_block_height_ - unsigned int; The block height at which to start looking for payments. -Outputs: _None_. +Outputs: + +- _payments_ - list of: + - _payment_id_ - string; Payment ID matching one of the input IDs. + - _tx_hash_ - string; Transaction hash used as the transaction ID. + - _amount_ - unsigned int; Amount for this payment. + - _block_height_ - unsigned int; Height of the block that first confirmed this payment. + - _unlock_time_ - unsigned int; Time (in block height) until this payment is safe to spend. + - _subaddr_index_ - subaddress index: + - _major_ - unsigned int; Account index for the subaddress. + - _minor_ - unsigned int; Index of the subaddress in the account. + - _address_ - string; Address receiving the payment; Base58 representation of the public keys. Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"set_account_tag_description","params":{"tag":"myTag","description":"Test tag"}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_bulk_payments","params":{"payment_ids":["60900e5603bf96e3"],"min_block_height":"120000"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { + "payments": [{ + "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", + "amount": 1000000000000, + "block_height": 127606, + "payment_id": "60900e5603bf96e3", + "subaddr_index": { + "major": 0, + "minor": 0 + }, + "tx_hash": "3292e83ad28fc1cc7bc26dbd38862308f4588680fbf93eae3e803cddd1bd614f", + "unlock_time": 0 + }] } } @@ -572,397 +953,27 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **transfer** +### **get_languages** -Send monero to a number of recipients. - -Alias: _None_. - -Inputs: - -- _destinations_ - array of destinations to receive XMR: - - _amount_ - unsigned int; Amount to send to each destination, in atomic units. - - _address_ - string; Destination public address. -- _account_index_ - unsigned int; (Optional) Transfer from this account index. (Defaults to 0) -- _subaddr_indices_ - array of unsigned int; (Optional) Transfer from this set of subaddresses. (Defaults to 0) -- _priority_ - unsigned int; Set a priority for the transaction. Accepted Values are: 0-3 for: default, unimportant, normal, elevated, priority. -- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). -- _ring_size_ - unsigned int; Number of outputs to mix in the transaction (this output + N decoys from the blockchain). -- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). -- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. -- _get_tx_key_ - boolean; (Optional) Return the transaction key after sending. -- _do_not_relay_ - boolean; (Optional) If true, the newly created transaction will not be relayed to the monero network. (Defaults to false) -- _get_tx_hex_ - boolean; Return the transaction as hex string after sending (Defaults to false) -- _get_tx_metadata_ - boolean; Return the metadata needed to relay the transaction. (Defaults to false) - -Outputs: - -- _amount_ - Amount transferred for the transaction. -- _fee_ - Integer value of the fee charged for the txn. -- _multisig_txset_ - Set of multisig transactions in the process of being signed (empty for non-multisig). -- _tx_blob_ - Raw transaction represented as hex string, if get_tx_hex is true. -- _tx_hash_ - String for the publically searchable transaction hash. -- _tx_key_ - String for the transaction key if get_tx_key is true, otherwise, blank string. -- _tx_metadata_ - Set of transaction metadata needed to relay this transfer later, if get_tx_metadata is true. -- _unsigned_txset_ - String. Set of unsigned tx for cold-signing purposes. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"transfer","params":{"destinations":[{"amount":100000000000,"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"},{"amount":200000000000,"address":"75sNpRwUtekcJGejMuLSGA71QFuK1qcCVLZnYRTfQLgFU5nJ7xiAHtR5ihioS53KMe8pBhH61moraZHyLoG4G7fMER8xkNv"}],"account_index":0,"subaddr_indices":[0],"priority":0,"ring_size":7,"get_tx_key": true}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "amount": 300000000000, - "fee": 86897600000, - "multisig_txset": "", - "tx_blob": "", - "tx_hash": "7663438de4f72b25a0e395b770ea9ecf7108cd2f0c4b75be0b14a103d3362be9", - "tx_key": "25c9d8ec20045c80c93d665c9d3684aab7335f8b2cd02e1ba2638485afd1c70e236c4bdd7a2f1cb511dbf466f13421bdf8df988b7b969c448ca6239d7251490e4bf1bbf9f6ffacffdcdc93b9d1648ec499eada4d6b4e02ce92d4a1c0452e5d009fbbbf15b549df8856205a4c7bda6338d82c823f911acd00cb75850b198c5803", - "tx_metadata": "", - "unsigned_txset": "" - } -} - -``` ---- - -### **transfer_split** - -Same as transfer, but can split into more than one tx if necessary. - -Alias: _None_. - -Inputs: - -- _destinations_ - array of destinations to receive XMR: - - _amount_ - unsigned int; Amount to send to each destination, in atomic units. - - _address_ - string; Destination public address. -- _account_index_ - unsigned int; (Optional) Transfer from this account index. (Defaults to 0) -- _subaddr_indices_ - array of unsigned int; (Optional) Transfer from this set of subaddresses. (Defaults to 0) -- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). -- _ring_size_ - unsigned int; Sets ringsize to n (mixin + 1). -- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). -- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. -- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. -- _priority_ - unsigned int; Set a priority for the transactions. Accepted Values are: 0-3 for: default, unimportant, normal, elevated, priority. -- _do_not_relay_ - boolean; (Optional) If true, the newly created transaction will not be relayed to the monero network. (Defaults to false) -- _get_tx_hex_ - boolean; Return the transactions as hex string after sending -- _new_algorithm_ - boolean; True to use the new transaction construction algorithm, defaults to false. -- _get_tx_metadata_ - boolean; Return list of transaction metadata needed to relay the transfer later. - -Outputs: - -- _tx_hash_list_ - array of: string. The tx hashes of every transaction. -- _tx_key_list_ - array of: string. The transaction keys for every transaction. -- _amount_list_ - array of: integer. The amount transferred for every transaction. -- _fee_list_ - array of: integer. The amount of fees paid for every transaction. -- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. -- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. -- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). -- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"transfer_split","params":{"destinations":[{"amount":1000000000000,"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"},{"amount":2000000000000,"address":"75sNpRwUtekcJGejMuLSGA71QFuK1qcCVLZnYRTfQLgFU5nJ7xiAHtR5ihioS53KMe8pBhH61moraZHyLoG4G7fMER8xkNv"}],"account_index":0,"subaddr_indices":[0],"priority":0,"ring_size":7,"get_tx_key": true}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "amount_list": [3000000000000], - "fee_list": [85106400000], - "multisig_txset": "", - "tx_hash_list": ["c8d815f48f27d53fdaf198a74b292a91bfaf87529a9a9a9ee66079a890b3b58b"], - "unsigned_txset": "" - } -} - -``` ---- - -### **sign_transfer** - -Sign a transaction created on a read-only wallet (in cold-signing process) - -Alias: _None_. - -Inputs: - -- _unsigned_txset_ - string. Set of unsigned tx returned by "transfer" or "transfer_split" methods. -- _export_raw_ - boolean; (Optional) If true, return the raw transaction data. (Defaults to false) - -Outputs: - -- _signed_txset_ - string. Set of signed tx to be used for submitting transfer. -- _tx_hash_list_ - array of: string. The tx hashes of every transaction. -- _tx_raw_list_ - array of: string. The tx raw data of every transaction. - -In the example below, we first generate an unsigned_txset on a read only wallet before signing it: - -Generate unsigned_txset using the above "transfer" method on read-only wallet: - -``` -curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"transfer","params":{"destinations":[{"amount":1000000000000,"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"}],"account_index":0,"subaddr_indices":[0],"priority":0,"ring_size":7,"do_not_relay":true,"get_tx_hex":true}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "amount": 1000000000000, - "fee": 15202740000, - "multisig_txset": "", - "tx_blob": "...long_hex...", - "tx_hash": "c648ba0a049e5ce4ec21361dbf6e4b21eac0f828eea9090215de86c76b31d0a4", - "tx_key": "", - "tx_metadata": "", - "unsigned_txset": "...long_hex..." - } -} - -``` - -Sign tx using the previously generated unsigned_txset - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sign_transfer","params":{"unsigned_txset":...long_hex..."}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "signed_txset": "...long_hex...", - "tx_hash_list": ["ff2e2d49fbfb1c9a55754f786576e171c8bf21b463a74438df604b7fa6cebc6d"] - } -} - -``` ---- - -### **submit_transfer** - -Submit a previously signed transaction on a read-only wallet (in cold-signing process). - -Alias: _None_. - -Inputs: - -- _tx_data_hex_ - string; Set of signed tx returned by "sign_transfer" - -Outputs: - -- _tx_hash_list_ - array of: string. The tx hashes of every transaction. - -In the example below, we submit the transfer using the signed_txset generated above: - -``` -curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"submit_transfer","params":{"tx_data_hex":...long_hex..."}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "tx_hash_list": ["40fad7c828bb383ac02648732f7afce9adc520ba5629e1f5d9c03f584ac53d74"] - } -} - -``` ---- - -### **sweep_dust** - -Send all dust outputs back to the wallet's, to make them easier to spend (and mix). - -Alias: _sweep_unmixable_. - -Inputs: - -- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. -- _do_not_relay_ - boolean; (Optional) If true, the newly created transaction will not be relayed to the monero network. (Defaults to false) -- _get_tx_hex_ - boolean; (Optional) Return the transactions as hex string after sending. (Defaults to false) -- _get_tx_metadata_ - boolean; (Optional) Return list of transaction metadata needed to relay the transfer later. (Defaults to false) - -Outputs: - -- _tx_hash_list_ - array of: string. The tx hashes of every transaction. -- _tx_key_list_ - array of: string. The transaction keys for every transaction. -- _amount_list_ - array of: integer. The amount transferred for every transaction. -- _fee_list_ - array of: integer. The amount of fees paid for every transaction. -- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. -- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. -- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). -- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. - -Example (In this example, `sweep_dust` returns nothing because there are no funds to sweep): - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sweep_dust","params":{"get_tx_keys":true}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "multisig_txset": "", - "unsigned_txset": "" - } -} - -``` ---- - -### **sweep_all** - -Send all unlocked balance to an address. - -Alias: _None_. - -Inputs: - -- _address_ - string; Destination public address. -- _account_index_ - unsigned int; Sweep transactions from this account. -- _subaddr_indices_ - array of unsigned int; (Optional) Sweep from this set of subaddresses in the account. -- _priority_ - unsigned int; (Optional) Priority for sending the sweep transfer, partially determines fee. -- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). -- _ring_size_ - unsigned int; Sets ringsize to n (mixin + 1). -- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). -- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. -- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. -- _below_amount_ - unsigned int; (Optional) Include outputs below this amount. -- _do_not_relay_ - boolean; (Optional) If true, do not relay this sweep transfer. (Defaults to false) -- _get_tx_hex_ - boolean; (Optional) return the transactions as hex encoded string. (Defaults to false) -- _get_tx_metadata_ - boolean; (Optional) return the transaction metadata as a string. (Defaults to false) - -Outputs: - -- _tx_hash_list_ - array of: string. The tx hashes of every transaction. -- _tx_key_list_ - array of: string. The transaction keys for every transaction. -- _amount_list_ - array of: integer. The amount transferred for every transaction. -- _fee_list_ - array of: integer. The amount of fees paid for every transaction. -- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. -- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. -- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). -- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sweep_all","params":{"address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","subaddr_indices":[4],"ring_size":7,"unlock_time":0,"get_tx_keys":true}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "amount_list": [9985885770000], - "fee_list": [14114230000], - "multisig_txset": "", - "tx_hash_list": ["ab4b6b65cc8cd8c9dd317d0b90d97582d68d0aa1637b0065b05b61f9a66ea5c5"], - "tx_key_list": ["b9b4b39d3bb3062ddb85ec0266d4df39058f4c86077d99309f218ce4d76af607"], - "unsigned_txset": "" - } -} - -``` ---- - -### **sweep_single** - -Send all of a specific unlocked output to an address. - -Alias: _None_. - -Inputs: - -- _address_ - string; Destination public address. -- _account_index_ - unsigned int; Sweep transactions from this account. -- _subaddr_indices_ - array of unsigned int; (Optional) Sweep from this set of subaddresses in the account. -- _priority_ - unsigned int; (Optional) Priority for sending the sweep transfer, partially determines fee. -- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). -- _ring_size_ - unsigned int; Sets ringsize to n (mixin + 1). -- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). -- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. -- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. -- _key_image_ - string; Key image of specific output to sweep. -- _below_amount_ - unsigned int; (Optional) Include outputs below this amount. -- _do_not_relay_ - boolean; (Optional) If true, do not relay this sweep transfer. (Defaults to false) -- _get_tx_hex_ - boolean; (Optional) return the transactions as hex encoded string. (Defaults to false) -- _get_tx_metadata_ - boolean; (Optional) return the transaction metadata as a string. (Defaults to false) - -Outputs: - -- _tx_hash_list_ - array of: string. The tx hashes of every transaction. -- _tx_key_list_ - array of: string. The transaction keys for every transaction. -- _amount_list_ - array of: integer. The amount transferred for every transaction. -- _fee_list_ - array of: integer. The amount of fees paid for every transaction. -- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. -- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. -- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). -- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sweep_single","params":{"address":"74Jsocx8xbpTBEjm3ncKE5LBQbiJouyCDaGhgSiebpvNDXZnTAbW2CmUR5SsBeae2pNk9WMVuz6jegkC4krUyqRjA6VjoLD","ring_size":7,"unlock_time":0,"key_image":"a7834459ef795d2efb6f665d2fd758c8d9288989d8d4c712a68f8023f7804a5e","get_tx_keys":true}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "amount": 27126892247503, - "fee": 14111630000, - "multisig_txset": "", - "tx_blob": "", - "tx_hash": "106d4391a031e5b735ded555862fec63233e34e5fa4fc7edcfdbe461c275ae5b", - "tx_key": "", - "tx_metadata": "", - "unsigned_txset": "" - } -} - -``` ---- - -### **relay_tx** - -Relay a transaction previously created with `"do_not_relay":true`. - -Alias: _None_. - -Inputs: - -- _hex_ - string; transaction metadata returned from a `transfer` method with `get_tx_metadata` set to `true`. - -Outputs: - -- _tx_hash_ - String for the publically searchable transaction hash. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"relay_tx","params":{"hex":"...tx_metadata..."}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "tx_hash": "1c42dcc5672bb09bccf33fb1e9ab4a498af59a6dbd33b3d0cfb289b9e0e25fa5" - } -} - -``` ---- - -### **store** - -Save the wallet file. +Get a list of available languages for your wallet's seed. Alias: _None_. Inputs: _None_. -Outputs: _None_. +Outputs: + +- _languages_ - array of string; List of available languages Example: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"store"}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_languages"}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { + "languages": ["Deutsch","English","Español","Français","Italiano","Nederlands","Português","русский язык","日本語","简体中文 (中国)","Esperanto","Lojban"] } } @@ -1018,48 +1029,210 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **get_bulk_payments** +### **get_reserve_proof** -Get a list of incoming payments using a given payment id, or a list of payments ids, from a given height. This method is the preferred method over `get_payments`because it has the same functionality but is more extendable. Either is fine for looking up transactions by a single payment ID. +Generate a signature to prove of an available amount in a wallet. Alias: _None_. Inputs: -- _payment_ids_ - array of: string; Payment IDs used to find the payments (16 characters hex). -- _min_block_height_ - unsigned int; The block height at which to start looking for payments. +- _all_ - boolean; Proves all wallet balance to be disposable. +- _account_index_ - unsigned int; Specify the account from witch to prove reserve. (ignored if `all` is set to true) +- _amount_ - unsigned int; Amount (in atomic units) to prove the account has for reserve. (ignored if `all` is set to true) +- _message_ - string; (Optional) add a message to the signature to further authenticate the prooving process. Outputs: -- _payments_ - list of: - - _payment_id_ - string; Payment ID matching one of the input IDs. - - _tx_hash_ - string; Transaction hash used as the transaction ID. - - _amount_ - unsigned int; Amount for this payment. - - _block_height_ - unsigned int; Height of the block that first confirmed this payment. - - _unlock_time_ - unsigned int; Time (in block height) until this payment is safe to spend. - - _subaddr_index_ - subaddress index: - - _major_ - unsigned int; Account index for the subaddress. - - _minor_ - unsigned int; Index of the subaddress in the account. - - _address_ - string; Address receiving the payment; Base58 representation of the public keys. +- _signature_ - string; reserve signature. Example: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_bulk_payments","params":{"payment_ids":["60900e5603bf96e3"],"min_block_height":"120000"}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_reserve_proof","params":{"all":false,"account_index":0,"amount":100000000000}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "payments": [{ + "signature": "ReserveProofV11BZ23sBt9sZJeGccf84mzyAmNCP3KzYbE1111112VKmH111118NfCYJQjZ6c46gT2kXgcHCaSSZeL8sRdzqjqx7i1e7FQfQGu2o113UYFVdwzHQi3iENDPa76Kn1BvywbKz3bMkXdZkBEEhBSF4kjjGaiMJ1ucKb6wvMVC4A8sA4nZEdL2Mk3wBucJCYTZwKqA8i1M113kqakDkG25FrjiDqdQTCYz2wDBmfKxF3eQiV5FWzZ6HmAyxnqTWUiMWukP9A3Edy3ZXqjP1b23dhz7Mbj39bBxe3ZeDNu9HnTSqYvHNRyqCkeUMJpHyQweqjGUJ1DSfFYr33J1E7MkhMnEi1o7trqWjVix32XLetYfePG73yvHbS24837L7Q64i5n1LSpd9yMiQZ3Dyaysi5y6jPx7TpAvnSqBFtuCciKoNzaXoA3dqt9cuVFZTXzdXKqdt3cXcVJMNxY8RvKPVQHhUur94Lpo1nSpxf7BN5a5rHrbZFqoZszsZmiWikYPkLX72XUdw6NWjLrTBxSy7KuPYH86c6udPEXLo2xgN6XHMBMBJzt8FqqK7EcpNUBkuHm2AtpGkf9CABY3oSjDQoRF5n4vNLd3qUaxNsG4XJ12L9gJ7GrK273BxkfEA8fDdxPrb1gpespbgEnCTuZHqj1A" + } +} + +``` +--- + +### **get_spend_proof** + +Generate a signature to prove a spend. Unlike proving a transaction, it does not requires the destination public address. + +Alias: _None_. + +Inputs: + +- _txid_ - string; transaction id. +- _message_ - string; (Optional) add a message to the signature to further authenticate the prooving process. + +Outputs: + +- _signature_ - string; spend signature. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"this is my transaction"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "signature": "SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB" + } +} + +``` +--- + +### **get_transfer_by_txid** + +Show information about a transfer to/from this address. + +Alias: _None_. + +Inputs: + +- _txid_ - string; Transaction ID used to find the transfer. +- _account_index_ - unsigned int; (Optional) Index of the account to query for the transfer. + +Outputs: + +- _transfer_ - JSON object containing payment information: + - _address_ - string; Address that transferred the funds. Base58 representation of the public keys. + - _amount_ - unsigned int; Amount of this transfer. + - _confirmations_ - unsigned int; Number of block mined since the block containing this transaction (or block height at which the transaction should be added to a block if not yet confirmed). + - _destinations_ - array of JSON objects containing transfer destinations: + - _amount_ - unsigned int; Amount transferred to this destination. + - _address_ - string; Address for this destination. Base58 representation of the public keys. + - _double_spend_seen_ - boolean; True if the key image(s) for the transfer have been seen before. + - _fee_ - unsigned int; Transaction fee for this transfer. + - _height_ - unsigned int; Height of the first block that confirmed this transfer. + - _note_ - string; Note about this transfer. + - _payment_id_ - string; Payment ID for this transfer. + - _subaddr_index_ - JSON object containing the major & minor subaddress index: + - _major_ - unsigned int; Account index for the subaddress. + - _minor_ - unsigned int; Index of the subaddress under the account. + - _suggested_confirmations_threshold_ - unsigned int; Estimation of the confirmations needed for the transaction to be included in a block. + - _timestamp_ - unsigned int; POSIX timestamp for the block that confirmed this transfer (or timestamp submission if not mined yet). + - _txid_ - string; Transaction ID of this transfer (same as input TXID). + - _type_ - string; Type of transfer, one of the following: "in", "out", "pending", "failed", "pool" + - _unlock_time_ - unsigned int; Number of blocks until transfer is safely spendable. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_transfer_by_txid","params":{"txid":"c36258a276018c3a4bc1f195a7fb530f50cd63a4fa765fb7c6f7f49fc051762a"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "transfer": { "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", - "amount": 1000000000000, - "block_height": 127606, - "payment_id": "60900e5603bf96e3", + "amount": 300000000000, + "confirmations": 1, + "destinations": [{ + "address": "7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o", + "amount": 100000000000 + },{ + "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp", + "amount": 200000000000 + }], + "double_spend_seen": false, + "fee": 21650200000, + "height": 153624, + "note": "", + "payment_id": "0000000000000000", "subaddr_index": { "major": 0, "minor": 0 }, - "tx_hash": "3292e83ad28fc1cc7bc26dbd38862308f4588680fbf93eae3e803cddd1bd614f", + "suggested_confirmations_threshold": 1, + "timestamp": 1535918400, + "txid": "c36258a276018c3a4bc1f195a7fb530f50cd63a4fa765fb7c6f7f49fc051762a", + "type": "out", + "unlock_time": 0 + } + } +} + +``` +--- + +### **get_transfers** + +Returns a list of transfers. + +Alias: _None_. + +Inputs: + +- _in_ - boolean; (Optional) Include incoming transfers. +- _out_ - boolean; (Optional) Include outgoing transfers. +- _pending_ - boolean; (Optional) Include pending transfers. +- _failed_ - boolean; (Optional) Include failed transfers. +- _pool_ - boolean; (Optional) Include transfers from the daemon's transaction pool. +- _filter_by_height_ - boolean; (Optional) Filter transfers by block height. +- _min_height_ - unsigned int; (Optional) Minimum block height to scan for transfers, if filtering by height is enabled. +- _max_height_ - unsigned int; (Opional) Maximum block height to scan for transfers, if filtering by height is enabled (defaults to max block height). +- _account_index_ - unsigned int; (Optional) Index of the account to query for transfers. (defaults to 0) +- _subaddr_indices_ - array of unsigned int; (Optional) List of subaddress indices to query for transfers. (defaults to 0) + +Outputs: + +- _in_ array of transfers: + - _address_ - string; Public address of the transfer. + - _amount_ - unsigned int; Amount transferred. + - _confirmations_ - unsigned int; Number of block mined since the block containing this transaction (or block height at which the transaction should be added to a block if not yet confirmed). + - _double_spend_seen_ - boolean; True if the key image(s) for the transfer have been seen before. + - _fee_ - unsigned int; Transaction fee for this transfer. + - _height_ - unsigned int; Height of the first block that confirmed this transfer (0 if not mined yet). + - _note_ - string; Note about this transfer. + - _payment_id_ - string; Payment ID for this transfer. + - _subaddr_index_ - JSON object containing the major & minor subaddress index: + - _major_ - unsigned int; Account index for the subaddress. + - _minor_ - unsigned int; Index of the subaddress under the account. + - _suggested_confirmations_threshold_ - unsigned int; Estimation of the confirmations needed for the transaction to be included in a block. + - _timestamp_ - unsigned int; POSIX timestamp for when this transfer was first confirmed in a block (or timestamp submission if not mined yet). + - _txid_ - string; Transaction ID for this transfer. + - _type_ - string; Transfer type: "in" + - _unlock_time_ - unsigned int; Number of blocks until transfer is safely spendable. +- _out_ array of transfers (see above). +- _pending_ array of transfers (see above). +- _failed_ array of transfers (see above). +- _pool_ array of transfers (see above). + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_transfers","params":{"in":true,"account_index":1}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "in": [{ + "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp", + "amount": 200000000000, + "confirmations": 1, + "double_spend_seen": false, + "fee": 21650200000, + "height": 153624, + "note": "", + "payment_id": "0000000000000000", + "subaddr_index": { + "major": 1, + "minor": 0 + }, + "suggested_confirmations_threshold": 1, + "timestamp": 1535918400, + "txid": "c36258a276018c3a4bc1f195a7fb530f50cd63a4fa765fb7c6f7f49fc051762a", + "type": "in", "unlock_time": 0 }] } @@ -1068,6 +1241,214 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- +### **get_tx_key** + +Get transaction secret key from transaction id. + +Alias: _None_. + +Inputs: + +- _txid_ - string; transaction id. + +Outputs: + +- _tx_key_ - string; transaction secret key. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_tx_key","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "tx_key": "feba662cf8fb6d0d0da18fc9b70ab28e01cc76311278fdd7fe7ab16360762b06" + } +} + +``` +--- + +### **get_tx_notes** + +Get string notes for transactions. + +Alias: _None_. + +Inputs: + +- _txids_ - array of string; transaction ids + +Outputs: + +- _notes_ - array of string; notes for the transactions + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_tx_notes","params":{"txids":["3292e83ad28fc1cc7bc26dbd38862308f4588680fbf93eae3e803cddd1bd614f"]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "notes": ["This is an example"] + } +} + +``` +--- + +### **get_tx_proof** + +Get transaction signature to prove it. + +Alias: _None_. + +Inputs: + +- _txid_ - string; transaction id. +- _address_ - string; destination public address of the transaction. +- _message_ - string; (Optional) add a message to the signature to further authenticate the prooving process. + +Outputs: + +- _signature_ - string; transaction signature. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_tx_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o","message":"this is my transaction"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "signature": "InProofV13vqBCT6dpSAXkypZmSEMPGVnNRFDX2vscUYeVS4WnSVnV5BwLs31T9q6Etfj9Wts6tAxSAS4gkMeSYzzLS7Gt4vvCSQRh9niGJMUDJsB5hTzb2XJiCkUzWkkcjLFBBRVD5QZ" + } +} + +``` +--- + +### **get_version** + +Get RPC version Major & Minor integer-format, where Major is the first 16 bits and Minor the last 16 bits. + +Alias: _None_. + +Inputs: _None_. + +Outputs: + +- _version_ - unsigned int; RPC version, formatted with `Major * 2^16 + Minor`(Major encoded over the first 16 bits, and Minor over the last 16 bits). + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_version"}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "version": 65539 + } +} +``` +--- + +### **import_key_images** + +Import signed key images list and verify their spent status. + +Alias: _None_. + +Inputs: + +- _signed_key_images_ - array of signed key images: + - _key_image_ - string; + - _signature_ - string; + +Outputs: + +- _height_ - unsigned int; +- _spent_ - unsigned int; Amount (in atomic units) spent from those key images. +- _unspent_ - unsigned int; Amount (in atomic units) still available from those key images. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"import_key_images", "params":{"signed_key_images":[{"key_image":"cd35239b72a35e26a57ed17400c0b66944a55de9d5bda0f21190fed17f8ea876","signature":"c9d736869355da2538ab4af188279f84138c958edbae3c5caf388a63cd8e780b8c5a1aed850bd79657df659422c463608ea4e0c730ba9b662c906ae933816d00"},{"key_image":"65158a8ee5a3b32009b85a307d85b375175870e560e08de313531c7dbbe6fc19","signature":"c96e40d09dfc45cfc5ed0b76bfd7ca793469588bb0cf2b4d7b45ef23d40fd4036057b397828062e31700dc0c2da364f50cd142295a8405b9fe97418b4b745d0c"}]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "height": 76428, + "spent": 62708953408711, + "unspent": 0 + } +} + +``` +--- + +### **import_multisig_info** + +Import multisig info from other participants. + +Alias: _None_. + +Inputs: + +- _info_ - array of string; List of multisig info in hex format from other participants. + +Outputs: + +- _n_outputs_ - unsigned int; Number of outputs signed with those multisig info. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"import_multisig_info","params":{"info":["...multisig_info..."]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "n_outputs": 35 + } +} + +``` +--- + +### **import_outputs** + +Import outputs in hex format. + +Alias: _None_. + +Inputs: + +- _outputs_data_hex_ - string; wallet outputs in hex format. + +Outputs: + +- _num_imported_ - unsigned int; number of outputs imported. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"import_outputs","params":{"outputs_data_hex":"...outputs..."}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "num_imported": 6400 + } +} + +``` +--- + ### **incoming_transfers** Return a list of incoming transfers to the wallet. @@ -1181,43 +1562,110 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **query_key** +### **is_multisig** -Return the spend or view private key. +Check if a wallet is a multisig one. Alias: _None_. -Inputs: - -- _key_type_ - string; Which key to retrieve: "mnemonic" - the mnemonic seed (older wallets do not have one) OR "view_key" - the view key +Inputs: _None_. Outputs: -- _key_ - string; The view key will be hex encoded, while the mnemonic will be a string of words. +- _multisig_ - boolean; States if the wallet is multisig +- _ready_ - boolean; +- _threshold_ - unsigned int; Amount of signature needed to sign a transfer. +- _total_ - unsigned int; Total amount of signature in the multisig wallet. -Example (Query view key): +Example for a non-multisig wallet: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"query_key","params":{"key_type":"view_key"}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"is_multisig"}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "key": "0a1a38f6d246e894600a3e27238a064bf5e8d91801df47a17107596b1378e501" + "multisig": false, + "ready": false, + "threshold": 0, + "total": 0 } } ``` -Example (Query mnemonic key): +Example for a multisig wallet: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"query_key","params":{"key_type":"mnemonic"}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"is_multisig"}' -H 'Content-Type: application/json' { + "id": "0", + "jsonrpc": "2.0", + "result": { + "multisig": true, + "ready": true, + "threshold": 2, + "total": 2 + } +} + +``` +--- + +### **label_account** + +Label an account. + +Alias: _None_. + +Inputs: + +- _account_index_ - unsigned int; Apply label to account at this index. +- _label_ - string; Label for the account. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"label_account","params":{"account_index":0,"label":"Primary account"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "account_tags": [{ + "accounts": [0,1], + "label": "", + "tag": "myTag" + }] + } +} + +``` +--- + +### **label_address** + +Label an address. + +Alias: _None_. + +Inputs: + +- _index_ - subaddress index; JSON Object containing the major & minor address index: + - _major_ - unsigned int; Account index for the subaddress. + - _minor_ - unsigned int; Index of the subaddress in the account. +- _label_ - string; Label for the address. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"label_address","params":{"index":{"major":0,"minor":5},"label":"myLabel"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "key": "vocal either anvil films dolphin zeal bacon cuisine quote syndrome rejoices envy okay pancakes tulips lair greater petals organs enmity dedicated oust thwart tomorrow tomorrow" } } @@ -1256,850 +1704,48 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **split_integrated_address** +### **make_multisig** -Retrieve the standard address and payment id corresponding to an integrated address. +Make a wallet multisig by importing peers multisig string. Alias: _None_. Inputs: -- _integrated_address_ - string +- _multisig_info_ - array of string; List of multisig string from peers. +- _threshold_ - unsigned int; Amount of signatures needed to sign a transfer. Must be less or equal than the amount of signature in `multisig_info`. +- _password_ - string; Wallet password Outputs: -- _is_subaddress_ - boolean; States if the address is a subaddress -- _payment_ - string; hex encoded -- _standard_address_ - string +- _address_ - string; multisig wallet address. +- _multisig_info_ - string; Multisig string to share with peers to create the multisig wallet (extra step for N-1/N wallets). -Example: +Example for 2/2 Multisig Wallet: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"split_integrated_address","params":{"integrated_address": "5F38Rw9HKeaLQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZXCkbHUXdPHyiUeRyokn"}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"make_multisig","params":{"multisig_info":["MultisigV1K4tGGe8QirZdHgTYoBZMumSug97fdDyM3Z63M3ZY5VXvAdoZvx16HJzPCP4Rp2ABMKUqLD2a74ugMdBfrVpKt4BwD8qCL5aZLrsYWoHiA7JJwDESuhsC3eF8QC9UMvxLXEMsMVh16o98GnKRYz1HCKXrAEWfcrCHyz3bLW1Pdggyowop"],"threshold":2}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "is_subaddress": false, - "payment_id": "420fa29b2d9a49f5", - "standard_address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt" - } -} - -``` ---- - -### **stop_wallet** - -Stops the wallet, storing the current state. - -Alias: _None_. - -Inputs: _None_. - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"stop_wallet"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - } -} - -``` ---- - -### **rescan_blockchain** - -Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. -This includes destination addresses, tx secret keys, tx notes, etc. - -Alias: _None_. - -Inputs: _None_. - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"rescan_blockchain"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - } -} - -``` ---- - -### **set_tx_notes** - -Set arbitrary string notes for transactions. - -Alias: _None_. - -Inputs: - -- _txids_ - array of string; transaction ids -- _notes_ - array of string; notes for the transactions - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"set_tx_notes","params":{"txids":["3292e83ad28fc1cc7bc26dbd38862308f4588680fbf93eae3e803cddd1bd614f"],"notes":["This is an example"]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - } -} - -``` ---- - -### **get_tx_notes** - -Get string notes for transactions. - -Alias: _None_. - -Inputs: - -- _txids_ - array of string; transaction ids - -Outputs: - -- _notes_ - array of string; notes for the transactions - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_tx_notes","params":{"txids":["3292e83ad28fc1cc7bc26dbd38862308f4588680fbf93eae3e803cddd1bd614f"]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "notes": ["This is an example"] - } -} - -``` ---- - -### **set_attribute** - -Set arbitrary attribute. - -Alias: _None_. - -Inputs: - -- _key_ - string; attribute name -- _value_ - string; attribute value - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"set_attribute","params":{"key":"my_attribute","value":"my_value"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - } -} - -``` ---- - -### **get_attribute** - -Get attribute value by name. - -Alias: _None_. - -Inputs: - -- _key_ - string; attribute name - -Outputs: - -- _value_ - string; attribute value - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_attribute","params":{"key":"my_attribute"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "value": "my_value" - } -} - -``` ---- - -### **get_tx_key** - -Get transaction secret key from transaction id. - -Alias: _None_. - -Inputs: - -- _txid_ - string; transaction id. - -Outputs: - -- _tx_key_ - string; transaction secret key. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_tx_key","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "tx_key": "feba662cf8fb6d0d0da18fc9b70ab28e01cc76311278fdd7fe7ab16360762b06" - } -} - -``` ---- - -### **check_tx_key** - -Check a transaction in the blockchain with its secret key. - -Alias: _None_. - -Inputs: - -- _txid_ - string; transaction id. -- _tx_key_ - string; transaction secret key. -- _address_ - string; destination public address of the transaction. - -Outputs: - -- _confirmations_ - unsigned int; Number of block mined after the one with the transaction. -- _in_pool_ - boolean; States if the transaction is still in pool or has been added to a block. -- _received_ - unsigned int; Amount of the transaction. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_tx_key","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","tx_key":"feba662cf8fb6d0d0da18fc9b70ab28e01cc76311278fdd7fe7ab16360762b06","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "confirmations": 0, - "in_pool": false, - "received": 1000000000000 - } -} - -``` ---- - -### **get_tx_proof** - -Get transaction signature to prove it. - -Alias: _None_. - -Inputs: - -- _txid_ - string; transaction id. -- _address_ - string; destination public address of the transaction. -- _message_ - string; (Optional) add a message to the signature to further authenticate the prooving process. - -Outputs: - -- _signature_ - string; transaction signature. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_tx_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o","message":"this is my transaction"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "signature": "InProofV13vqBCT6dpSAXkypZmSEMPGVnNRFDX2vscUYeVS4WnSVnV5BwLs31T9q6Etfj9Wts6tAxSAS4gkMeSYzzLS7Gt4vvCSQRh9niGJMUDJsB5hTzb2XJiCkUzWkkcjLFBBRVD5QZ" - } -} - -``` ---- - -### **check_tx_proof** - -Prove a transaction by checking its signature. - -Alias: _None_. - -Inputs: - -- _txid_ - string; transaction id. -- _address_ - string; destination public address of the transaction. -- _message_ - string; (Optional) Should be the same message used in `get_tx_proof`. -- _signature_ - string; transaction signature to confirm. - -Outputs: - -- _confirmations_ - unsigned int; Number of block mined after the one with the transaction. -- _good_ - boolean; States if the inputs proves the transaction. -- _in_pool_ - boolean; States if the transaction is still in pool or has been added to a block. -- _received_ - unsigned int; Amount of the transaction. - -In the example below, the transaction has been proven: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_tx_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o","message":"this is my transaction","signature":"InProofV13vqBCT6dpSAXkypZmSEMPGVnNRFDX2vscUYeVS4WnSVnV5BwLs31T9q6Etfj9Wts6tAxSAS4gkMeSYzzLS7Gt4vvCSQRh9niGJMUDJsB5hTzb2XJiCkUzWkkcjLFBBRVD5QZ"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "confirmations": 482, - "good": true, - "in_pool": false, - "received": 1000000000000 + "address": "55SoZTKH7D39drxfgT62k8T4adVFjmDLUXnbzEKYf1MoYwnmTNKKaqGfxm4sqeKCHXQ5up7PVxrkoeRzXu83d8xYURouMod", + "multisig_info": "" } } ``` -In the example below, the wrong message is used, avoiding the transaction to be proved: +Example for 2/3 Multisig Wallet: ``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_tx_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o","message":"wrong message","signature":"InProofV13vqBCT6dpSAXkypZmSEMPGVnNRFDX2vscUYeVS4WnSVnV5BwLs31T9q6Etfj9Wts6tAxSAS4gkMeSYzzLS7Gt4vvCSQRh9niGJMUDJsB5hTzb2XJiCkUzWkkcjLFBBRVD5QZ"}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"make_multisig","params":{"multisig_info":["MultisigV1MTVm4DZAdJw1PyVutpSy8Q4WisZBCFRAaZY7hhQnMwr5AZ4swzThyaSiVVQM5FHj1JQi3zPKhQ4k81BZkPSEaFjwRJtbfqfJcVvCqRnmBVcWVxhnihX5s8fZWBCjKrzT3CS95spG4dzNzJSUcjheAkLzCpVmSzGtgwMhAS3Vuz9Pas24","MultisigV1TEx58ycKCd6ADCfxF8hALpcdSRAkhZTi1bu4Rs6FdRC98EdB1LY7TAkMxasM55khFgcxrSXivaSr5FCMyJGHmojm1eE4HpGWPeZKv6cgCTThRzC4u6bkkSoFQdbzWN92yn1XEjuP2XQrGHk81mG2LMeyB51MWKJAVF99Pg9mX2BpmYFj"],"threshold":2}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "confirmations": 0, - "good": false, - "in_pool": false, - "received": 0 - } -} - -``` ---- - -### **get_spend_proof** - -Generate a signature to prove a spend. Unlike proving a transaction, it does not requires the destination public address. - -Alias: _None_. - -Inputs: - -- _txid_ - string; transaction id. -- _message_ - string; (Optional) add a message to the signature to further authenticate the prooving process. - -Outputs: - -- _signature_ - string; spend signature. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"this is my transaction"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "signature": "SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB" - } -} - -``` ---- - -### **check_spend_proof** - -Prove a spend using a signature. Unlike proving a transaction, it does not requires the destination public address. - -Alias: _None_. - -Inputs: - -- _txid_ - string; transaction id. -- _message_ - string; (Optional) Should be the same message used in `get_spend_proof`. -- _signature_ - string; spend signature to confirm. - -Outputs: - -- _good_ - boolean; States if the inputs proves the spend. - -In the example below, the spend has been proven: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"this is my transaction","signature":"SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "good": true - } -} - -``` - -In the example below, the wrong message is used, avoiding the spend to be proved: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"wrong message","signature":"SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "good": false - } -} - -``` ---- - -### **get_reserve_proof** - -Generate a signature to prove of an available amount in a wallet. - -Alias: _None_. - -Inputs: - -- _all_ - boolean; Proves all wallet balance to be disposable. -- _account_index_ - unsigned int; Specify the account from witch to prove reserve. (ignored if `all` is set to true) -- _amount_ - unsigned int; Amount (in atomic units) to prove the account has for reserve. (ignored if `all` is set to true) -- _message_ - string; (Optional) add a message to the signature to further authenticate the prooving process. - -Outputs: - -- _signature_ - string; reserve signature. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_reserve_proof","params":{"all":false,"account_index":0,"amount":100000000000}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "signature": "ReserveProofV11BZ23sBt9sZJeGccf84mzyAmNCP3KzYbE1111112VKmH111118NfCYJQjZ6c46gT2kXgcHCaSSZeL8sRdzqjqx7i1e7FQfQGu2o113UYFVdwzHQi3iENDPa76Kn1BvywbKz3bMkXdZkBEEhBSF4kjjGaiMJ1ucKb6wvMVC4A8sA4nZEdL2Mk3wBucJCYTZwKqA8i1M113kqakDkG25FrjiDqdQTCYz2wDBmfKxF3eQiV5FWzZ6HmAyxnqTWUiMWukP9A3Edy3ZXqjP1b23dhz7Mbj39bBxe3ZeDNu9HnTSqYvHNRyqCkeUMJpHyQweqjGUJ1DSfFYr33J1E7MkhMnEi1o7trqWjVix32XLetYfePG73yvHbS24837L7Q64i5n1LSpd9yMiQZ3Dyaysi5y6jPx7TpAvnSqBFtuCciKoNzaXoA3dqt9cuVFZTXzdXKqdt3cXcVJMNxY8RvKPVQHhUur94Lpo1nSpxf7BN5a5rHrbZFqoZszsZmiWikYPkLX72XUdw6NWjLrTBxSy7KuPYH86c6udPEXLo2xgN6XHMBMBJzt8FqqK7EcpNUBkuHm2AtpGkf9CABY3oSjDQoRF5n4vNLd3qUaxNsG4XJ12L9gJ7GrK273BxkfEA8fDdxPrb1gpespbgEnCTuZHqj1A" - } -} - -``` ---- - -### **check_reserve_proof** - -Proves a wallet has a disposable reserve using a signature. - -Alias: _None_. - -Inputs: - -- _address_ - string; Public address of the wallet. -- _message_ - string; (Optional) Should be the same message used in `get_reserve_proof`. -- _signature_ - string; reserve signature to confirm. - -Outputs: - -- _good_ - boolean; States if the inputs proves the reserve. - -In the example below, the reserve has been proven: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_reserve_proof","params":{"address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","signature":"ReserveProofV11BZ23sBt9sZJeGccf84mzyAmNCP3KzYbE1111112VKmH111118NfCYJQjZ6c46gT2kXgcHCaSSZeL8sRdzqjqx7i1e7FQfQGu2o113UYFVdwzHQi3iENDPa76Kn1BvywbKz3bMkXdZkBEEhBSF4kjjGaiMJ1ucKb6wvMVC4A8sA4nZEdL2Mk3wBucJCYTZwKqA8i1M113kqakDkG25FrjiDqdQTCYz2wDBmfKxF3eQiV5FWzZ6HmAyxnqTWUiMWukP9A3Edy3ZXqjP1b23dhz7Mbj39bBxe3ZeDNu9HnTSqYvHNRyqCkeUMJpHyQweqjGUJ1DSfFYr33J1E7MkhMnEi1o7trqWjVix32XLetYfePG73yvHbS24837L7Q64i5n1LSpd9yMiQZ3Dyaysi5y6jPx7TpAvnSqBFtuCciKoNzaXoA3dqt9cuVFZTXzdXKqdt3cXcVJMNxY8RvKPVQHhUur94Lpo1nSpxf7BN5a5rHrbZFqoZszsZmiWikYPkLX72XUdw6NWjLrTBxSy7KuPYH86c6udPEXLo2xgN6XHMBMBJzt8FqqK7EcpNUBkuHm2AtpGkf9CABY3oSjDQoRF5n4vNLd3qUaxNsG4XJ12L9gJ7GrK273BxkfEA8fDdxPrb1gpespbgEnCTuZHqj1A"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "good": true, - "spent": 0, - "total": 100000000000 - } -} - -``` - -In the example below, all wallet reserve has been proven: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_reserve_proof","params":{"address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","message":"I have 10 at least","signature":"...signature..."}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "good": true, - "spent": 0, - "total": 164113855714662789 - } -} - -``` - -In the example below, the wrong message is used, avoiding the reserve to be proved: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"check_spend_proof","params":{"txid":"19d5089f9469db3d90aca9024dfcb17ce94b948300101c8345a5e9f7257353be","message":"wrong message","signature":"SpendProofV1aSh8Todhk54736iXgV6vJAFP7egxByuMWZeyNDaN2JY737S95X5zz5mNMQSuCNSLjjhi5HJCsndpNWSNVsuThxwv285qy1KkUrLFRkxMSCjfL6bbycYN33ScZ5UB4Fzseceo1ndpL393T1q638VmcU3a56dhNHF1RPZFiGPS61FA78nXFSqE9uoKCCoHkEz83M1dQVhxZV5CEPF2P6VioGTKgprLCH9vvj9k1ivd4SX19L2VSMc3zD1u3mkR24ioETvxBoLeBSpxMoikyZ6inhuPm8yYo9YWyFtQK4XYfAV9mJ9knz5fUPXR8vvh7KJCAg4dqeJXTVb4mbMzYtsSZXHd6ouWoyCd6qMALdW8pKhgMCHcVYMWp9X9WHZuCo9rsRjRpg15sJUw7oJg1JoGiVgj8P4JeGDjnZHnmLVa5bpJhVCbMhyM7JLXNQJzFWTGC27TQBbthxCfQaKdusYnvZnKPDJWSeceYEFzepUnsWhQtyhbb73FzqgWC4eKEFKAZJqT2LuuSoxmihJ9acnFK7Ze23KTVYgDyMKY61VXADxmSrBvwUtxCaW4nQtnbMxiPMNnDMzeixqsFMBtN72j5UqhiLRY99k6SE7Qf5f29haNSBNSXCFFHChPKNTwJrehkofBdKUhh2VGPqZDNoefWUwfudeu83t85bmjv8Q3LrQSkFgFjRT5tLo8TMawNXoZCrQpyZrEvnodMDDUUNf3NL7rxyv3gM1KrTWjYaWXFU2RAsFee2Q2MTwUW7hR25cJvSFuB1BX2bfkoCbiMk923tHZGU2g7rSKF1GDDkXAc1EvFFD4iGbh1Q5t6hPRhBV8PEncdcCWGq5uAL5D4Bjr6VXG8uNeCy5oYWNgbZ5JRSfm7QEhPv8Fy9AKMgmCxDGMF9dVEaU6tw2BAnJavQdfrxChbDBeQXzCbCfep6oei6n2LZdE5Q84wp7eoQFE5Cwuo23tHkbJCaw2njFi3WGBbA7uGZaGHJPyB2rofTWBiSUXZnP2hiE9bjJghAcDm1M4LVLfWvhZmFEnyeru3VWMETnetz1BYLUC5MJGFXuhnHwWh7F6r74FDyhdswYop4eWPbyrXMXmUQEccTGd2NaT8g2VHADZ76gMC6BjWESvcnz2D4n8XwdmM7ZQ1jFwhuXrBfrb1dwRasyXxxHMGAC2onatNiExyeQ9G1W5LwqNLAh9hvcaNTGaYKYXoceVzLkgm6e5WMkLsCwuZXvB"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "good": false - } -} - -``` ---- - -### **get_transfers** - -Returns a list of transfers. - -Alias: _None_. - -Inputs: - -- _in_ - boolean; (Optional) Include incoming transfers. -- _out_ - boolean; (Optional) Include outgoing transfers. -- _pending_ - boolean; (Optional) Include pending transfers. -- _failed_ - boolean; (Optional) Include failed transfers. -- _pool_ - boolean; (Optional) Include transfers from the daemon's transaction pool. -- _filter_by_height_ - boolean; (Optional) Filter transfers by block height. -- _min_height_ - unsigned int; (Optional) Minimum block height to scan for transfers, if filtering by height is enabled. -- _max_height_ - unsigned int; (Opional) Maximum block height to scan for transfers, if filtering by height is enabled (defaults to max block height). -- _account_index_ - unsigned int; (Optional) Index of the account to query for transfers. (defaults to 0) -- _subaddr_indices_ - array of unsigned int; (Optional) List of subaddress indices to query for transfers. (defaults to 0) - -Outputs: - -- _in_ array of transfers: - - _address_ - string; Public address of the transfer. - - _amount_ - unsigned int; Amount transferred. - - _confirmations_ - unsigned int; Number of block mined since the block containing this transaction (or block height at which the transaction should be added to a block if not yet confirmed). - - _double_spend_seen_ - boolean; True if the key image(s) for the transfer have been seen before. - - _fee_ - unsigned int; Transaction fee for this transfer. - - _height_ - unsigned int; Height of the first block that confirmed this transfer (0 if not mined yet). - - _note_ - string; Note about this transfer. - - _payment_id_ - string; Payment ID for this transfer. - - _subaddr_index_ - JSON object containing the major & minor subaddress index: - - _major_ - unsigned int; Account index for the subaddress. - - _minor_ - unsigned int; Index of the subaddress under the account. - - _suggested_confirmations_threshold_ - unsigned int; Estimation of the confirmations needed for the transaction to be included in a block. - - _timestamp_ - unsigned int; POSIX timestamp for when this transfer was first confirmed in a block (or timestamp submission if not mined yet). - - _txid_ - string; Transaction ID for this transfer. - - _type_ - string; Transfer type: "in" - - _unlock_time_ - unsigned int; Number of blocks until transfer is safely spendable. -- _out_ array of transfers (see above). -- _pending_ array of transfers (see above). -- _failed_ array of transfers (see above). -- _pool_ array of transfers (see above). - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_transfers","params":{"in":true,"account_index":1}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "in": [{ - "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp", - "amount": 200000000000, - "confirmations": 1, - "double_spend_seen": false, - "fee": 21650200000, - "height": 153624, - "note": "", - "payment_id": "0000000000000000", - "subaddr_index": { - "major": 1, - "minor": 0 - }, - "suggested_confirmations_threshold": 1, - "timestamp": 1535918400, - "txid": "c36258a276018c3a4bc1f195a7fb530f50cd63a4fa765fb7c6f7f49fc051762a", - "type": "in", - "unlock_time": 0 - }] - } -} - -``` ---- - -### **get_transfer_by_txid** - -Show information about a transfer to/from this address. - -Alias: _None_. - -Inputs: - -- _txid_ - string; Transaction ID used to find the transfer. -- _account_index_ - unsigned int; (Optional) Index of the account to query for the transfer. - -Outputs: - -- _transfer_ - JSON object containing payment information: - - _address_ - string; Address that transferred the funds. Base58 representation of the public keys. - - _amount_ - unsigned int; Amount of this transfer. - - _confirmations_ - unsigned int; Number of block mined since the block containing this transaction (or block height at which the transaction should be added to a block if not yet confirmed). - - _destinations_ - array of JSON objects containing transfer destinations: - - _amount_ - unsigned int; Amount transferred to this destination. - - _address_ - string; Address for this destination. Base58 representation of the public keys. - - _double_spend_seen_ - boolean; True if the key image(s) for the transfer have been seen before. - - _fee_ - unsigned int; Transaction fee for this transfer. - - _height_ - unsigned int; Height of the first block that confirmed this transfer. - - _note_ - string; Note about this transfer. - - _payment_id_ - string; Payment ID for this transfer. - - _subaddr_index_ - JSON object containing the major & minor subaddress index: - - _major_ - unsigned int; Account index for the subaddress. - - _minor_ - unsigned int; Index of the subaddress under the account. - - _suggested_confirmations_threshold_ - unsigned int; Estimation of the confirmations needed for the transaction to be included in a block. - - _timestamp_ - unsigned int; POSIX timestamp for the block that confirmed this transfer (or timestamp submission if not mined yet). - - _txid_ - string; Transaction ID of this transfer (same as input TXID). - - _type_ - string; Type of transfer, one of the following: "in", "out", "pending", "failed", "pool" - - _unlock_time_ - unsigned int; Number of blocks until transfer is safely spendable. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_transfer_by_txid","params":{"txid":"c36258a276018c3a4bc1f195a7fb530f50cd63a4fa765fb7c6f7f49fc051762a"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "transfer": { - "address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt", - "amount": 300000000000, - "confirmations": 1, - "destinations": [{ - "address": "7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o", - "amount": 100000000000 - },{ - "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp", - "amount": 200000000000 - }], - "double_spend_seen": false, - "fee": 21650200000, - "height": 153624, - "note": "", - "payment_id": "0000000000000000", - "subaddr_index": { - "major": 0, - "minor": 0 - }, - "suggested_confirmations_threshold": 1, - "timestamp": 1535918400, - "txid": "c36258a276018c3a4bc1f195a7fb530f50cd63a4fa765fb7c6f7f49fc051762a", - "type": "out", - "unlock_time": 0 - } - } -} - -``` ---- - -### **sign** - -Sign a string. - -Alias: _None_. - -Inputs: - -- _data_ - string; Anything you need to sign. - -Outputs: - -- _signature_ - string; Signature generated against the "data" and the account public address. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sign","params":{"data":"This is sample data to be signed"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "signature": "SigV14K6G151gycjiGxjQ74tKX6A2LwwghvuHjcDeuRFQio5LS6Gb27BNxjYQY1dPuUvXkEbGQUkiHSVLPj4nJAHRrrw3" - } -} - -``` ---- - -### **verify** - -Verify a signature on a string. - -Alias: _None_. - -Inputs: - -- _data_ - string; What should have been signed. -- _address_ - string; Public address of the wallet used to `sign` the data. -- _signature_ - string; signature generated by `sign` method. - -Outputs: - -- _good_ - boolean; - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"verify","params":{"data":"This is sample data to be signed","address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","signature":"SigV14K6G151gycjiGxjQ74tKX6A2LwwghvuHjcDeuRFQio5LS6Gb27BNxjYQY1dPuUvXkEbGQUkiHSVLPj4nJAHRrrw3"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "good": true - } -} - -``` ---- - -### **export_outputs** - -Export all outputs in hex format. - -Alias: _None_. - -Inputs: _None_. - -Outputs: - -- _outputs_data_hex_ - string; wallet outputs in hex format. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"export_outputs"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "outputs_data_hex": "...outputs..." - } -} - -``` ---- - -### **import_outputs** - -Import outputs in hex format. - -Alias: _None_. - -Inputs: - -- _outputs_data_hex_ - string; wallet outputs in hex format. - -Outputs: - -- _num_imported_ - unsigned int; number of outputs imported. - -Example: - -``` -$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"import_outputs","params":{"outputs_data_hex":"...outputs..."}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "num_imported": 6400 - } -} - -``` ---- - -### **export_key_images** - -Export a signed set of key images. - -Alias: _None_. - -Inputs: _None_. - -Outputs: - -- _signed_key_images_ - array of signed key images: - - _key_image_ - string; - - _signature_ - string; - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"export_key_images"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "signed_key_images": [{ - "key_image": "cd35239b72a35e26a57ed17400c0b66944a55de9d5bda0f21190fed17f8ea876", - "signature": "c9d736869355da2538ab4af188279f84138c958edbae3c5caf388a63cd8e780b8c5a1aed850bd79657df659422c463608ea4e0c730ba9b662c906ae933816d00" - },{ - "key_image": "65158a8ee5a3b32009b85a307d85b375175870e560e08de313531c7dbbe6fc19", - "signature": "c96e40d09dfc45cfc5ed0b76bfd7ca793469588bb0cf2b4d7b45ef23d40fd4036057b397828062e31700dc0c2da364f50cd142295a8405b9fe97418b4b745d0c" - },...] - } -} - -``` ---- - -### **import_key_images** - -Import signed key images list and verify their spent status. - -Alias: _None_. - -Inputs: - -- _signed_key_images_ - array of signed key images: - - _key_image_ - string; - - _signature_ - string; - -Outputs: - -- _height_ - unsigned int; -- _spent_ - unsigned int; Amount (in atomic units) spent from those key images. -- _unspent_ - unsigned int; Amount (in atomic units) still available from those key images. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"import_key_images", "params":{"signed_key_images":[{"key_image":"cd35239b72a35e26a57ed17400c0b66944a55de9d5bda0f21190fed17f8ea876","signature":"c9d736869355da2538ab4af188279f84138c958edbae3c5caf388a63cd8e780b8c5a1aed850bd79657df659422c463608ea4e0c730ba9b662c906ae933816d00"},{"key_image":"65158a8ee5a3b32009b85a307d85b375175870e560e08de313531c7dbbe6fc19","signature":"c96e40d09dfc45cfc5ed0b76bfd7ca793469588bb0cf2b4d7b45ef23d40fd4036057b397828062e31700dc0c2da364f50cd142295a8405b9fe97418b4b745d0c"}]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "height": 76428, - "spent": 62708953408711, - "unspent": 0 + "address": "51sLpF8fWaK1111111111111111111111111111111111ABVbHNf1JFWJyFp5YZgZRQ44RiviJi1sPHgLVMbckRsDkTRgKS", + "multisig_info": "MultisigxV18jCaYAQQvzCMUJaAWMCaAbAoHpAD6WPmYDmLtBtazD654E8RWkLaGRf29fJ3stU471MELKxwufNYeigP7LoE4tn2Sscwn5g7PyCfcBc1V4ffRHY3Kxqq6VocSCUTncpVeUskaDKuTAWtdB9VTBGW7iG1cd7Zm1dYgur3CiemkGjRUAj9bL3xTEuyaKGYSDhtpFZFp99HQX57EawhiRHk3qq4hjWX" } } @@ -2139,6 +1785,33 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- +### **open_wallet** + +Open a wallet. You need to have set the argument "–wallet-dir" when launching monero-wallet-rpc to make this work. + +Alias: _None_. + +Inputs: + +- _filename_ - string; wallet name stored in –wallet-dir. +- _password_ - string; (Optional) only needed if the wallet has a password defined. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"open_wallet","params":{"filename":"mytestwallet","password":"mytestpassword"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + ### **parse_uri** Parse a payment URI to get payment information. @@ -2179,100 +1852,70 @@ $ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **get_address_book** +### **prepare_multisig** -Retrieves entries from the address book. +Prepare a wallet for multisig by generating a multisig string to share with peers. Alias: _None_. -Inputs: - -- _entries_ - array of unsigned int; indices of the requested address book entries +Inputs: _None_. Outputs: -- _entries_ - array of entries: - - _address_ - string; Public address of the entry - - _description_ - string; Description of this address entry - - _index_ - unsigned int; - - _payment_id_ - string; +- _multisig_info_ - string; Multisig string to share with peers to create the multisig wallet. Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_address_book","params":{"entries":[0,1]}}' -H 'Content-Type: application/json' +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"prepare_multisig"}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "entries": [{ - "address": "77Vx9cs1VPicFndSVgYUvTdLCJEZw9h81hXLMYsjBCXSJfUehLa9TDW3Ffh45SQa7xb6dUs18mpNxfUhQGqfwXPSMrvKhVp", - "description": "Second account", - "index": 0, - "payment_id": "0000000000000000000000000000000000000000000000000000000000000000" - },{ - "address": "78P16M3XmFRGcWFCcsgt1WcTntA1jzcq31seQX1Eg92j8VQ99NPivmdKam4J5CKNAD7KuNWcq5xUPgoWczChzdba5WLwQ4j", - "description": "Third account", - "index": 1, - "payment_id": "0000000000000000000000000000000000000000000000000000000000000000" - }] + "multisig_info": "MultisigV1BFdxQ653cQHB8wsj9WJQd2VdnjxK89g5M94dKPBNw22reJnyJYKrz6rJeXdjFwJ3Mz6n4qNQLd6eqUZKLiNzJFi3UPNVcTjtkG2aeSys9sYkvYYKMZ7chCxvoEXVgm74KKUcUu4V8xveCBFadFuZs8shnxBWHbcwFr5AziLr2mE7KHJT" } } ``` --- -### **add_address_book** +### **query_key** -Add an entry to the address book. +Return the spend or view private key. Alias: _None_. Inputs: -- _address_ - string; -- _payment_id_ - (optional) string, defaults to "0000000000000000000000000000000000000000000000000000000000000000"; -- _description_ - (optional) string, defaults to ""; +- _key_type_ - string; Which key to retrieve: "mnemonic" - the mnemonic seed (older wallets do not have one) OR "view_key" - the view key Outputs: -- _index_ - unsigned int; The index of the address book entry. +- _key_ - string; The view key will be hex encoded, while the mnemonic will be a string of words. -Example: +Example (Query view key): ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"add_address_book","params":{"address":"78P16M3XmFRGcWFCcsgt1WcTntA1jzcq31seQX1Eg92j8VQ99NPivmdKam4J5CKNAD7KuNWcq5xUPgoWczChzdba5WLwQ4j","description":"Third account"}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"query_key","params":{"key_type":"view_key"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "index": 1 + "key": "0a1a38f6d246e894600a3e27238a064bf5e8d91801df47a17107596b1378e501" } } ``` ---- -### **delete_address_book** - -Delete an entry from the address book. - -Alias: _None_. - -Inputs: - -- _index_ - unsigned int; The index of the address book entry. - -Outputs: _None_. - -Example: +Example (Query mnemonic key): ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"delete_address_book","params":{"index":1}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"query_key","params":{"key_type":"mnemonic"}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { + "key": "vocal either anvil films dolphin zeal bacon cuisine quote syndrome rejoices envy okay pancakes tulips lair greater petals organs enmity dedicated oust thwart tomorrow tomorrow" } } @@ -2310,6 +1953,60 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- +### **relay_tx** + +Relay a transaction previously created with `"do_not_relay":true`. + +Alias: _None_. + +Inputs: + +- _hex_ - string; transaction metadata returned from a `transfer` method with `get_tx_metadata` set to `true`. + +Outputs: + +- _tx_hash_ - String for the publically searchable transaction hash. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"relay_tx","params":{"hex":"...tx_metadata..."}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "tx_hash": "1c42dcc5672bb09bccf33fb1e9ab4a498af59a6dbd33b3d0cfb289b9e0e25fa5" + } +} + +``` +--- + +### **rescan_blockchain** + +Rescan the blockchain from scratch, losing any information which can not be recovered from the blockchain itself. +This includes destination addresses, tx secret keys, tx notes, etc. + +Alias: _None_. + +Inputs: _None_. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"rescan_blockchain"}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + ### **rescan_spent** Rescan the blockchain for spent outputs. @@ -2335,6 +2032,236 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- +### **set_account_tag_description** + +Set description for an account tag. + +Alias: _None_. + +Inputs: + +- _tag_ - string; Set a description for this tag. +- _description_ - string; Description for the tag. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"set_account_tag_description","params":{"tag":"myTag","description":"Test tag"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **set_attribute** + +Set arbitrary attribute. + +Alias: _None_. + +Inputs: + +- _key_ - string; attribute name +- _value_ - string; attribute value + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"set_attribute","params":{"key":"my_attribute","value":"my_value"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **set_tx_notes** + +Set arbitrary string notes for transactions. + +Alias: _None_. + +Inputs: + +- _txids_ - array of string; transaction ids +- _notes_ - array of string; notes for the transactions + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"set_tx_notes","params":{"txids":["3292e83ad28fc1cc7bc26dbd38862308f4588680fbf93eae3e803cddd1bd614f"],"notes":["This is an example"]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **sign** + +Sign a string. + +Alias: _None_. + +Inputs: + +- _data_ - string; Anything you need to sign. + +Outputs: + +- _signature_ - string; Signature generated against the "data" and the account public address. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sign","params":{"data":"This is sample data to be signed"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "signature": "SigV14K6G151gycjiGxjQ74tKX6A2LwwghvuHjcDeuRFQio5LS6Gb27BNxjYQY1dPuUvXkEbGQUkiHSVLPj4nJAHRrrw3" + } +} + +``` +--- + +### **sign_multisig** + +Sign a transaction in multisig. + +Alias: _None_. + +Inputs: + +- _tx_data_hex_ - string; Multisig transaction in hex format, as returned by `transfer` under `multisig_txset`. + +Outputs: + +- _tx_data_hex_ - string; Multisig transaction in hex format. +- _tx_hash_list_ - array of string; List of transaction Hash. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sign_multisig","params":{"tx_data_hex":"...multisig_txset..."}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "tx_data_hex": "...multisig_txset...", + "tx_hash_list": ["4996091b61c1be112c1097fd5e97d8ff8b28f0e5e62e1137a8c831bacf034f2d"] + } +} + +``` +--- + +### **sign_transfer** + +Sign a transaction created on a read-only wallet (in cold-signing process) + +Alias: _None_. + +Inputs: + +- _unsigned_txset_ - string. Set of unsigned tx returned by "transfer" or "transfer_split" methods. +- _export_raw_ - boolean; (Optional) If true, return the raw transaction data. (Defaults to false) + +Outputs: + +- _signed_txset_ - string. Set of signed tx to be used for submitting transfer. +- _tx_hash_list_ - array of: string. The tx hashes of every transaction. +- _tx_raw_list_ - array of: string. The tx raw data of every transaction. + +In the example below, we first generate an unsigned_txset on a read only wallet before signing it: + +Generate unsigned_txset using the above "transfer" method on read-only wallet: + +``` +curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"transfer","params":{"destinations":[{"amount":1000000000000,"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"}],"account_index":0,"subaddr_indices":[0],"priority":0,"ring_size":7,"do_not_relay":true,"get_tx_hex":true}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "amount": 1000000000000, + "fee": 15202740000, + "multisig_txset": "", + "tx_blob": "...long_hex...", + "tx_hash": "c648ba0a049e5ce4ec21361dbf6e4b21eac0f828eea9090215de86c76b31d0a4", + "tx_key": "", + "tx_metadata": "", + "unsigned_txset": "...long_hex..." + } +} + +``` + +Sign tx using the previously generated unsigned_txset + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sign_transfer","params":{"unsigned_txset":...long_hex..."}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "signed_txset": "...long_hex...", + "tx_hash_list": ["ff2e2d49fbfb1c9a55754f786576e171c8bf21b463a74438df604b7fa6cebc6d"] + } +} + +``` +--- + +### **split_integrated_address** + +Retrieve the standard address and payment id corresponding to an integrated address. + +Alias: _None_. + +Inputs: + +- _integrated_address_ - string + +Outputs: + +- _is_subaddress_ - boolean; States if the address is a subaddress +- _payment_ - string; hex encoded +- _standard_address_ - string + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"split_integrated_address","params":{"integrated_address": "5F38Rw9HKeaLQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZXCkbHUXdPHyiUeRyokn"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "is_subaddress": false, + "payment_id": "420fa29b2d9a49f5", + "standard_address": "55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt" + } +} + +``` +--- + ### **start_mining** Start mining in the Monero daemon. @@ -2387,91 +2314,9 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **get_languages** +### **stop_wallet** -Get a list of available languages for your wallet's seed. - -Alias: _None_. - -Inputs: _None_. - -Outputs: - -- _languages_ - array of string; List of available languages - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_languages"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "languages": ["Deutsch","English","Español","Français","Italiano","Nederlands","Português","русский язык","日本語","简体中文 (中国)","Esperanto","Lojban"] - } -} - -``` ---- - -### **create_wallet** - -Create a new wallet. You need to have set the argument "–wallet-dir" when launching monero-wallet-rpc to make this work. - -Alias: _None_. - -Inputs: - -- _filename_ - string; Wallet file name. -- _password_ - string; (Optional) password to protect the wallet. -- _language_ - string; Language for your wallets' seed. - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"create_wallet","params":{"filename":"mytestwallet","password":"mytestpassword","language":"English"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - } -} - -``` ---- - -### **open_wallet** - -Open a wallet. You need to have set the argument "–wallet-dir" when launching monero-wallet-rpc to make this work. - -Alias: _None_. - -Inputs: - -- _filename_ - string; wallet name stored in –wallet-dir. -- _password_ - string; (Optional) only needed if the wallet has a password defined. - -Outputs: _None_. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"open_wallet","params":{"filename":"mytestwallet","password":"mytestpassword"}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - } -} - -``` ---- - -### **close_wallet** - -Close the currently opened wallet, after trying to save it. +Stops the wallet, storing the current state. Alias: _None_. @@ -2482,7 +2327,7 @@ Outputs: _None_. Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"close_wallet"}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"stop_wallet"}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", @@ -2493,23 +2338,20 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **change_wallet_password** +### **store** -Change a wallet password. +Save the wallet file. Alias: _None_. -Inputs: - -- _old_password_ - string; (Optional) Current wallet password, if defined. -- _new_password_ - string; (Optional) New wallet password, if not blank. +Inputs: _None_. Outputs: _None_. Example: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"change_wallet_password","params":{"old_password":"theCurrentSecretPassPhrase","new_password":"theNewSecretPassPhrase"}}' -H 'Content-Type: application/json' +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"store"}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", @@ -2520,247 +2362,6 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **is_multisig** - -Check if a wallet is a multisig one. - -Alias: _None_. - -Inputs: _None_. - -Outputs: - -- _multisig_ - boolean; States if the wallet is multisig -- _ready_ - boolean; -- _threshold_ - unsigned int; Amount of signature needed to sign a transfer. -- _total_ - unsigned int; Total amount of signature in the multisig wallet. - -Example for a non-multisig wallet: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"is_multisig"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "multisig": false, - "ready": false, - "threshold": 0, - "total": 0 - } -} - -``` - -Example for a multisig wallet: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"is_multisig"}' -H 'Content-Type: application/json' { - "id": "0", - "jsonrpc": "2.0", - "result": { - "multisig": true, - "ready": true, - "threshold": 2, - "total": 2 - } -} - -``` ---- - -### **prepare_multisig** - -Prepare a wallet for multisig by generating a multisig string to share with peers. - -Alias: _None_. - -Inputs: _None_. - -Outputs: - -- _multisig_info_ - string; Multisig string to share with peers to create the multisig wallet. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"prepare_multisig"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "multisig_info": "MultisigV1BFdxQ653cQHB8wsj9WJQd2VdnjxK89g5M94dKPBNw22reJnyJYKrz6rJeXdjFwJ3Mz6n4qNQLd6eqUZKLiNzJFi3UPNVcTjtkG2aeSys9sYkvYYKMZ7chCxvoEXVgm74KKUcUu4V8xveCBFadFuZs8shnxBWHbcwFr5AziLr2mE7KHJT" - } -} - -``` ---- - -### **make_multisig** - -Make a wallet multisig by importing peers multisig string. - -Alias: _None_. - -Inputs: - -- _multisig_info_ - array of string; List of multisig string from peers. -- _threshold_ - unsigned int; Amount of signatures needed to sign a transfer. Must be less or equal than the amount of signature in `multisig_info`. -- _password_ - string; Wallet password - -Outputs: - -- _address_ - string; multisig wallet address. -- _multisig_info_ - string; Multisig string to share with peers to create the multisig wallet (extra step for N-1/N wallets). - -Example for 2/2 Multisig Wallet: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"make_multisig","params":{"multisig_info":["MultisigV1K4tGGe8QirZdHgTYoBZMumSug97fdDyM3Z63M3ZY5VXvAdoZvx16HJzPCP4Rp2ABMKUqLD2a74ugMdBfrVpKt4BwD8qCL5aZLrsYWoHiA7JJwDESuhsC3eF8QC9UMvxLXEMsMVh16o98GnKRYz1HCKXrAEWfcrCHyz3bLW1Pdggyowop"],"threshold":2}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "address": "55SoZTKH7D39drxfgT62k8T4adVFjmDLUXnbzEKYf1MoYwnmTNKKaqGfxm4sqeKCHXQ5up7PVxrkoeRzXu83d8xYURouMod", - "multisig_info": "" - } -} - -``` - -Example for 2/3 Multisig Wallet: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"make_multisig","params":{"multisig_info":["MultisigV1MTVm4DZAdJw1PyVutpSy8Q4WisZBCFRAaZY7hhQnMwr5AZ4swzThyaSiVVQM5FHj1JQi3zPKhQ4k81BZkPSEaFjwRJtbfqfJcVvCqRnmBVcWVxhnihX5s8fZWBCjKrzT3CS95spG4dzNzJSUcjheAkLzCpVmSzGtgwMhAS3Vuz9Pas24","MultisigV1TEx58ycKCd6ADCfxF8hALpcdSRAkhZTi1bu4Rs6FdRC98EdB1LY7TAkMxasM55khFgcxrSXivaSr5FCMyJGHmojm1eE4HpGWPeZKv6cgCTThRzC4u6bkkSoFQdbzWN92yn1XEjuP2XQrGHk81mG2LMeyB51MWKJAVF99Pg9mX2BpmYFj"],"threshold":2}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "address": "51sLpF8fWaK1111111111111111111111111111111111ABVbHNf1JFWJyFp5YZgZRQ44RiviJi1sPHgLVMbckRsDkTRgKS", - "multisig_info": "MultisigxV18jCaYAQQvzCMUJaAWMCaAbAoHpAD6WPmYDmLtBtazD654E8RWkLaGRf29fJ3stU471MELKxwufNYeigP7LoE4tn2Sscwn5g7PyCfcBc1V4ffRHY3Kxqq6VocSCUTncpVeUskaDKuTAWtdB9VTBGW7iG1cd7Zm1dYgur3CiemkGjRUAj9bL3xTEuyaKGYSDhtpFZFp99HQX57EawhiRHk3qq4hjWX" - } -} - -``` ---- - -### **export_multisig_info** - -Export multisig info for other participants. - -Alias: _None_. - -Inputs: _None_. - -Outputs: - -- _info_ - string; Multisig info in hex format for other participants. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"export_multisig_info"}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "info": "4d6f6e65726f206d756c7469736967206578706f72740105cf6442b09b75f5eca9d846771fe1a879c9a97ab0553ffbcec64b1148eb7832b51e7898d7944c41cee000415c5a98f4f80dc0efdae379a98805bb6eacae743446f6f421cd03e129eb5b27d6e3b73eb6929201507c1ae706c1a9ecd26ac8601932415b0b6f49cbbfd712e47d01262c59980a8f9a8be776f2bf585f1477a6df63d6364614d941ecfdcb6e958a390eb9aa7c87f056673d73bc7c5f0ab1f74a682e902e48a3322c0413bb7f6fd67404f13fb8e313f70a0ce568c853206751a334ef490068d3c8ca0e" - } -} - -``` ---- - -### **import_multisig_info** - -Import multisig info from other participants. - -Alias: _None_. - -Inputs: - -- _info_ - array of string; List of multisig info in hex format from other participants. - -Outputs: - -- _n_outputs_ - unsigned int; Number of outputs signed with those multisig info. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"import_multisig_info","params":{"info":["...multisig_info..."]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "n_outputs": 35 - } -} - -``` ---- - -### **finalize_multisig** - -Turn this wallet into a multisig wallet, extra step for N-1/N wallets. - -Alias: _None_. - -Inputs: - -- _multisig_info_ - array of string; List of multisig string from peers. -- _password_ - string; Wallet password - -Outputs: - -- _address_ - string; multisig wallet address. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"finalize_multisig","params":{"multisig_info":["MultisigxV1JNC6Ja2oBt5Sqea9LN2YEF7WYZCpHqr2EKvPG89Trf3X4E8RWkLaGRf29fJ3stU471MELKxwufNYeigP7LoE4tn2McPr4SbL9q15xNvZT5uwC9YRr7UwjXqSZHmTWN9PBuZEKVAQ4HPPyQciSCdNjgwsuFRBzrskMdMUwNMgKst1debYfm37i6PSzDoS2tk4kYTYj83kkAdR7kdshet1axQPd6HQ","MultisigxV1Unma7Ko4zdd8Ps3Af4oZwtj2JdWKzwNfP6s2G9ZvXhMoSscwn5g7PyCfcBc1V4ffRHY3Kxqq6VocSCUTncpVeUskMcPr4SbL9q15xNvZT5uwC9YRr7UwjXqSZHmTWN9PBuZE1LTpWxLoC3vPMSrqVVcjnmL9LYfdCZz3fECjNZbCEDq3PHDiUuY5jurQTcNoGhDTio5WM9xaAdim9YByiS5KyqF4"]}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "address": "5B9gZUTDuHTcGGuY3nL3t8K2tDnEHeRVHSBQgLZUTQxtFYVLnho5JJjWJyFp5YZgZRQ44RiviJi1sPHgLVMbckRsDqDx1gV" - } -} - -``` ---- - -### **sign_multisig** - -Sign a transaction in multisig. - -Alias: _None_. - -Inputs: - -- _tx_data_hex_ - string; Multisig transaction in hex format, as returned by `transfer` under `multisig_txset`. - -Outputs: - -- _tx_data_hex_ - string; Multisig transaction in hex format. -- _tx_hash_list_ - array of string; List of transaction Hash. - -Example: - -``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sign_multisig","params":{"tx_data_hex":"...multisig_txset..."}}' -H 'Content-Type: application/json' -{ - "id": "0", - "jsonrpc": "2.0", - "result": { - "tx_data_hex": "...multisig_txset...", - "tx_hash_list": ["4996091b61c1be112c1097fd5e97d8ff8b28f0e5e62e1137a8c831bacf034f2d"] - } -} - -``` ---- - ### **submit_multisig** Submit a signed multisig transaction. @@ -2790,29 +2391,375 @@ $ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","me ``` --- -### **get_version** +### **submit_transfer** -Get RPC version Major & Minor integer-format, where Major is the first 16 bits and Minor the last 16 bits. +Submit a previously signed transaction on a read-only wallet (in cold-signing process). Alias: _None_. -Inputs: _None_. +Inputs: + +- _tx_data_hex_ - string; Set of signed tx returned by "sign_transfer" Outputs: -- _version_ - unsigned int; RPC version, formatted with `Major * 2^16 + Minor`(Major encoded over the first 16 bits, and Minor over the last 16 bits). +- _tx_hash_list_ - array of: string. The tx hashes of every transaction. -Example: +In the example below, we submit the transfer using the signed_txset generated above: ``` -$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"get_version"}' -H 'Content-Type: application/json' +curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"submit_transfer","params":{"tx_data_hex":...long_hex..."}}' -H 'Content-Type: application/json' { "id": "0", "jsonrpc": "2.0", "result": { - "version": 65539 + "tx_hash_list": ["40fad7c828bb383ac02648732f7afce9adc520ba5629e1f5d9c03f584ac53d74"] } } + +``` +--- + +### **sweep_all** + +Send all unlocked balance to an address. + +Alias: _None_. + +Inputs: + +- _address_ - string; Destination public address. +- _account_index_ - unsigned int; Sweep transactions from this account. +- _subaddr_indices_ - array of unsigned int; (Optional) Sweep from this set of subaddresses in the account. +- _priority_ - unsigned int; (Optional) Priority for sending the sweep transfer, partially determines fee. +- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). +- _ring_size_ - unsigned int; Sets ringsize to n (mixin + 1). +- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). +- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. +- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. +- _below_amount_ - unsigned int; (Optional) Include outputs below this amount. +- _do_not_relay_ - boolean; (Optional) If true, do not relay this sweep transfer. (Defaults to false) +- _get_tx_hex_ - boolean; (Optional) return the transactions as hex encoded string. (Defaults to false) +- _get_tx_metadata_ - boolean; (Optional) return the transaction metadata as a string. (Defaults to false) + +Outputs: + +- _tx_hash_list_ - array of: string. The tx hashes of every transaction. +- _tx_key_list_ - array of: string. The transaction keys for every transaction. +- _amount_list_ - array of: integer. The amount transferred for every transaction. +- _fee_list_ - array of: integer. The amount of fees paid for every transaction. +- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. +- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. +- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). +- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sweep_all","params":{"address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","subaddr_indices":[4],"ring_size":7,"unlock_time":0,"get_tx_keys":true}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "amount_list": [9985885770000], + "fee_list": [14114230000], + "multisig_txset": "", + "tx_hash_list": ["ab4b6b65cc8cd8c9dd317d0b90d97582d68d0aa1637b0065b05b61f9a66ea5c5"], + "tx_key_list": ["b9b4b39d3bb3062ddb85ec0266d4df39058f4c86077d99309f218ce4d76af607"], + "unsigned_txset": "" + } +} + +``` +--- + +### **sweep_dust** + +Send all dust outputs back to the wallet's, to make them easier to spend (and mix). + +Alias: _sweep_unmixable_. + +Inputs: + +- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. +- _do_not_relay_ - boolean; (Optional) If true, the newly created transaction will not be relayed to the monero network. (Defaults to false) +- _get_tx_hex_ - boolean; (Optional) Return the transactions as hex string after sending. (Defaults to false) +- _get_tx_metadata_ - boolean; (Optional) Return list of transaction metadata needed to relay the transfer later. (Defaults to false) + +Outputs: + +- _tx_hash_list_ - array of: string. The tx hashes of every transaction. +- _tx_key_list_ - array of: string. The transaction keys for every transaction. +- _amount_list_ - array of: integer. The amount transferred for every transaction. +- _fee_list_ - array of: integer. The amount of fees paid for every transaction. +- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. +- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. +- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). +- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. + +Example (In this example, `sweep_dust` returns nothing because there are no funds to sweep): + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sweep_dust","params":{"get_tx_keys":true}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "multisig_txset": "", + "unsigned_txset": "" + } +} + +``` +--- + +### **sweep_single** + +Send all of a specific unlocked output to an address. + +Alias: _None_. + +Inputs: + +- _address_ - string; Destination public address. +- _account_index_ - unsigned int; Sweep transactions from this account. +- _subaddr_indices_ - array of unsigned int; (Optional) Sweep from this set of subaddresses in the account. +- _priority_ - unsigned int; (Optional) Priority for sending the sweep transfer, partially determines fee. +- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). +- _ring_size_ - unsigned int; Sets ringsize to n (mixin + 1). +- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). +- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. +- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. +- _key_image_ - string; Key image of specific output to sweep. +- _below_amount_ - unsigned int; (Optional) Include outputs below this amount. +- _do_not_relay_ - boolean; (Optional) If true, do not relay this sweep transfer. (Defaults to false) +- _get_tx_hex_ - boolean; (Optional) return the transactions as hex encoded string. (Defaults to false) +- _get_tx_metadata_ - boolean; (Optional) return the transaction metadata as a string. (Defaults to false) + +Outputs: + +- _tx_hash_list_ - array of: string. The tx hashes of every transaction. +- _tx_key_list_ - array of: string. The transaction keys for every transaction. +- _amount_list_ - array of: integer. The amount transferred for every transaction. +- _fee_list_ - array of: integer. The amount of fees paid for every transaction. +- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. +- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. +- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). +- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"sweep_single","params":{"address":"74Jsocx8xbpTBEjm3ncKE5LBQbiJouyCDaGhgSiebpvNDXZnTAbW2CmUR5SsBeae2pNk9WMVuz6jegkC4krUyqRjA6VjoLD","ring_size":7,"unlock_time":0,"key_image":"a7834459ef795d2efb6f665d2fd758c8d9288989d8d4c712a68f8023f7804a5e","get_tx_keys":true}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "amount": 27126892247503, + "fee": 14111630000, + "multisig_txset": "", + "tx_blob": "", + "tx_hash": "106d4391a031e5b735ded555862fec63233e34e5fa4fc7edcfdbe461c275ae5b", + "tx_key": "", + "tx_metadata": "", + "unsigned_txset": "" + } +} + +``` +--- + +### **tag_accounts** + +Apply a filtering tag to a list of accounts. + +Alias: _None_. + +Inputs: + +- _tag_ - string; Tag for the accounts. +- _accounts_ - array of unsigned int; Tag this list of accounts. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"tag_accounts","params":{"tag":"myTag","accounts":[0,1]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **transfer** + +Send monero to a number of recipients. + +Alias: _None_. + +Inputs: + +- _destinations_ - array of destinations to receive XMR: + - _amount_ - unsigned int; Amount to send to each destination, in atomic units. + - _address_ - string; Destination public address. +- _account_index_ - unsigned int; (Optional) Transfer from this account index. (Defaults to 0) +- _subaddr_indices_ - array of unsigned int; (Optional) Transfer from this set of subaddresses. (Defaults to 0) +- _priority_ - unsigned int; Set a priority for the transaction. Accepted Values are: 0-3 for: default, unimportant, normal, elevated, priority. +- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). +- _ring_size_ - unsigned int; Number of outputs to mix in the transaction (this output + N decoys from the blockchain). +- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). +- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. +- _get_tx_key_ - boolean; (Optional) Return the transaction key after sending. +- _do_not_relay_ - boolean; (Optional) If true, the newly created transaction will not be relayed to the monero network. (Defaults to false) +- _get_tx_hex_ - boolean; Return the transaction as hex string after sending (Defaults to false) +- _get_tx_metadata_ - boolean; Return the metadata needed to relay the transaction. (Defaults to false) + +Outputs: + +- _amount_ - Amount transferred for the transaction. +- _fee_ - Integer value of the fee charged for the txn. +- _multisig_txset_ - Set of multisig transactions in the process of being signed (empty for non-multisig). +- _tx_blob_ - Raw transaction represented as hex string, if get_tx_hex is true. +- _tx_hash_ - String for the publically searchable transaction hash. +- _tx_key_ - String for the transaction key if get_tx_key is true, otherwise, blank string. +- _tx_metadata_ - Set of transaction metadata needed to relay this transfer later, if get_tx_metadata is true. +- _unsigned_txset_ - String. Set of unsigned tx for cold-signing purposes. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"transfer","params":{"destinations":[{"amount":100000000000,"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"},{"amount":200000000000,"address":"75sNpRwUtekcJGejMuLSGA71QFuK1qcCVLZnYRTfQLgFU5nJ7xiAHtR5ihioS53KMe8pBhH61moraZHyLoG4G7fMER8xkNv"}],"account_index":0,"subaddr_indices":[0],"priority":0,"ring_size":7,"get_tx_key": true}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "amount": 300000000000, + "fee": 86897600000, + "multisig_txset": "", + "tx_blob": "", + "tx_hash": "7663438de4f72b25a0e395b770ea9ecf7108cd2f0c4b75be0b14a103d3362be9", + "tx_key": "25c9d8ec20045c80c93d665c9d3684aab7335f8b2cd02e1ba2638485afd1c70e236c4bdd7a2f1cb511dbf466f13421bdf8df988b7b969c448ca6239d7251490e4bf1bbf9f6ffacffdcdc93b9d1648ec499eada4d6b4e02ce92d4a1c0452e5d009fbbbf15b549df8856205a4c7bda6338d82c823f911acd00cb75850b198c5803", + "tx_metadata": "", + "unsigned_txset": "" + } +} + +``` +--- + +### **transfer_split** + +Same as transfer, but can split into more than one tx if necessary. + +Alias: _None_. + +Inputs: + +- _destinations_ - array of destinations to receive XMR: + - _amount_ - unsigned int; Amount to send to each destination, in atomic units. + - _address_ - string; Destination public address. +- _account_index_ - unsigned int; (Optional) Transfer from this account index. (Defaults to 0) +- _subaddr_indices_ - array of unsigned int; (Optional) Transfer from this set of subaddresses. (Defaults to 0) +- _mixin_ - unsigned int; Number of outputs from the blockchain to mix with (0 means no mixing). +- _ring_size_ - unsigned int; Sets ringsize to n (mixin + 1). +- _unlock_time_ - unsigned int; Number of blocks before the monero can be spent (0 to not add a lock). +- _payment_id_ - string; (Optional) Random 32-byte/64-character hex string to identify a transaction. +- _get_tx_keys_ - boolean; (Optional) Return the transaction keys after sending. +- _priority_ - unsigned int; Set a priority for the transactions. Accepted Values are: 0-3 for: default, unimportant, normal, elevated, priority. +- _do_not_relay_ - boolean; (Optional) If true, the newly created transaction will not be relayed to the monero network. (Defaults to false) +- _get_tx_hex_ - boolean; Return the transactions as hex string after sending +- _new_algorithm_ - boolean; True to use the new transaction construction algorithm, defaults to false. +- _get_tx_metadata_ - boolean; Return list of transaction metadata needed to relay the transfer later. + +Outputs: + +- _tx_hash_list_ - array of: string. The tx hashes of every transaction. +- _tx_key_list_ - array of: string. The transaction keys for every transaction. +- _amount_list_ - array of: integer. The amount transferred for every transaction. +- _fee_list_ - array of: integer. The amount of fees paid for every transaction. +- _tx_blob_list_ - array of: string. The tx as hex string for every transaction. +- _tx_metadata_list_ - array of: string. List of transaction metadata needed to relay the transactions later. +- _multisig_txset_ - string. The set of signing keys used in a multisig transaction (empty for non-multisig). +- _unsigned_txset_ - string. Set of unsigned tx for cold-signing purposes. + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"transfer_split","params":{"destinations":[{"amount":1000000000000,"address":"7BnERTpvL5MbCLtj5n9No7J5oE5hHiB3tVCK5cjSvCsYWD2WRJLFuWeKTLiXo5QJqt2ZwUaLy2Vh1Ad51K7FNgqcHgjW85o"},{"amount":2000000000000,"address":"75sNpRwUtekcJGejMuLSGA71QFuK1qcCVLZnYRTfQLgFU5nJ7xiAHtR5ihioS53KMe8pBhH61moraZHyLoG4G7fMER8xkNv"}],"account_index":0,"subaddr_indices":[0],"priority":0,"ring_size":7,"get_tx_key": true}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "amount_list": [3000000000000], + "fee_list": [85106400000], + "multisig_txset": "", + "tx_hash_list": ["c8d815f48f27d53fdaf198a74b292a91bfaf87529a9a9a9ee66079a890b3b58b"], + "unsigned_txset": "" + } +} + +``` +--- + +### **untag_accounts** + +Remove filtering tag from a list of accounts. + +Alias: _None_. + +Inputs: + +- _accounts_ - array of unsigned int; Remove tag from this list of accounts. + +Outputs: _None_. + +Example: + +``` +$ curl -X POST http://localhost:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"untag_accounts","params":{"accounts":[1]}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + } +} + +``` +--- + +### **verify** + +Verify a signature on a string. + +Alias: _None_. + +Inputs: + +- _data_ - string; What should have been signed. +- _address_ - string; Public address of the wallet used to `sign` the data. +- _signature_ - string; signature generated by `sign` method. + +Outputs: + +- _good_ - boolean; + +Example: + +``` +$ curl -X POST http://127.0.0.1:18082/json_rpc -d '{"jsonrpc":"2.0","id":"0","method":"verify","params":{"data":"This is sample data to be signed","address":"55LTR8KniP4LQGJSPtbYDacR7dz8RBFnsfAKMaMuwUNYX6aQbBcovzDPyrQF9KXF9tVU6Xk3K8no1BywnJX6GvZX8yJsXvt","signature":"SigV14K6G151gycjiGxjQ74tKX6A2LwwghvuHjcDeuRFQio5LS6Gb27BNxjYQY1dPuUvXkEbGQUkiHSVLPj4nJAHRrrw3"}}' -H 'Content-Type: application/json' +{ + "id": "0", + "jsonrpc": "2.0", + "result": { + "good": true + } +} + ``` ## Sources: