118 lines
5.3 KiB
C++
Executable file
118 lines
5.3 KiB
C++
Executable file
// 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 <http://www.gnu.org/licenses/>.
|
|
|
|
#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
|
|
);
|
|
|
|
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<WalletLegacyTransaction>& txs, const std::vector<WalletLegacyTransfer>& trs);
|
|
|
|
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;
|
|
};
|
|
|
|
} //namespace CryptoNote
|