1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "base/process/process_handle.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "base/win/scoped_handle.h"
11 #include "base/win/windows_version.h"
15 ProcessId
GetCurrentProcId() {
16 return ::GetCurrentProcessId();
19 ProcessHandle
GetCurrentProcessHandle() {
20 return ::GetCurrentProcess();
23 bool OpenProcessHandle(ProcessId pid
, ProcessHandle
* handle
) {
24 // We try to limit privileges granted to the handle. If you need this
25 // for test code, consider using OpenPrivilegedProcessHandle instead of
26 // adding more privileges here.
27 ProcessHandle result
= OpenProcess(PROCESS_TERMINATE
|
28 PROCESS_QUERY_INFORMATION
|
39 bool OpenProcessHandleWithAccess(ProcessId pid
,
41 ProcessHandle
* handle
) {
42 ProcessHandle result
= OpenProcess(access_flags
, FALSE
, pid
);
51 void CloseProcessHandle(ProcessHandle process
) {
55 ProcessId
GetProcId(ProcessHandle process
) {
56 // This returns 0 if we have insufficient rights to query the process handle.
57 return GetProcessId(process
);
60 bool GetProcessIntegrityLevel(ProcessHandle process
, IntegrityLevel
*level
) {
64 if (win::GetVersion() < base::win::VERSION_VISTA
)
68 if (!OpenProcessToken(process
, TOKEN_QUERY
| TOKEN_QUERY_SOURCE
,
72 win::ScopedHandle
scoped_process_token(process_token
);
74 DWORD token_info_length
= 0;
75 if (GetTokenInformation(process_token
, TokenIntegrityLevel
, NULL
, 0,
76 &token_info_length
) ||
77 GetLastError() != ERROR_INSUFFICIENT_BUFFER
)
80 scoped_ptr
<char[]> token_label_bytes(new char[token_info_length
]);
81 if (!token_label_bytes
.get())
84 TOKEN_MANDATORY_LABEL
* token_label
=
85 reinterpret_cast<TOKEN_MANDATORY_LABEL
*>(token_label_bytes
.get());
89 if (!GetTokenInformation(process_token
, TokenIntegrityLevel
, token_label
,
90 token_info_length
, &token_info_length
))
93 DWORD integrity_level
= *GetSidSubAuthority(token_label
->Label
.Sid
,
94 (DWORD
)(UCHAR
)(*GetSidSubAuthorityCount(token_label
->Label
.Sid
)-1));
96 if (integrity_level
< SECURITY_MANDATORY_MEDIUM_RID
) {
97 *level
= LOW_INTEGRITY
;
98 } else if (integrity_level
>= SECURITY_MANDATORY_MEDIUM_RID
&&
99 integrity_level
< SECURITY_MANDATORY_HIGH_RID
) {
100 *level
= MEDIUM_INTEGRITY
;
101 } else if (integrity_level
>= SECURITY_MANDATORY_HIGH_RID
) {
102 *level
= HIGH_INTEGRITY
;