OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef REMOTING_HOST_WIN_SECURITY_DESCRIPTOR_H_ | 5 #ifndef REMOTING_HOST_WIN_SECURITY_DESCRIPTOR_H_ |
6 #define REMOTING_HOST_WIN_SECURITY_DESCRIPTOR_H_ | 6 #define REMOTING_HOST_WIN_SECURITY_DESCRIPTOR_H_ |
7 | 7 |
8 #include <windows.h> | 8 #include <windows.h> |
9 | 9 |
10 #include <string> | 10 #include <string> |
11 | 11 |
12 #include "remoting/base/typed_buffer.h" | 12 #include "remoting/base/typed_buffer.h" |
13 | 13 |
14 namespace remoting { | 14 namespace remoting { |
15 | 15 |
| 16 typedef TypedBuffer<ACL> ScopedAcl; |
16 typedef TypedBuffer<SECURITY_DESCRIPTOR> ScopedSd; | 17 typedef TypedBuffer<SECURITY_DESCRIPTOR> ScopedSd; |
17 typedef TypedBuffer<SID> ScopedSid; | 18 typedef TypedBuffer<SID> ScopedSid; |
18 | 19 |
19 // Converts an SDDL string into a binary self-relative security descriptor. | 20 // Converts an SDDL string into a binary self-relative security descriptor. |
20 ScopedSd ConvertSddlToSd(const std::string& sddl); | 21 ScopedSd ConvertSddlToSd(const std::string& sddl); |
21 | 22 |
22 // Converts a SID into a text string. | 23 // Converts a SID into a text string. |
23 std::string ConvertSidToString(SID* sid); | 24 std::string ConvertSidToString(SID* sid); |
24 | 25 |
25 // Returns the logon SID of a token. Returns NULL if the token does not specify | 26 // Returns the logon SID of a token. Returns NULL if the token does not specify |
26 // a logon SID or in case of an error. | 27 // a logon SID or in case of an error. |
27 ScopedSid GetLogonSid(HANDLE token); | 28 ScopedSid GetLogonSid(HANDLE token); |
28 | 29 |
| 30 // Converts a security descriptor in self-relative format to a security |
| 31 // descriptor in absolute format. |
| 32 bool MakeScopedAbsoluteSd(const ScopedSd& relative_sd, |
| 33 ScopedSd* absolute_sd, |
| 34 ScopedAcl* dacl, |
| 35 ScopedSid* group, |
| 36 ScopedSid* owner, |
| 37 ScopedAcl* sacl); |
| 38 |
29 } // namespace remoting | 39 } // namespace remoting |
30 | 40 |
31 #endif // REMOTING_HOST_WIN_SECURITY_DESCRIPTOR_H_ | 41 #endif // REMOTING_HOST_WIN_SECURITY_DESCRIPTOR_H_ |
OLD | NEW |