iota.lib.cpp
IOTA C++ Library
curl.hpp
1 //
2 // MIT License
3 //
4 // Copyright (c) 2017-2018 Thibault Martinez and Simon Ninon
5 //
6 // Permission is hereby granted, free of charge, to any person obtaining a copy
7 // of this software and associated documentation files (the "Software"), to deal
8 // in the Software without restriction, including without limitation the rights
9 // to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
10 // copies of the Software, and to permit persons to whom the Software is
11 // furnished to do so, subject to the following conditions:
12 //
13 // The above copyright notice and this permission notice shall be included in all
14 // copies or substantial portions of the Software.
15 //
16 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
19 // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
21 // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
22 // SOFTWARE.
23 //
24 //
25 
26 #pragma once
27 
28 #include <algorithm>
29 
30 #include <iota/constants.hpp>
31 #include <iota/types/trits.hpp>
32 
33 namespace IOTA {
34 
35 namespace Crypto {
36 
42 class Curl {
43 public:
47  Curl();
51  ~Curl() = default;
52 
53 public:
57  void reset();
58 
66  void absorb(const Types::Trits& trits, std::size_t offset = 0, std::size_t length = 0);
67 
75  void squeeze(Types::Trits& trits, std::size_t offset = 0, std::size_t length = 0);
76 
77 private:
81  void transform();
82 
91  template <typename T>
92  static void arrayCopy(const typename std::vector<T>::const_iterator& input,
93  const typename std::vector<T>::iterator& output, std::size_t length) {
94  std::transform(input, input + length, output, [](T c) { return c; });
95  }
96 
97 private:
101  static const std::size_t StateLength = 3 * TritHashLength;
102 
106  static const std::size_t NumberOfRounds = 81;
107 
111  static int TruthTable[];
112 
113 private:
117  std::vector<int8_t> state_;
118 
122  std::vector<int8_t> scratchpad_;
123 };
124 
125 } // namespace Crypto
126 
127 } // namespace IOTA
Definition: curl.hpp:42
void squeeze(Types::Trits &trits, std::size_t offset=0, std::size_t length=0)
void absorb(const Types::Trits &trits, std::size_t offset=0, std::size_t length=0)
Definition: core.hpp:33