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
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
use shared::guiddef::GUID;
use shared::minwindef::{BYTE, DWORD, LPVOID};
use shared::ntdef::{HANDLE, LONG, LPCWSTR, LPWSTR, WCHAR};
use shared::windef::HWND;
use um::wincrypt::{CRYPT_DATA_BLOB, PCERT_STRONG_SIGN_PARA};
//90
pub const WTD_UI_ALL: DWORD = 1;
pub const WTD_UI_NONE: DWORD = 2;
pub const WTD_UI_NOBAD: DWORD = 3;
pub const WTD_UI_NOGOOD: DWORD = 4;
pub const WTD_REVOKE_NONE: DWORD = 0x00000000;
pub const WTD_REVOKE_WHOLECHAIN: DWORD = 0x00000001;
pub const WTD_CHOICE_FILE: DWORD = 1;
pub const WTD_CHOICE_CATALOG: DWORD = 2;
pub const WTD_CHOICE_BLOB: DWORD = 3;
pub const WTD_CHOICE_SIGNER: DWORD = 4;
pub const WTD_CHOICE_CERT: DWORD = 5;
pub const WTD_STATEACTION_IGNORE: DWORD = 0x00000000;
pub const WTD_STATEACTION_VERIFY: DWORD = 0x00000001;
pub const WTD_STATEACTION_CLOSE: DWORD = 0x00000002;
pub const WTD_STATEACTION_AUTO_CACHE: DWORD = 0x00000003;
pub const WTD_STATEACTION_AUTO_CACHE_FLUSH: DWORD = 0x00000004;
pub const WTD_PROV_FLAGS_MASK: DWORD = 0x0000FFFF;
pub const WTD_USE_IE4_TRUST_FLAG: DWORD = 0x00000001;
pub const WTD_NO_IE4_CHAIN_FLAG: DWORD = 0x00000002;
pub const WTD_NO_POLICY_USAGE_FLAG: DWORD = 0x00000004;
pub const WTD_REVOCATION_CHECK_NONE: DWORD = 0x00000010;
pub const WTD_REVOCATION_CHECK_END_CERT: DWORD = 0x00000020;
pub const WTD_REVOCATION_CHECK_CHAIN: DWORD = 0x00000040;
pub const WTD_REVOCATION_CHECK_CHAIN_EXCLUDE_ROOT: DWORD = 0x00000080;
pub const WTD_SAFER_FLAG: DWORD = 0x00000100;
pub const WTD_HASH_ONLY_FLAG: DWORD = 0x00000200;
pub const WTD_USE_DEFAULT_OSVER_CHECK: DWORD = 0x00000400;
pub const WTD_LIFETIME_SIGNING_FLAG: DWORD = 0x00000800;
pub const WTD_CACHE_ONLY_URL_RETRIEVAL: DWORD = 0x00001000;
pub const WTD_DISABLE_MD2_MD4: DWORD = 0x00002000;
pub const WTD_MOTW: DWORD = 0x00004000;
pub const WTD_CODE_INTEGRITY_DRIVER_MODE: DWORD = 0x00008000;
pub const WTD_UICONTEXT_EXECUTE: DWORD = 0;
pub const WTD_UICONTEXT_INSTALL: DWORD = 1;
STRUCT!{struct WINTRUST_DATA {
cbStruct: DWORD,
pPolicyCallbackData: LPVOID,
pSIPClientData: LPVOID,
dwUIChoice: DWORD,
fdwRevocationChecks: DWORD,
dwUnionChoice: DWORD,
u: WINTRUST_DATA_u,
dwStateAction: DWORD,
hWVTStateData: HANDLE,
pwszURLReference: *mut WCHAR,
dwProvFlags: DWORD,
dwUIContext: DWORD,
pSignatureSettings: *mut WINTRUST_SIGNATURE_SETTINGS,
}}
UNION!{union WINTRUST_DATA_u {
[usize; 1],
pFile pFile_mut: *mut WINTRUST_FILE_INFO,
// pCatalog pCatalog_mut: *mut WINTRUST_CATALOG_INFO,
// pBlob pBlob_mut: *mut WINTRUST_BLOB_INFO,
// pSgnr pSgnr_mut: *mut WINTRUST_SGNR_INFO,
// pCert pCert_mut: *mut WINTRUST_CERT_INFO,
}}
pub type PWINTRUST_DATA = *mut WINTRUST_DATA;
STRUCT!{struct WINTRUST_SIGNATURE_SETTINGS {
cbStruct: DWORD,
dwIndex: DWORD,
dwFlags: DWORD,
cSecondarySigs: DWORD,
dwVerifiedSigIndex: DWORD,
pCryptoPolicy: PCERT_STRONG_SIGN_PARA,
}}
pub type PWINTRUST_SIGNATURE_SETTINGS = *mut WINTRUST_SIGNATURE_SETTINGS;
//217
STRUCT! {struct WINTRUST_FILE_INFO {
cbStruct: DWORD,
pcwszFilePath: LPCWSTR,
hFile: HANDLE,
pgKnownSubject: *const GUID,
}}
//414
extern "system" {
pub fn WinVerifyTrust(hwnd: HWND, pgActionID: *mut GUID, pWVTData: LPVOID) -> LONG;
}
//1246
pub const SPC_UUID_LENGTH: usize = 16;
pub type SPC_UUID = [BYTE; SPC_UUID_LENGTH];
//SpcSerializedObjectAttributesClassId
STRUCT!{struct SPC_SERIALIZED_OBJECT {
ClassId: SPC_UUID,
SerializedData: CRYPT_DATA_BLOB,
}}
pub type PSPC_SERIALIZED_OBJECT = *mut SPC_SERIALIZED_OBJECT;
STRUCT!{struct SPC_SIGINFO {
dwSipVersion: DWORD,
gSIPGuid: GUID,
dwReserved1: DWORD,
dwReserved2: DWORD,
dwReserved3: DWORD,
dwReserved4: DWORD,
dwReserved5: DWORD,
}}
pub type PSPC_SIGINFO = *mut SPC_SIGINFO;
pub const SPC_URL_LINK_CHOICE: DWORD = 1;
pub const SPC_MONIKER_LINK_CHOICE: DWORD = 2;
pub const SPC_FILE_LINK_CHOICE: DWORD = 3;
STRUCT!{struct SPC_LINK {
dwLinkChoice: DWORD,
u: SPC_LINK_u,
}}
UNION!{union SPC_LINK_u {
[u32; 6] [u64; 4],
pwszUrl pwszUrl_mut: LPWSTR,
Moniker Moniker_mut: SPC_SERIALIZED_OBJECT,
pwszFile pwszFile_mut: LPWSTR,
}}
pub type PSPC_LINK = *mut SPC_LINK;
//1337
STRUCT!{struct SPC_SP_OPUS_INFO {
pwszProgramName: LPCWSTR,
pMoreInfo: *mut SPC_LINK,
pPublisherInfo: *mut SPC_LINK,
}}
|