1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
// Copyright © 2015, Peter Atashian
// Licensed under the MIT License <LICENSE.md>
//! FFI bindings to userenv.
#![cfg(windows)]
extern crate winapi;
use winapi::*;
extern "system" {
    // pub fn AreThereVisibleLogoffScripts();
    // pub fn AreThereVisibleShutdownScripts();
    // pub fn CheckDirectoryOwnership();
    // pub fn CheckXForestLogon();
    // pub fn CopyProfileDirectoryEx2();
    // pub fn CreateAppContainerProfile();
    // pub fn CreateAppContainerProfileInternal();
    // pub fn CreateDirectoryJunctionsForSystem();
    // pub fn CreateDirectoryJunctionsForUserProfile();
    pub fn CreateEnvironmentBlock(
        lpEnvironment: *mut LPVOID, hToken: HANDLE, bInherit: BOOL,
    ) -> BOOL;
    // pub fn CreateGroupEx();
    // pub fn CreateLinkFileEx();
    pub fn CreateProfile(
        pszUserSid: LPCWSTR, pszUserName: LPCWSTR, pszProfilePath: LPWSTR, cchProfilePath: DWORD,
    ) -> HRESULT;
    // pub fn DeleteAppContainerProfile();
    // pub fn DeleteAppContainerProfileInternal();
    // pub fn DeleteGroup();
    // pub fn DeleteLinkFile();
    pub fn DeleteProfileA(
        lpSidString: LPCSTR, lpProfilePath: LPCSTR, lpComputerName: LPCSTR,
    ) -> BOOL;
    // pub fn DeleteProfileDirectory();
    pub fn DeleteProfileW(
        lpSidString: LPCWSTR, lpProfilePath: LPCWSTR, lpComputerName: LPCWSTR,
    ) -> BOOL;
    // pub fn DeriveAppContainerSidFromAppContainerName();
    // pub fn DeriveRestrictedAppContainerSidFromAppContainerSidAndRestrictedName();
    pub fn DestroyEnvironmentBlock(lpEnvironment: LPVOID) -> BOOL;
    pub fn EnterCriticalPolicySection(bMachine: BOOL) -> HANDLE;
    pub fn ExpandEnvironmentStringsForUserA(
        hToken: HANDLE, lpSrc: LPCSTR, lpDest: LPSTR, dwSize: DWORD,
    ) -> BOOL;
    pub fn ExpandEnvironmentStringsForUserW(
        hToken: HANDLE, lpSrc: LPCWSTR, lpDest: LPWSTR, dwSize: DWORD,
    ) -> BOOL;
    // pub fn ForceSyncFgPolicy();
    // pub fn FreeGPOListA();
    // pub fn FreeGPOListW();
    // pub fn GenerateGPNotification();
    pub fn GetAllUsersProfileDirectoryA(lpProfileDir: LPSTR, lpcchSize: LPDWORD) -> BOOL;
    pub fn GetAllUsersProfileDirectoryW(lpProfileDir: LPWSTR, lpcchSize: LPDWORD) -> BOOL;
    // pub fn GetAppContainerFolderPath();
    // pub fn GetAppContainerRegistryLocation();
    // pub fn GetAppliedGPOListA();
    // pub fn GetAppliedGPOListW();
    pub fn GetDefaultUserProfileDirectoryA(lpProfileDir: LPSTR, lpcchSize: LPDWORD) -> BOOL;
    pub fn GetDefaultUserProfileDirectoryW(lpProfileDir: LPWSTR, lpcchSize: LPDWORD) -> BOOL;
    // pub fn GetGPOListA();
    // pub fn GetGPOListW();
    // pub fn GetLongProfilePathName();
    // pub fn GetNextFgPolicyRefreshInfo();
    // pub fn GetPreviousFgPolicyRefreshInfo();
    pub fn GetProfileType(dwFlags: *mut DWORD) -> BOOL;
    pub fn GetProfilesDirectoryA(lpProfileDir: LPSTR, lpcchSize: LPDWORD) -> BOOL;
    pub fn GetProfilesDirectoryW(lpProfileDir: LPWSTR, lpcchSize: LPDWORD) -> BOOL;
    pub fn GetUserProfileDirectoryA(
        hToken: HANDLE, lpProfileDir: LPSTR, lpcchSize: LPDWORD,
    ) -> BOOL;
    // pub fn GetUserProfileDirectoryForUserSidW();
    pub fn GetUserProfileDirectoryW(
        hToken: HANDLE, lpProfileDir: LPWSTR, lpcchSize: LPDWORD,
    ) -> BOOL;
    // pub fn HasPolicyForegroundProcessingCompleted();
    // pub fn IsAppContainerProfilePresentInternal();
    pub fn LeaveCriticalPolicySection(hSection: HANDLE) -> BOOL;
    // pub fn LoadUserProfileA(hToken: HANDLE, lpProfileInfo: LPPROFILEINFOA) -> BOOL;
    // pub fn LoadUserProfileW(hToken: HANDLE, lpProfileInfo: LPPROFILEINFOW) -> BOOL;
    // pub fn LookupAppContainerDisplayName();
    // pub fn PingComputer();
    // pub fn ProcessGroupPolicyCompleted();
    // pub fn ProcessGroupPolicyCompletedEx();
    pub fn RefreshPolicy(bMachine: BOOL) -> BOOL;
    pub fn RefreshPolicyEx(bMachine: BOOL, dwOptions: DWORD) -> BOOL;
    pub fn RegisterGPNotification(hEvent: HANDLE, bMachine: BOOL) -> BOOL;
    // pub fn RemapProfile();
    // pub fn RsopAccessCheckByType();
    // pub fn RsopFileAccessCheck();
    // pub fn RsopResetPolicySettingStatus();
    // pub fn RsopSetPolicySettingStatus();
    pub fn UnloadUserProfile(hToken: HANDLE, hProfile: HANDLE) -> BOOL;
    pub fn UnregisterGPNotification(hEvent: HANDLE) -> BOOL;
    // pub fn UpdateAppContainerProfile();
    // pub fn WaitForMachinePolicyForegroundProcessing();
    // pub fn WaitForUserPolicyForegroundProcessing();
}