// Copyright (c) 2011-2016 The Cryptonote developers // Distributed under the MIT/X11 software license, see the accompanying // file COPYING or http://www.opensource.org/licenses/mit-license.php. #pragma once #include "CryptoNoteFormatUtils.h" #include "TransactionExtra.h" namespace CryptoNote { class TransactionExtra { public: TransactionExtra() {} TransactionExtra(const std::vector& extra) { parse(extra); } bool parse(const std::vector& extra) { fields.clear(); return CryptoNote::parseTransactionExtra(extra, fields); } template bool get(T& value) const { auto it = find(typeid(T)); if (it == fields.end()) { return false; } value = boost::get(*it); return true; } template void set(const T& value) { auto it = find(typeid(T)); if (it != fields.end()) { *it = value; } else { fields.push_back(value); } } template void append(const T& value) { fields.push_back(value); } bool getPublicKey(Crypto::PublicKey& pk) const { CryptoNote::TransactionExtraPublicKey extraPk; if (!get(extraPk)) { return false; } pk = extraPk.publicKey; return true; } std::vector serialize() const { std::vector extra; writeTransactionExtra(extra, fields); return extra; } private: std::vector::const_iterator find(const std::type_info& t) const { return std::find_if(fields.begin(), fields.end(), [&t](const CryptoNote::TransactionExtraField& f) { return t == f.type(); }); } std::vector::iterator find(const std::type_info& t) { return std::find_if(fields.begin(), fields.end(), [&t](const CryptoNote::TransactionExtraField& f) { return t == f.type(); }); } std::vector fields; }; }