IBR-DTNSuite
0.10
Main Page
Namespaces
Classes
Files
File List
File Members
IBR-DTNSuite
Namespaces
Classes
Files
File List
daemon
src
api
core
net
routing
security
SecurityCertificateManager.cpp
SecurityCertificateManager.h
SecurityKeyManager.cpp
SecurityKeyManager.h
SecurityManager.cpp
SecurityManager.h
storage
CapsuleWorker.cpp
CapsuleWorker.h
Component.cpp
Component.h
config.h
Configuration.cpp
Configuration.h
Debugger.cpp
Debugger.h
DevNull.cpp
DevNull.h
DTNTPWorker.cpp
DTNTPWorker.h
EchoWorker.cpp
EchoWorker.h
Main.cpp
NativeDaemon.cpp
NativeDaemon.h
ibrcommon
ibrdtn
tools
File Members
SecurityCertificateManager.h
Go to the documentation of this file.
1
/*
2
* SecurityCertificateManager.h
3
*
4
* Copyright (C) 2011 IBR, TU Braunschweig
5
*
6
* Written-by: Stephen Roettger <roettger@ibr.cs.tu-bs.de>
7
*
8
* Licensed under the Apache License, Version 2.0 (the "License");
9
* you may not use this file except in compliance with the License.
10
* You may obtain a copy of the License at
11
*
12
* http://www.apache.org/licenses/LICENSE-2.0
13
*
14
* Unless required by applicable law or agreed to in writing, software
15
* distributed under the License is distributed on an "AS IS" BASIS,
16
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17
* See the License for the specific language governing permissions and
18
* limitations under the License.
19
*
20
*/
21
22
#ifndef SECURITYCERTIFICATEMANAGER_H_
23
#define SECURITYCERTIFICATEMANAGER_H_
24
25
#include "
Configuration.h
"
26
#include "
core/Event.h
"
27
#include "
Component.h
"
28
29
#include <
ibrcommon/data/File.h
>
30
#include <
ibrcommon/thread/Mutex.h
>
31
32
#include <
ibrdtn/data/EID.h
>
33
34
#include <openssl/ssl.h>
35
#include <string>
36
37
namespace
dtn
38
{
39
namespace
security
40
{
41
class
SecurityCertificateException
:
public
ibrcommon::Exception
42
{
43
public
:
44
SecurityCertificateException
(std::string
what
=
"verification failed"
) : ibrcommon::
Exception
(
what
)
45
{};
46
47
virtual
~SecurityCertificateException
() throw() {};
48
};
49
53
class
SecurityCertificateManager
:
public
dtn::daemon::Component
,
public
dtn::daemon::Configuration::OnChangeListener
{
54
public
:
55
static
const
std::string
TAG
;
56
57
SecurityCertificateManager
();
58
virtual
~SecurityCertificateManager
();
59
63
virtual
void
onConfigurationChanged
(
const
dtn::daemon::Configuration
&conf)
throw
();
64
71
static
void
validateSubject
(X509 *certificate,
const
std::string &cn)
throw
(
SecurityCertificateException
);
72
77
bool
isInitialized
();
78
84
const
X509 *
getCert
()
const
;
90
const
EVP_PKEY *
getPrivateKey
()
const
;
95
const
ibrcommon::File
&
getTrustedCAPath
()
const
;
96
97
/* functions from Component */
98
virtual
void
initialize
() throw ();
99
virtual
void
startup
() throw ();
100
virtual
void
terminate
() throw ();
101
virtual const std::
string
getName
() const;
102
103
private:
104
ibrcommon::Mutex _initialization_lock;
105
bool
_initialized;
106
107
X509 *_cert;
108
EVP_PKEY *_privateKey;
109
ibrcommon::File _trustedCAPath;
110
};
111
}
112
}
113
114
#endif
/* SECURITYCERTIFICATEMANAGER_H_ */
daemon
src
security
SecurityCertificateManager.h
Generated on Mon Jul 22 2013 15:16:00 for IBR-DTNSuite by
1.8.3.1