-
Notifications
You must be signed in to change notification settings - Fork 40
Expand file tree
/
Copy pathsodium.cpp
More file actions
98 lines (81 loc) · 2.27 KB
/
sodium.cpp
File metadata and controls
98 lines (81 loc) · 2.27 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
/**
* Copyright (c) 2011-2026 libbitcoin developers (see AUTHORS)
*
* This file is part of libbitcoin.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include <bitcoin/protocol/config/sodium.hpp>
#include <algorithm>
#include <sstream>
#include <bitcoin/system.hpp>
#include <bitcoin/protocol/define.hpp>
namespace libbitcoin {
namespace protocol {
using namespace bc::system;
sodium::sodium() NOEXCEPT
: value_(null_hash)
{
}
sodium::sodium(const std::string& base85) THROWS
: sodium()
{
std::stringstream(base85) >> *this;
}
sodium::sodium(const hash_digest& value) NOEXCEPT
: value_(value)
{
}
sodium::operator const hash_digest&() const NOEXCEPT
{
return value_;
}
sodium::operator bool() const NOEXCEPT
{
return value_ != null_hash;
}
std::string sodium::to_string() const NOEXCEPT
{
std::stringstream value;
BC_PUSH_WARNING(NO_THROW_IN_NOEXCEPT)
value << *this;
return value.str();
BC_POP_WARNING()
}
std::istream& operator>>(std::istream& input, sodium& argument) THROWS
{
std::string base85;
input >> base85;
data_chunk out_value;
if (!decode_base85(out_value, base85) || out_value.size() != hash_size)
{
throw istream_exception(base85);
}
std::copy_n(out_value.begin(), hash_size, argument.value_.begin());
return input;
}
std::ostream& operator<<(std::ostream& output,
const sodium& argument) THROWS
{
std::string decoded;
// Base85 requires four byte alignment (hash_digest is 32).
if (!encode_base85(decoded, argument.value_))
{
throw istream_exception(decoded);
}
output << decoded;
return output;
}
} // namespace protocol
} // namespace libbitcoin