2016-01-18 15:33:29 +00:00
|
|
|
// Copyright (c) 2011-2016 The Cryptonote developers
|
2015-09-18 11:55:31 +00:00
|
|
|
// Distributed under the MIT/X11 software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
2015-07-30 15:22:07 +00:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "IWallet.h"
|
|
|
|
#include "WalletIndices.h"
|
|
|
|
#include "Common/IInputStream.h"
|
|
|
|
#include "Common/IOutputStream.h"
|
|
|
|
#include "Transfers/TransfersSynchronizer.h"
|
|
|
|
#include "Serialization/BinaryInputStreamSerializer.h"
|
|
|
|
|
|
|
|
#include "crypto/chacha8.h"
|
|
|
|
|
|
|
|
namespace CryptoNote {
|
|
|
|
|
|
|
|
struct CryptoContext {
|
|
|
|
Crypto::chacha8_key key;
|
|
|
|
Crypto::chacha8_iv iv;
|
|
|
|
|
|
|
|
void incIv();
|
|
|
|
};
|
|
|
|
|
|
|
|
class WalletSerializer {
|
|
|
|
public:
|
|
|
|
WalletSerializer(
|
|
|
|
ITransfersObserver& transfersObserver,
|
|
|
|
Crypto::PublicKey& viewPublicKey,
|
|
|
|
Crypto::SecretKey& viewSecretKey,
|
|
|
|
uint64_t& actualBalance,
|
|
|
|
uint64_t& pendingBalance,
|
|
|
|
WalletsContainer& walletsContainer,
|
|
|
|
TransfersSyncronizer& synchronizer,
|
|
|
|
UnlockTransactionJobs& unlockTransactions,
|
|
|
|
WalletTransactions& transactions,
|
2015-08-27 18:55:14 +00:00
|
|
|
WalletTransfers& transfers,
|
2015-12-09 13:19:03 +00:00
|
|
|
uint32_t transactionSoftLockTime,
|
|
|
|
UncommitedTransactions& uncommitedTransactions
|
2015-07-30 15:22:07 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
void save(const std::string& password, Common::IOutputStream& destination, bool saveDetails, bool saveCache);
|
|
|
|
void load(const std::string& password, Common::IInputStream& source);
|
|
|
|
|
|
|
|
private:
|
|
|
|
static const uint32_t SERIALIZATION_VERSION;
|
|
|
|
|
2015-10-01 15:27:18 +00:00
|
|
|
void loadWallet(Common::IInputStream& source, const std::string& password, uint32_t version);
|
2015-07-30 15:22:07 +00:00
|
|
|
void loadWalletV1(Common::IInputStream& source, const std::string& password);
|
|
|
|
|
|
|
|
CryptoContext generateCryptoContext(const std::string& password);
|
|
|
|
|
|
|
|
void saveVersion(Common::IOutputStream& destination);
|
|
|
|
void saveIv(Common::IOutputStream& destination, Crypto::chacha8_iv& iv);
|
|
|
|
void saveKeys(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
void savePublicKey(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
void saveSecretKey(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
void saveFlags(bool saveDetails, bool saveCache, Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
void saveWallets(Common::IOutputStream& destination, bool saveCache, CryptoContext& cryptoContext);
|
|
|
|
void saveBalances(Common::IOutputStream& destination, bool saveCache, CryptoContext& cryptoContext);
|
|
|
|
void saveTransfersSynchronizer(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
void saveUnlockTransactionsJobs(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
2015-12-09 13:19:03 +00:00
|
|
|
void saveUncommitedTransactions(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
2015-07-30 15:22:07 +00:00
|
|
|
void saveTransactions(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
void saveTransfers(Common::IOutputStream& destination, CryptoContext& cryptoContext);
|
|
|
|
|
|
|
|
uint32_t loadVersion(Common::IInputStream& source);
|
|
|
|
void loadIv(Common::IInputStream& source, Crypto::chacha8_iv& iv);
|
|
|
|
void generateKey(const std::string& password, Crypto::chacha8_key& key);
|
|
|
|
void loadKeys(Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void loadPublicKey(Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void loadSecretKey(Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void checkKeys();
|
|
|
|
void loadFlags(bool& details, bool& cache, Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void loadWallets(Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void subscribeWallets();
|
|
|
|
void loadBalances(Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void loadTransfersSynchronizer(Common::IInputStream& source, CryptoContext& cryptoContext);
|
2015-12-09 13:19:03 +00:00
|
|
|
void loadObsoleteSpentOutputs(Common::IInputStream& source, CryptoContext& cryptoContext);
|
2015-07-30 15:22:07 +00:00
|
|
|
void loadUnlockTransactionsJobs(Common::IInputStream& source, CryptoContext& cryptoContext);
|
2015-12-09 13:19:03 +00:00
|
|
|
void loadObsoleteChange(Common::IInputStream& source, CryptoContext& cryptoContext);
|
|
|
|
void loadUncommitedTransactions(Common::IInputStream& source, CryptoContext& cryptoContext);
|
2015-07-30 15:22:07 +00:00
|
|
|
void loadTransactions(Common::IInputStream& source, CryptoContext& cryptoContext);
|
2015-10-01 15:27:18 +00:00
|
|
|
void loadTransfers(Common::IInputStream& source, CryptoContext& cryptoContext, uint32_t version);
|
2015-07-30 15:22:07 +00:00
|
|
|
|
|
|
|
void loadWalletV1Keys(CryptoNote::BinaryInputStreamSerializer& serializer);
|
|
|
|
void loadWalletV1Details(CryptoNote::BinaryInputStreamSerializer& serializer);
|
|
|
|
void addWalletV1Details(const std::vector<WalletLegacyTransaction>& txs, const std::vector<WalletLegacyTransfer>& trs);
|
2015-12-09 13:19:03 +00:00
|
|
|
void initTransactionPool();
|
|
|
|
void resetCachedBalance();
|
2015-08-27 18:55:14 +00:00
|
|
|
void updateTransactionsBaseStatus();
|
2015-12-09 13:19:03 +00:00
|
|
|
void updateTransfersSign();
|
2015-07-30 15:22:07 +00:00
|
|
|
|
|
|
|
ITransfersObserver& m_transfersObserver;
|
|
|
|
Crypto::PublicKey& m_viewPublicKey;
|
|
|
|
Crypto::SecretKey& m_viewSecretKey;
|
|
|
|
uint64_t& m_actualBalance;
|
|
|
|
uint64_t& m_pendingBalance;
|
|
|
|
WalletsContainer& m_walletsContainer;
|
|
|
|
TransfersSyncronizer& m_synchronizer;
|
|
|
|
UnlockTransactionJobs& m_unlockTransactions;
|
|
|
|
WalletTransactions& m_transactions;
|
|
|
|
WalletTransfers& m_transfers;
|
2015-08-27 18:55:14 +00:00
|
|
|
uint32_t m_transactionSoftLockTime;
|
2015-12-09 13:19:03 +00:00
|
|
|
UncommitedTransactions& uncommitedTransactions;
|
2015-07-30 15:22:07 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
} //namespace CryptoNote
|