ledger-core
DeterministicPublicKey.hpp
1 /*
2  *
3  * DeterministicPublicKey
4  * ledger-core
5  *
6  * Created by Pierre Pollastri on 14/12/2016.
7  *
8  * The MIT License (MIT)
9  *
10  * Copyright (c) 2016 Ledger
11  *
12  * Permission is hereby granted, free of charge, to any person obtaining a copy
13  * of this software and associated documentation files (the "Software"), to deal
14  * in the Software without restriction, including without limitation the rights
15  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
16  * copies of the Software, and to permit persons to whom the Software is
17  * furnished to do so, subject to the following conditions:
18  *
19  * The above copyright notice and this permission notice shall be included in all
20  * copies or substantial portions of the Software.
21  *
22  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
23  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
25  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
26  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
27  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
28  * SOFTWARE.
29  *
30  */
31 #ifndef LEDGER_CORE_DETERMINISTICPUBLICKEY_HPP
32 #define LEDGER_CORE_DETERMINISTICPUBLICKEY_HPP
33 
34 #include <vector>
35 
36 namespace ledger {
37  namespace core {
39  public:
40  DeterministicPublicKey( const std::vector<uint8_t>& publicKey,
41  const std::vector<uint8_t>& chainCode,
42  uint32_t childNum,
43  uint32_t depth,
44  uint32_t parentFingerprint,
45  const std::string &networkIdentifier
46  );
48  uint32_t getFingerprint() const;
49  DeterministicPublicKey derive(uint32_t childIndex) const;
50 
51  const std::vector<uint8_t>& getPublicKey() const;
52  std::vector<uint8_t> getUncompressedPublicKey() const;
53  std::vector<uint8_t> getPublicKeyHash160() const;
54  std::vector<uint8_t> getPublicKeyKeccak256() const;
55  std::vector<uint8_t> getPublicKeyBlake2b(bool isED25519 = false) const;
56  std::vector<uint8_t> toByteArray(const std::vector<uint8_t>& version = {}) const;
57  public:
58 
59 
60  private:
61  const std::vector<uint8_t> _key;
62  const std::vector<uint8_t> _chainCode;
63  const uint32_t _childNum;
64  const uint32_t _depth;
65  const uint32_t _parentFingerprint;
66  const std::string _networkIdentifier;
67  };
68  }
69 }
70 
71 
72 #endif //LEDGER_CORE_DETERMINISTICPUBLICKEY_HPP
Definition: DeterministicPublicKey.hpp:38
Definition: Account.cpp:8