blob: ccf73c5aa9a35f151104c6bed79cac5c5679e110 [file] [log] [blame]
peizhen guo410e0e12014-08-12 13:24:14 -07001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
3 * Copyright (c) 2014, Regents of the University of California
4 *
5 * This file is part of NSL (NDN Signature Logger).
6 * See AUTHORS.md for complete list of NSL authors and contributors.
7 *
8 * NSL is free software: you can redistribute it and/or modify it under the terms
9 * of the GNU General Public License as published by the Free Software Foundation,
10 * either version 3 of the License, or (at your option) any later version.
11 *
12 * NSL is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
13 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 * PURPOSE. See the GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License along with
17 * NSL, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
18 *
19 * @author Peizhen Guo <patrick.guopz@gmail.com>
20 */
21#ifndef NLS_CORE_MERKLE_TREE_HPP
22#define NLS_CORE_MERKLE_TREE_HPP
23
24#include <map>
25#include <vector>
26
27#include <stddef.h>
28#include <stdint.h>
29#include <time.h>
30
31#include "leaf.hpp"
32#include "intermediate-node.hpp"
33#include "merkle-tree-cache.hpp"
34
35namespace nsl {
36
37class MerkleTree
38{
39public:
40 MerkleTree();
41
42 ~MerkleTree()
43 {
44 }
45
46 ConstNodePtr
47 getNode(const Index& index);
48
49 uint64_t
50 getLeafNum() const;
51
52 uint64_t
53 getLevel() const;
54
55
56 //return root hash value
57 uint64_t
58 addLeaf(ndn::ConstBufferPtr info);
59
60
61 std::vector<ConstNodePtr>
62 generateProof(uint64_t version1, uint64_t version2); // version equals to leaf's index number
63
64
65private:
66 MerkleTreeCache m_cache;
67 uint64_t m_nLevels;
68 uint64_t m_nLeaves;
69
70};
71
72
73} // namespace nsl
74
75#endif // NLS_CORE_MERKLE_TREE_HPP