aboutsummaryrefslogtreecommitdiff
path: root/src/wallet/wallet_rpc_server.cpp
diff options
context:
space:
mode:
authormonero-project <sempre.amaro@gmail.com>2014-06-02 10:53:52 -0400
committermonero-project <sempre.amaro@gmail.com>2014-06-02 10:53:52 -0400
commit24b4f47413bf9e1874ff01866b7dc50cd41c415a (patch)
tree37e90eb393071d3ca4fabe72513501c7066b3e54 /src/wallet/wallet_rpc_server.cpp
parentMerge pull request #20 from artifexd/wallet_refresh (diff)
parentAdded 'payment_id' optional argument to 'transfer' wallet RPC method (diff)
downloadmonero-24b4f47413bf9e1874ff01866b7dc50cd41c415a.tar.xz
Merge pull request #21 from Neozaru/master
Added 'payment_id' optional argument to 'transfer' wallet RPC method
Diffstat (limited to 'src/wallet/wallet_rpc_server.cpp')
-rw-r--r--src/wallet/wallet_rpc_server.cpp29
1 files changed, 28 insertions, 1 deletions
diff --git a/src/wallet/wallet_rpc_server.cpp b/src/wallet/wallet_rpc_server.cpp
index 55f81aacc..af195cfcc 100644
--- a/src/wallet/wallet_rpc_server.cpp
+++ b/src/wallet/wallet_rpc_server.cpp
@@ -102,10 +102,37 @@ namespace tools
de.amount = it->amount;
dsts.push_back(de);
}
+
+ std::vector<uint8_t> extra;
+ if (!req.payment_id.empty()) {
+
+ /* Just to clarify */
+ const std::string& payment_id_str = req.payment_id;
+
+ crypto::hash payment_id;
+ /* Parse payment ID */
+ if (!wallet2::parse_payment_id(payment_id_str, payment_id)) {
+ er.code = WALLET_RPC_ERROR_CODE_WRONG_PAYMENT_ID;
+ er.message = "Payment id has invalid format: \"" + payment_id_str + "\", expected 64-character string";
+ return false;
+ }
+
+ std::string extra_nonce;
+ cryptonote::set_payment_id_to_tx_extra_nonce(extra_nonce, payment_id);
+
+ /* Append Payment ID data into extra */
+ if (!cryptonote::add_extra_nonce_to_tx_extra(extra, extra_nonce)) {
+ er.code = WALLET_RPC_ERROR_CODE_WRONG_PAYMENT_ID;
+ er.message = "Something went wront with payment_id. Please check its format: \"" + payment_id_str + "\", expected 64-character string";
+ return false;
+ }
+
+ }
+
try
{
cryptonote::transaction tx;
- m_wallet.transfer(dsts, req.mixin, req.unlock_time, req.fee, std::vector<uint8_t>(), tx);
+ m_wallet.transfer(dsts, req.mixin, req.unlock_time, req.fee, extra, tx);
res.tx_hash = boost::lexical_cast<std::string>(cryptonote::get_transaction_hash(tx));
return true;
}