// Copyright (c) 2012-2015, The CryptoNote developers, The Bytecoin developers
//
// This file is part of Bytecoin.
//
// Bytecoin is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// Bytecoin is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with Bytecoin. If not, see .
#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,
SpentOutputs& spentOutputs,
UnlockTransactionJobs& unlockTransactions,
TransactionChanges& change,
WalletTransactions& transactions,
WalletTransfers& transfers,
uint32_t transactionSoftLockTime
);
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;
void loadCurrentVersion(Common::IInputStream& source, const std::string& password);
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 saveSpentOutputs(Common::IOutputStream& destination, CryptoContext& cryptoContext);
void saveUnlockTransactionsJobs(Common::IOutputStream& destination, CryptoContext& cryptoContext);
void saveChange(Common::IOutputStream& destination, CryptoContext& cryptoContext);
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);
void loadSpentOutputs(Common::IInputStream& source, CryptoContext& cryptoContext);
void loadUnlockTransactionsJobs(Common::IInputStream& source, CryptoContext& cryptoContext);
void loadChange(Common::IInputStream& source, CryptoContext& cryptoContext);
void loadTransactions(Common::IInputStream& source, CryptoContext& cryptoContext);
void loadTransfers(Common::IInputStream& source, CryptoContext& cryptoContext);
void loadWalletV1Keys(CryptoNote::BinaryInputStreamSerializer& serializer);
void loadWalletV1Details(CryptoNote::BinaryInputStreamSerializer& serializer);
void addWalletV1Details(const std::vector& txs, const std::vector& trs);
void updateTransactionsBaseStatus();
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;
SpentOutputs& m_spentOutputs;
UnlockTransactionJobs& m_unlockTransactions;
TransactionChanges& m_change;
WalletTransactions& m_transactions;
WalletTransfers& m_transfers;
uint32_t m_transactionSoftLockTime;
};
} //namespace CryptoNote