blocxx
src
blocxx
Secure.hpp
Go to the documentation of this file.
1
/*******************************************************************************
2
* Copyright (C) 2005, Quest Software, Inc. All rights reserved.
3
* Copyright (C) 2006, Novell, Inc. All rights reserved.
4
*
5
* Redistribution and use in source and binary forms, with or without
6
* modification, are permitted provided that the following conditions are met:
7
*
8
* * Redistributions of source code must retain the above copyright notice,
9
* this list of conditions and the following disclaimer.
10
* * Redistributions in binary form must reproduce the above copyright
11
* notice, this list of conditions and the following disclaimer in the
12
* documentation and/or other materials provided with the distribution.
13
* * Neither the name of
14
* Quest Software, Inc.,
15
* nor Novell, Inc.,
16
* nor the names of its contributors or employees may be used to
17
* endorse or promote products derived from this software without
18
* specific prior written permission.
19
*
20
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
24
* LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
25
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
26
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27
* INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28
* CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
29
* ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
30
* POSSIBILITY OF SUCH DAMAGE.
31
*******************************************************************************/
32
33
34
#ifndef BLOCXX_SECURE_HPP_INCLUDE_GUARD_
35
#define BLOCXX_SECURE_HPP_INCLUDE_GUARD_
36
38
39
#include "blocxx/BLOCXX_config.h"
40
#include "
blocxx/Exception.hpp
"
41
#include "
blocxx/CommonFwd.hpp
"
42
#include "
blocxx/Types.hpp
"
43
44
namespace
BLOCXX_NAMESPACE
45
{
46
namespace
Secure
47
{
48
enum
EChildGroupAction
49
{
50
E_NO_EXTENDED_GROUPS
= 0,
51
E_SOURCE_EXTENDED_GROUPS
52
};
53
59
BLOCXX_DECLARE_EXCEPTION
(
ProcessAbort
);
60
71
BLOCXX_COMMON_API
void
dropPrivilegesPermanently
(
uid_t
newuid
,
gid_t
newgid
,
EChildGroupAction
extendedGroupAction
);
72
82
BLOCXX_COMMON_API
void
runAs
(
char
const
*
username
,
EChildGroupAction
extendedGroupAction
=
E_SOURCE_EXTENDED_GROUPS
);
83
87
BLOCXX_COMMON_API
StringArray
minimalEnvironment
();
88
89
}
// namespace Secure
90
}
// namespace BLOCXX_NAMESPACE
91
92
#endif
93
CommonFwd.hpp
Exception.hpp
BLOCXX_DECLARE_EXCEPTION
#define BLOCXX_DECLARE_EXCEPTION(NAME)
Declare a new exception class named <NAME>Exception that derives from Exception This macro is typical...
Definition
Exception.hpp:386
Types.hpp
BLOCXX_NAMESPACE::Array< String >
BLOCXX_NAMESPACE::Secure::minimalEnvironment
StringArray minimalEnvironment()
Definition
Secure.cpp:360
BLOCXX_NAMESPACE::Secure::EChildGroupAction
EChildGroupAction
Definition
Secure.hpp:49
BLOCXX_NAMESPACE::Secure::E_SOURCE_EXTENDED_GROUPS
@ E_SOURCE_EXTENDED_GROUPS
Definition
Secure.hpp:51
BLOCXX_NAMESPACE::Secure::E_NO_EXTENDED_GROUPS
@ E_NO_EXTENDED_GROUPS
Definition
Secure.hpp:50
BLOCXX_NAMESPACE::Secure::dropPrivilegesPermanently
void dropPrivilegesPermanently(::uid_t newuid, ::gid_t newgid, EChildGroupAction extendedGroupAction)
Definition
Secure.cpp:137
BLOCXX_NAMESPACE::Secure::runAs
void runAs(char const *username, EChildGroupAction extendedGroupAction)
Look up user ID and group ID for username in password file, chdir to "/", then drop privileges and ru...
Definition
Secure.cpp:365
BLOCXX_NAMESPACE
Taken from RFC 1321.
Definition
AppenderLogger.cpp:48
BLOCXX_NAMESPACE::operator==
bool operator==(const Array< T > &x, const Array< T > &y)
Definition
ArrayImpl.hpp:434
Generated by
1.10.0