NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.5: NDN, CCN, CCNx, content centric networks
API Documentation
safe-bag.hpp
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2013-2017 Regents of the University of California.
4
*
5
* This file is part of ndn-cxx library (NDN C++ library with eXperimental eXtensions).
6
*
7
* ndn-cxx library is free software: you can redistribute it and/or modify it under the
8
* terms of the GNU Lesser General Public License as published by the Free Software
9
* Foundation, either version 3 of the License, or (at your option) any later version.
10
*
11
* ndn-cxx library is distributed in the hope that it will be useful, but WITHOUT ANY
12
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
13
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
14
*
15
* You should have received copies of the GNU General Public License and GNU Lesser
16
* General Public License along with ndn-cxx, e.g., in COPYING.md file. If not, see
17
* <http://www.gnu.org/licenses/>.
18
*
19
* See AUTHORS.md for complete list of ndn-cxx authors and contributors.
20
*
21
* @author Zhiyi Zhang <dreamerbarrychang@gmail.com>
22
*/
23
#ifndef NDN_CXX_SECURITY_SAFE_BAG_HPP
24
#define NDN_CXX_SECURITY_SAFE_BAG_HPP
25
26
#include "../common.hpp"
27
#include "../data.hpp"
28
#include "../encoding/block.hpp"
29
#include "../encoding/buffer.hpp"
30
#include "
security-common.hpp
"
31
32
namespace
ndn
{
33
namespace
security {
34
37
class
SafeBag
38
{
39
public
:
43
SafeBag
();
44
48
explicit
49
SafeBag
(
const
Block
& wire);
50
57
SafeBag
(
const
Data
& certificate,
58
const
Buffer
& encryptedKeyBag);
59
67
SafeBag
(
const
Data
& certificate,
68
const
uint8_t* encryptedKey,
69
size_t
encryptedKeyLen);
70
71
public
:
75
template
<encoding::Tag TAG>
76
size_t
77
wireEncode
(
EncodingImpl<TAG>
& encoder)
const
;
78
82
const
Block
&
83
wireEncode
()
const
;
84
88
void
89
wireDecode
(
const
Block
& wire);
90
91
public
:
95
const
Data
&
96
getCertificate
()
const
97
{
98
return
m_certificate;
99
}
100
104
const
Buffer
&
105
getEncryptedKeyBag
()
const
106
{
107
return
m_encryptedKeyBag;
108
}
109
110
private
:
111
Data
m_certificate;
112
Buffer
m_encryptedKeyBag;
113
114
mutable
Block
m_wire;
115
};
116
117
NDN_CXX_DECLARE_WIRE_ENCODE_INSTANTIATIONS
(
SafeBag
);
118
119
}
// namespace security
120
}
// namespace ndn
121
122
#endif // NDN_CXX_SECURITY_SAFE_BAG_HPP
ndn
Copyright (c) 2011-2015 Regents of the University of California.
Definition:
ndn-strategy-choice-helper.hpp:34
ndn::security::NDN_CXX_DECLARE_WIRE_ENCODE_INSTANTIATIONS
NDN_CXX_DECLARE_WIRE_ENCODE_INSTANTIATIONS(SafeBag)
ndn::security::SafeBag::SafeBag
SafeBag()
Create a new empty SafeBag object.
ndn::Block
Represents a TLV element of NDN packet format.
Definition:
block.hpp:42
ndn::security::SafeBag::getEncryptedKeyBag
const Buffer & getEncryptedKeyBag() const
Get the private key in PKCS#8 from safe bag.
Definition:
safe-bag.hpp:105
ndn::security::SafeBag::getCertificate
const Data & getCertificate() const
Get the certificate data packet from safe bag.
Definition:
safe-bag.hpp:96
ndn::security::SafeBag::wireDecode
void wireDecode(const Block &wire)
Decode the input from wire format.
Definition:
safe-bag.cpp:95
ndn::encoding::EncodingImpl
Definition:
encoding-buffer-fwd.hpp:36
ndn::security::SafeBag
a secured container for sensitive information(certificate, private key)
Definition:
safe-bag.hpp:37
ndn::tlv::security::SafeBag
Definition:
tlv-security.hpp:32
ndn::security::SafeBag::wireEncode
const Block & wireEncode() const
Encode to a wire format.
Definition:
safe-bag.cpp:82
ndn::Data
Represents a Data packet.
Definition:
data.hpp:35
ndn::Buffer
General-purpose automatically managed/resized buffer.
Definition:
buffer.hpp:40
security-common.hpp
ndnSIM
ndn-cxx
src
security
safe-bag.hpp
Generated on Tue Aug 7 2018 16:19:16 for ndnSIM by
1.8.14