2020-06-13 19:00:39 +00:00
|
|
|
/*
|
|
|
|
Copyright (c) 2020 tevador <tevador@gmail.com>
|
|
|
|
All rights reserved.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#include <string>
|
|
|
|
#include <array>
|
|
|
|
#include <cstdint>
|
|
|
|
#include <iostream>
|
|
|
|
#include <ctime>
|
|
|
|
#include "gf_poly.hpp"
|
|
|
|
|
|
|
|
class monero_seed {
|
|
|
|
public:
|
|
|
|
static const std::string erasure;
|
|
|
|
static constexpr size_t size = 16;
|
|
|
|
static constexpr size_t key_size = 32;
|
|
|
|
using secret_key = std::array<uint8_t, key_size>;
|
|
|
|
using secret_seed = std::array<uint8_t, size>;
|
2020-06-15 20:26:29 +00:00
|
|
|
monero_seed(const std::string& phrase, const std::string& coin);
|
|
|
|
monero_seed(std::time_t date_created, const std::string& coin, const std::string& net);
|
2020-06-13 19:00:39 +00:00
|
|
|
std::time_t date() const {
|
|
|
|
return date_;
|
|
|
|
}
|
|
|
|
const std::string& correction() const {
|
|
|
|
return correction_;
|
|
|
|
}
|
2020-06-15 20:26:29 +00:00
|
|
|
const char* net_name() const {
|
|
|
|
return net_name_;
|
|
|
|
}
|
2020-06-13 19:00:39 +00:00
|
|
|
const secret_key& key() const {
|
|
|
|
return key_;
|
|
|
|
}
|
|
|
|
friend std::ostream& operator<<(std::ostream& os, const monero_seed& seed);
|
|
|
|
private:
|
|
|
|
secret_seed seed_;
|
|
|
|
secret_key key_;
|
|
|
|
std::time_t date_;
|
2020-06-15 20:26:29 +00:00
|
|
|
unsigned net_type_;
|
2020-06-13 19:00:39 +00:00
|
|
|
unsigned reserved_;
|
|
|
|
std::string correction_;
|
|
|
|
gf_poly message_;
|
2020-06-15 20:26:29 +00:00
|
|
|
const char* net_name_;
|
2020-06-13 19:00:39 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
std::ostream& operator<<(std::ostream& os, const monero_seed::secret_key& key);
|