wownero-seed/src/monero_seed.hpp

48 lines
1.1 KiB
C++
Raw Normal View History

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);