aboutsummaryrefslogtreecommitdiff
path: root/src/wallet/wallet2.h
diff options
context:
space:
mode:
authorRiccardo Spagni <ric@spagni.net>2016-12-12 22:39:38 +0200
committerRiccardo Spagni <ric@spagni.net>2016-12-12 22:39:38 +0200
commitaa7a926681fbb97b796e8fde5792eca3e67eacb0 (patch)
tree9a41eee577076adffb97e2c1b3dc3a2634d24779 /src/wallet/wallet2.h
parentMerge pull request #1433 (diff)
parentGUI address book (diff)
downloadmonero-aa7a926681fbb97b796e8fde5792eca3e67eacb0.tar.xz
Merge pull request #1434
5df92877 GUI address book (Jaquee)
Diffstat (limited to 'src/wallet/wallet2.h')
-rw-r--r--src/wallet/wallet2.h30
1 files changed, 29 insertions, 1 deletions
diff --git a/src/wallet/wallet2.h b/src/wallet/wallet2.h
index 616b74edb..fc06864e2 100644
--- a/src/wallet/wallet2.h
+++ b/src/wallet/wallet2.h
@@ -286,6 +286,14 @@ namespace tools
FIELD(cache_data)
END_SERIALIZE()
};
+
+ // GUI Address book
+ struct address_book_row
+ {
+ cryptonote::account_public_address m_address;
+ crypto::hash m_payment_id;
+ std::string m_description;
+ };
/*!
* \brief Generates a wallet or restores one.
@@ -471,6 +479,9 @@ namespace tools
return;
}
a & m_pub_keys;
+ if(ver < 16)
+ return;
+ a & m_address_book;
}
/*!
@@ -509,6 +520,13 @@ namespace tools
bool get_tx_key(const crypto::hash &txid, crypto::secret_key &tx_key) const;
+ /*!
+ * \brief GUI Address book get/store
+ */
+ std::map<int, address_book_row> get_address_book() const { return m_address_book; }
+ bool add_address_book_row(const cryptonote::account_public_address &address, const crypto::hash &payment_id, const std::string &description);
+ bool delete_address_book_row(int row_id);
+
uint64_t get_num_rct_outputs();
const transfer_details &get_transfer_details(size_t idx) const;
@@ -623,6 +641,7 @@ namespace tools
std::unordered_map<crypto::public_key, size_t> m_pub_keys;
cryptonote::account_public_address m_account_public_address;
std::unordered_map<crypto::hash, std::string> m_tx_notes;
+ std::map<int, tools::wallet2::address_book_row> m_address_book;
uint64_t m_upper_transaction_size_limit; //TODO: auto-calc this value or request from daemon, now use some fixed value
std::atomic<bool> m_run;
@@ -645,11 +664,12 @@ namespace tools
bool m_confirm_missing_payment_id;
};
}
-BOOST_CLASS_VERSION(tools::wallet2, 15)
+BOOST_CLASS_VERSION(tools::wallet2, 16)
BOOST_CLASS_VERSION(tools::wallet2::transfer_details, 7)
BOOST_CLASS_VERSION(tools::wallet2::payment_details, 1)
BOOST_CLASS_VERSION(tools::wallet2::unconfirmed_transfer_details, 6)
BOOST_CLASS_VERSION(tools::wallet2::confirmed_transfer_details, 3)
+BOOST_CLASS_VERSION(tools::wallet2::address_book_row, 16)
namespace boost
{
@@ -839,6 +859,14 @@ namespace boost
a & x.amount;
a & x.addr;
}
+
+ template <class Archive>
+ inline void serialize(Archive& a, tools::wallet2::address_book_row& x, const boost::serialization::version_type ver)
+ {
+ a & x.m_address;
+ a & x.m_payment_id;
+ a & x.m_description;
+ }
}
}