aboutsummaryrefslogtreecommitdiff
path: root/src/wallet/api/address_book.cpp
diff options
context:
space:
mode:
authormoneromooo-monero <moneromooo-monero@users.noreply.github.com>2017-01-01 16:06:34 +0000
committermoneromooo-monero <moneromooo-monero@users.noreply.github.com>2017-01-01 16:06:34 +0000
commit21c5af5a8a20a58cb913ac0a417ba3d508b2ef91 (patch)
tree9d6e7592aa2346f30547ba5ad938d37f3a7de65e /src/wallet/api/address_book.cpp
parentMerge pull request #1487 (diff)
downloadmonero-21c5af5a8a20a58cb913ac0a417ba3d508b2ef91.tar.xz
wallet2_api: add an address book payment id lookup API
Diffstat (limited to '')
-rw-r--r--src/wallet/api/address_book.cpp22
1 files changed, 22 insertions, 0 deletions
diff --git a/src/wallet/api/address_book.cpp b/src/wallet/api/address_book.cpp
index bbf96c81a..b878491ce 100644
--- a/src/wallet/api/address_book.cpp
+++ b/src/wallet/api/address_book.cpp
@@ -103,6 +103,28 @@ bool AddressBookImpl::deleteRow(std::size_t rowId)
return r;
}
+int AddressBookImpl::lookupPaymentID(const std::string &payment_id) const
+{
+ // turn short ones into long ones for comparison
+ const std::string long_payment_id = payment_id + std::string(64 - payment_id.size(), '0');
+
+ int idx = -1;
+ for (const auto &row: m_rows) {
+ ++idx;
+ // this does short/short and long/long
+ if (payment_id == row->getPaymentId())
+ return idx;
+ // short/long
+ if (long_payment_id == row->getPaymentId())
+ return idx;
+ // one case left: payment_id was long, row's is short
+ const std::string long_row_payment_id = row->getPaymentId() + std::string(64 - row->getPaymentId().size(), '0');
+ if (payment_id == long_row_payment_id)
+ return idx;
+ }
+ return -1;
+}
+
void AddressBookImpl::clearRows() {
for (auto r : m_rows) {
delete r;