blob: f275c00183e1aeafa758e7a7f9a4d7aedb98da26 [file] [log] [blame]
// Copyright 2018 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_CHROME_CLEANER_OS_SYSTEM_UTIL_H_
#define CHROME_CHROME_CLEANER_OS_SYSTEM_UTIL_H_
#include <windows.h>
#include <vector>
#include "base/strings/string16.h"
#include "base/win/scoped_handle.h"
#include "base/win/wincrypt_shim.h"
#include "chrome/chrome_cleaner/os/scoped_service_handle.h"
namespace chrome_cleaner {
// Enumerate the contexts of the given certificate store.
class CertificateEnumerator {
public:
explicit CertificateEnumerator(HCERTSTORE store_handle) {
store_handle_ = store_handle;
}
~CertificateEnumerator() {
if (context_)
::CertFreeCertificateContext(context_);
}
bool Next() {
context_ = ::CertEnumCertificatesInStore(store_handle_, context_);
return context_ != nullptr;
}
PCCERT_CONTEXT context() const { return context_; }
private:
HCERTSTORE store_handle_;
PCCERT_CONTEXT context_ = nullptr;
};
// Based on ENUM_SERVICE_STATUS_PROCESSW from
// https://docs.microsoft.com/en-us/windows/desktop/api/winsvc/ns-winsvc-_enum_service_status_processw
struct ServiceStatus {
base::string16 service_name;
base::string16 display_name;
SERVICE_STATUS_PROCESS service_status_process;
};
// Set |medium_integrity_token| with a medium integrity level token duplicated
// from the current process token. Return false on failures or if called when
// running on a Windows version before Vista.
bool GetMediumIntegrityToken(base::win::ScopedHandle* medium_integrity_token);
// Convert a GUID to its textual representation. |output| receives the textual
// representation.
void GUIDToString(const GUID&, base::string16* output);
// Set the current process to background mode.
void SetBackgroundMode();
// Return whether Windows is performing registry key redirection for Windows
// on Windows for the current process.
// Do not use this value as sign of x64 architecture, as it true only for
// 32-bit processes running on 64-bit OS.
bool IsWowRedirectionActive();
// Return whether this version of Windows uses x64 processor architecture.
bool IsX64Architecture();
// Return whether the current process is 64-bit.
bool IsX64Process();
// Fills |services| with services from the given |service_manager| that match
// |service_type| and |service_state|. Returns false on error. The possible
// values of |service_type| and |service_state| are given at
// https://docs.microsoft.com/en-us/windows/desktop/api/winsvc/nf-winsvc-enumservicesstatusexa.
bool EnumerateServices(const ScopedScHandle& service_manager,
DWORD service_type,
DWORD service_state,
std::vector<ServiceStatus>* services);
} // namespace chrome_cleaner
#endif // CHROME_CHROME_CLEANER_OS_SYSTEM_UTIL_H_