blob: 2e4006b2b8ac7a00c9a3d6be15514d2e1f98158e [file] [log] [blame]
Francois Gouget85ae2552004-10-21 21:00:29 +00001/*
2 * Copyright (C) 2004 Francois Gouget
3 *
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
8 *
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
13 *
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
Jonathan Ernst360a3f92006-05-18 14:49:52 +020016 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
Francois Gouget85ae2552004-10-21 21:00:29 +000017 */
18
19#ifndef __WINE_WINTRUST_H
20#define __WINE_WINTRUST_H
21
22#include <wincrypt.h>
23
24
25#include <pshpack8.h>
26
27typedef struct WINTRUST_FILE_INFO_
28{
29 DWORD cbStruct;
30 LPCWSTR pcwszFilePath;
31 HANDLE hFile;
32 GUID* pgKnownSubject;
33} WINTRUST_FILE_INFO, *PWINTRUST_FILE_INFO;
34
35typedef struct WINTRUST_CATALOG_INFO_
36{
37 DWORD cbStruct;
38 DWORD dwCatalogVersion;
39 LPCWSTR pcwszCatalogFilePath;
40 LPCWSTR pcwszMemberTag;
41 LPCWSTR pcwszMemberFilePath;
42 HANDLE hMemberFile;
43 BYTE* pbCalculatedFileHash;
44 DWORD cbCalculatedFileHash;
45 PCCTL_CONTEXT pcCatalogContext;
46} WINTRUST_CATALOG_INFO, *PWINTRUST_CATALOG_INFO;
47
48typedef struct WINTRUST_BLOB_INFO_
49{
50 DWORD cbStruct;
51 GUID gSubject;
52 LPCWSTR pcwszDisplayName;
53 DWORD cbMemObject;
54 BYTE* pbMemObject;
55 DWORD cbMemSignedMsg;
56 BYTE* pbMemSignedMsg;
57} WINTRUST_BLOB_INFO, *PWINTRUST_BLOB_INFO;
58
59typedef struct WINTRUST_SGNR_INFO_
60{
61 DWORD cbStruct;
62 LPCWSTR pcwszDisplayName;
63 CMSG_SIGNER_INFO* psSignerInfo;
64 DWORD chStores;
65 HCERTSTORE* pahStores;
66} WINTRUST_SGNR_INFO, *PWINTRUST_SGNR_INFO;
67
68typedef struct WINTRUST_CERT_INFO_
69{
70 DWORD cbStruct;
71 LPCWSTR pcwszDisplayName;
72 CERT_CONTEXT* psCertContext;
73 DWORD chStores;
74 HCERTSTORE* pahStores;
75 DWORD dwFlags;
76 FILETIME* psftVerifyAsOf;
77} WINTRUST_CERT_INFO, *PWINTRUST_CERT_INFO;
78
Juan Lang5860cc22006-09-26 22:08:54 -070079#define WTCI_DONT_OPEN_STORES 0x00000001
80#define WTCI_OPEN_ONLY_ROOT 0x00000002
81
Paul Vriens5ffb0172006-08-18 08:42:47 +020082/* dwUIChoice */
83#define WTD_UI_ALL 1
84#define WTD_UI_NONE 2
85#define WTD_UI_NOBAD 3
86#define WTD_UI_NOGOOD 4
87/* fdwRevocationChecks */
88#define WTD_REVOKE_NONE 0
89#define WTD_REVOKE_WHOLECHAIN 1
90/* dwUnionChoice */
91#define WTD_CHOICE_FILE 1
92#define WTD_CHOICE_CATALOG 2
93#define WTD_CHOICE_BLOB 3
94#define WTD_CHOICE_SIGNER 4
95#define WTD_CHOICE_CERT 5
Francois Gouget85ae2552004-10-21 21:00:29 +000096
97typedef struct _WINTRUST_DATA
98{
99 DWORD cbStruct;
100 LPVOID pPolicyCallbackData;
101 LPVOID pSIPClientData;
102 DWORD dwUIChoice;
103 DWORD fdwRevocationChecks;
104 DWORD dwUnionChoice;
105 union
106 {
107 struct WINTRUST_FILE_INFO_* pFile;
108 struct WINTRUST_CATALOG_INFO_* pCatalog;
109 struct WINTRUST_BLOB_INFO_* pBlob;
110 struct WINTRUST_SGNR_INFO_* pSgnr;
111 struct WINTRUST_CERT_INFO_* pCert;
112 } DUMMYUNIONNAME;
113
114 DWORD dwStateAction;
115 HANDLE hWVTStateData;
116 WCHAR* pwszURLReference;
117 DWORD dwProvFlags;
Paul Vriensb92725a2005-07-15 09:56:40 +0000118 DWORD dwUIContext;
Francois Gouget85ae2552004-10-21 21:00:29 +0000119} WINTRUST_DATA, *PWINTRUST_DATA;
120
Juan Lang5860cc22006-09-26 22:08:54 -0700121#define WTD_STATEACTION_IGNORE 0
122#define WTD_STATEACTION_VERIFY 1
123#define WTD_STATEACTION_CLOSE 2
124#define WTD_STATEACTION_AUTO_CACHE 3
125#define WTD_STATEACTION_AUTO_CACHE_FLUSH 4
126
127#define WTD_PROV_FLAGS_MASK 0x0000ffff
128#define WTD_USE_IE4_TRUST_FLAG 0x00000001
129#define WTD_NO_IE4_CHAIN_FLAG 0x00000002
130#define WTD_NO_POLICY_USAGE_FLAG 0x00000004
131#define WTD_REVOCATION_CHECK_NONE 0x00000010
132#define WTD_REVOCATION_CHECK_END_CERT 0x00000020
133#define WTD_REVOCATION_CHECK_CHAIN 0x00000040
134#define WTD_REVOCATION_CHECK_CHAIN_EXCLUDE_ROOT 0x00000080
135#define WTD_SAFER_FLAG 0x00000100
136#define WTD_HASH_ONLY_FLAG 0x00000200
137#define WTD_USE_DEFAULT_OSVER_CHECK 0x00000400
138#define WTD_LIFETIME_SIGNING_FLAG 0x00000800
Juan Lang3db50272007-08-28 15:52:55 -0700139#define WTD_CACHE_ONLY_URL_RETRIEVAL 0x00001000
Juan Lang5860cc22006-09-26 22:08:54 -0700140
141#define WTD_UICONTEXT_EXECUTE 0
142#define WTD_UICONTEXT_INSTALL 1
143
Mike McCormack8ec66822005-06-01 19:49:29 +0000144typedef struct _CRYPT_TRUST_REG_ENTRY
145{
146 DWORD cbStruct;
147 WCHAR *pwszDLLName;
148 WCHAR *pwszFunctionName;
149} CRYPT_TRUST_REG_ENTRY, *PCRYPT_TRUST_REG_ENTRY;
150
151typedef struct _CRYPT_REGISTER_ACTIONID
152{
153 DWORD cbStruct;
154 CRYPT_TRUST_REG_ENTRY sInitProvider;
155 CRYPT_TRUST_REG_ENTRY sObjectProvider;
156 CRYPT_TRUST_REG_ENTRY sSignatureProvider;
157 CRYPT_TRUST_REG_ENTRY sCertificateProvider;
158 CRYPT_TRUST_REG_ENTRY sCertificatePolicyProvider;
159 CRYPT_TRUST_REG_ENTRY sFinalPolicyProvider;
160 CRYPT_TRUST_REG_ENTRY sTestPolicyProvider;
161 CRYPT_TRUST_REG_ENTRY sCleanupProvider;
162} CRYPT_REGISTER_ACTIONID, *PCRYPT_REGISTER_ACTIONID;
163
Paul Vriens1f054202006-09-12 13:18:25 +0200164typedef struct _CRYPT_PROVIDER_REGDEFUSAGE
165{
166 DWORD cbStruct;
167 GUID *pgActionID;
168 WCHAR *pwszDllName;
169 char *pwszLoadCallbackDataFunctionName;
170 char *pwszFreeCallbackDataFunctionName;
171} CRYPT_PROVIDER_REGDEFUSAGE, *PCRYPT_PROVIDER_REGDEFUSAGE;
172
Juan Lang2c5f20b2006-02-18 15:50:01 +0100173typedef struct _CRYPT_PROVUI_DATA {
174 DWORD cbStruct;
175 DWORD dwFinalError;
176 WCHAR *pYesButtonText;
177 WCHAR *pNoButtonText;
178 WCHAR *pMoreInfoButtonText;
179 WCHAR *pAdvancedLinkText;
180 WCHAR *pCopyActionText;
181 WCHAR *pCopyActionTextNoTS;
182 WCHAR *pCopyActionTextNotSigned;
183} CRYPT_PROVUI_DATA, *PCRYPT_PROVUI_DATA;
184
185typedef struct _CRYPT_PROVIDER_CERT {
186 DWORD cbStruct;
187 PCCERT_CONTEXT pCert;
188 BOOL fCommercial;
189 BOOL fTrustedRoot;
190 BOOL fSelfSigned;
191 BOOL fTestCert;
192 DWORD dwRevokedReason;
193 DWORD dwConfidence;
194 DWORD dwError;
195 CTL_CONTEXT *pTrustListContext;
196 BOOL fTrustListSignerCert;
197 PCCTL_CONTEXT pCtlContext;
198 DWORD dwCtlError;
199 BOOL fIsCyclic;
200 PCERT_CHAIN_ELEMENT pChainElement;
201} CRYPT_PROVIDER_CERT, *PCRYPT_PROVIDER_CERT;
202
Juan Lang3db50272007-08-28 15:52:55 -0700203#define CERT_CONFIDENCE_SIG 0x10000000
204#define CERT_CONFIDENCE_TIME 0x01000000
205#define CERT_CONFIDENCE_TIMENEST 0x00100000
206#define CERT_CONFIDENCE_AUTHIDEXT 0x00010000
207#define CERT_CONFIDENCE_HYGIENE 0x00001000
208#define CERT_CONFIDENCE_HIGHEST 0x11111000
209
Juan Lang2c5f20b2006-02-18 15:50:01 +0100210typedef struct _CRYPT_PROVIDER_SGNR {
211 DWORD cbStruct;
212 FILETIME sftVerifyAsOf;
213 DWORD csCertChain;
214 CRYPT_PROVIDER_CERT *pasCertChain;
215 DWORD dwSignerType;
216 CMSG_SIGNER_INFO *psSigner;
217 DWORD dwError;
218 DWORD csCounterSigners;
219 struct _CRYPT_PROVIDER_SGNR *pasCounterSigners;
220 PCCERT_CHAIN_CONTEXT pChainContext;
221} CRYPT_PROVIDER_SGNR, *PCRYPT_PROVIDER_SGNR;
222
Juan Lang3db50272007-08-28 15:52:55 -0700223#define SGNR_TYPE_TIMESTAMP 0x00000010
224
Juan Lang2c5f20b2006-02-18 15:50:01 +0100225typedef struct _CRYPT_PROVIDER_PRIVDATA {
226 DWORD cbStruct;
227 GUID gProviderID;
228 DWORD cbProvData;
229 void *pvProvData;
230} CRYPT_PROVIDER_PRIVDATA, *PCRYPT_PROVIDER_PRIVDATA;
231
232struct _CRYPT_PROVIDER_DATA;
233
Juan Langbb963cc2007-08-24 15:08:12 -0700234#define TRUSTERROR_STEP_WVTPARAMS 0
235#define TRUSTERROR_STEP_FILEIO 2
236#define TRUSTERROR_STEP_SIP 3
237#define TRUSTERROR_STEP_SIPSUBJINFO 5
238#define TRUSTERROR_STEP_CATALOGFILE 6
239#define TRUSTERROR_STEP_CERTSTORE 7
240#define TRUSTERROR_STEP_MESSAGE 8
241#define TRUSTERROR_STEP_MSG_SIGNERCOUNT 9
242#define TRUSTERROR_STEP_MSG_INNERCNTTYPE 10
243#define TRUSTERROR_STEP_MSG_INNERCNT 11
244#define TRUSTERROR_STEP_MSG_STORE 12
245#define TRUSTERROR_STEP_MSG_SIGNERINFO 13
246#define TRUSTERROR_STEP_MSG_SIGNERCERT 14
247#define TRUSTERROR_STEP_MSG_CERTCHAIN 15
248#define TRUSTERROR_STEP_MSG_COUNTERSIGINFO 16
249#define TRUSTERROR_STEP_MSG_COUNTERSIGCERT 17
250#define TRUSTERROR_STEP_VERIFY_MSGHASH 18
251#define TRUSTERROR_STEP_VERIFY_MSGINDIRECTDATA 19
252#define TRUSTERROR_STEP_FINAL_WVTINIT 30
253#define TRUSTERROR_STEP_FINAL_INITPROV 31
254#define TRUSTERROR_STEP_FINAL_OBJPROV 32
255#define TRUSTERROR_STEP_FINAL_SIGPROV 33
256#define TRUSTERROR_STEP_FINAL_CERTPROV 34
257#define TRUSTERROR_STEP_FINAL_CERTCHKPROV 35
258#define TRUSTERROR_STEP_FINAL_POLICYPROV 36
259#define TRUSTERROR_STEP_FINAL_UIPROV 37
260
261#define TRUSTERROR_MAX_STEPS 38
262
Marcus Meissnerde530b52008-09-12 19:14:45 +0200263typedef void * (__WINE_ALLOC_SIZE(1) WINAPI *PFN_CPD_MEM_ALLOC)(DWORD cbSize);
Juan Lang67a0ff42007-08-24 15:06:39 -0700264typedef void (WINAPI *PFN_CPD_MEM_FREE)(void *pvMem2Free);
265typedef BOOL (WINAPI *PFN_CPD_ADD_STORE)(struct _CRYPT_PROVIDER_DATA *pProvData,
Juan Lang2c5f20b2006-02-18 15:50:01 +0100266 HCERTSTORE hStore2Add);
Juan Lang67a0ff42007-08-24 15:06:39 -0700267typedef BOOL (WINAPI *PFN_CPD_ADD_SGNR)(struct _CRYPT_PROVIDER_DATA *pProvData,
Juan Lang2c5f20b2006-02-18 15:50:01 +0100268 BOOL fCounterSigner, DWORD idxSigner, struct _CRYPT_PROVIDER_SGNR *pSgnr2Add);
Juan Lang67a0ff42007-08-24 15:06:39 -0700269typedef BOOL (WINAPI *PFN_CPD_ADD_CERT)(struct _CRYPT_PROVIDER_DATA *pProvData,
Juan Lang2c5f20b2006-02-18 15:50:01 +0100270 DWORD idxSigner, BOOL fCounterSigner, DWORD idxCounterSigner,
271 PCCERT_CONTEXT pCert2Add);
Juan Lang67a0ff42007-08-24 15:06:39 -0700272typedef BOOL (WINAPI *PFN_CPD_ADD_PRIVDATA)(struct _CRYPT_PROVIDER_DATA *pProvData,
Juan Lang2c5f20b2006-02-18 15:50:01 +0100273 struct _CRYPT_PROVIDER_PRIVDATA *pPrivData2Add);
Juan Lang67a0ff42007-08-24 15:06:39 -0700274typedef HRESULT (WINAPI *PFN_PROVIDER_INIT_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100275 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700276typedef HRESULT (WINAPI *PFN_PROVIDER_OBJTRUST_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100277 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700278typedef HRESULT (WINAPI *PFN_PROVIDER_SIGTRUST_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100279 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700280typedef HRESULT (WINAPI *PFN_PROVIDER_CERTTRUST_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100281 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700282typedef HRESULT (WINAPI *PFN_PROVIDER_FINALPOLICY_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100283 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700284typedef HRESULT (WINAPI *PFN_PROVIDER_TESTFINALPOLICY_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100285 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700286typedef HRESULT (WINAPI *PFN_PROVIDER_CLEANUP_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100287 struct _CRYPT_PROVIDER_DATA *pProvData);
Juan Lang67a0ff42007-08-24 15:06:39 -0700288typedef BOOL (WINAPI *PFN_PROVIDER_CERTCHKPOLICY_CALL)(
Juan Lang2c5f20b2006-02-18 15:50:01 +0100289 struct _CRYPT_PROVIDER_DATA *pProvData, DWORD idxSigner,
290 BOOL fCounterSignerChain, DWORD idxCounterSigner);
291
292typedef struct _CRYPT_PROVIDER_FUNCTIONS {
293 DWORD cbStruct;
294 PFN_CPD_MEM_ALLOC pfnAlloc;
295 PFN_CPD_MEM_FREE pfnFree;
296 PFN_CPD_ADD_STORE pfnAddStore2Chain;
297 PFN_CPD_ADD_SGNR pfnAddSgnr2Chain;
298 PFN_CPD_ADD_CERT pfnAddCert2Chain;
299 PFN_CPD_ADD_PRIVDATA pfnAddPrivData2Chain;
300 PFN_PROVIDER_INIT_CALL pfnInitialize;
301 PFN_PROVIDER_OBJTRUST_CALL pfnObjectTrust;
302 PFN_PROVIDER_SIGTRUST_CALL pfnSignatureTrust;
Juan Langda3970d2007-05-02 07:42:24 -0700303 PFN_PROVIDER_CERTTRUST_CALL pfnCertificateTrust;
Juan Lang2c5f20b2006-02-18 15:50:01 +0100304 PFN_PROVIDER_FINALPOLICY_CALL pfnFinalPolicy;
305 PFN_PROVIDER_CERTCHKPOLICY_CALL pfnCertCheckPolicy;
306 PFN_PROVIDER_TESTFINALPOLICY_CALL pfnTestFinalPolicy;
307 struct _CRYPT_PROVUI_FUNCS *psUIpfns;
308 PFN_PROVIDER_CLEANUP_CALL pfnCleanupPolicy;
309} CRYPT_PROVIDER_FUNCTIONS, *PCRYPT_PROVIDER_FUNCTIONS;
310
311struct SIP_DISPATCH_INFO_;
312struct SIP_SUBJECTINFO_;
313struct SIP_INDIRECT_DATA_;
314
315typedef struct _PROVDATA_SIP {
316 DWORD cbStruct;
317 GUID gSubject;
318 struct SIP_DISPATCH_INFO_ *pSip;
319 struct SIP_DISPATCH_INFO_ *pCATSip;
320 struct SIP_SUBJECTINFO_ *psSipSubjectInfo;
321 struct SIP_SUBJECTINFO_ *psSipCATSubjectInfo;
322 struct SIP_INDIRECT_DATA_ *psIndirectData;
323} PROVDATA_SIP, *PPROVDATA_SIP;
324
325typedef struct _CRYPT_PROVIDER_DATA {
326 DWORD cbStruct;
327 WINTRUST_DATA *pWintrustData;
328 BOOL fOpenedFile;
329 HWND hWndParent;
330 GUID *pgActionID;
331 HCRYPTPROV hProv;
332 DWORD dwError;
333 DWORD dwRegSecuritySettings;
334 DWORD dwRegPolicySettings;
335 CRYPT_PROVIDER_FUNCTIONS *psPfns;
336 DWORD cdwTrustStepErrors;
337 DWORD *padwTrustStepErrors;
338 DWORD chStores;
339 HCERTSTORE *pahStores;
340 DWORD dwEncoding;
341 HCRYPTMSG hMsg;
342 DWORD csSigners;
343 CRYPT_PROVIDER_SGNR *pasSigners;
Paul Vriens254000d2008-01-27 17:28:18 +0100344 DWORD csProvPrivData;
345 CRYPT_PROVIDER_PRIVDATA *pasProvPrivData;
Juan Lang2c5f20b2006-02-18 15:50:01 +0100346 DWORD dwSubjectChoice;
347 union {
348 struct _PROVDATA_SIP *pPDSip;
349 } DUMMYUNIONNAME;
350 char *pszUsageOID;
351 BOOL fRecallWithState;
352 FILETIME sftSystemTime;
353 char *pszCTLSignerUsageOID;
354 DWORD dwProvFlags;
355 DWORD dwFinalError;
356 PCERT_USAGE_MATCH pRequestUsage;
357 DWORD dwTrustPubSettings;
358 DWORD dwUIStateFlags;
359} CRYPT_PROVIDER_DATA, *PCRYPT_PROVIDER_DATA;
360
Juan Lang3db50272007-08-28 15:52:55 -0700361#define CPD_CHOICE_SIP 1
362
363#define CPD_USE_NT5_CHAIN_FLAG 0x80000000
364#define CPD_REVOCATION_CHECK_NONE 0x00010000
365#define CPD_REVOCATION_CHECK_END_CERT 0x00020000
366#define CPD_REVOCATION_CHECK_CHAIN 0x00040000
367#define CPD_REVOCATION_CHECK_CHAIN_EXCLUDE_ROOT 0x00080000
368
369#define CPD_UISTATE_MODE_PROMPT 0x00000000
370#define CPD_UISTATE_MODE_BLOCK 0x00000001
371#define CPD_UISTATE_MODE_ALLOW 0x00000002
372#define CPD_UISTATE_MODE_MASK 0x00000003
373
Juan Lang2c5f20b2006-02-18 15:50:01 +0100374typedef BOOL (*PFN_PROVUI_CALL)(HWND hWndSecurityDialog,
375 struct _CRYPT_PROVIDER_DATA *pProvData);
376
377typedef struct _CRYPT_PROVUI_FUNCS {
378 DWORD cbStruct;
379 CRYPT_PROVUI_DATA psUIData;
380 PFN_PROVUI_CALL pfnOnMoreInfoClick;
381 PFN_PROVUI_CALL pfnOnMoreInfoClickDefault;
382 PFN_PROVUI_CALL pfnOnAdvancedClick;
383 PFN_PROVUI_CALL pfnOnAdvancedClickDefault;
384} CRYPT_PROVUI_FUNCS, *PCRYPT_PROVUI_FUNCS;
385
Francois Gouget85ae2552004-10-21 21:00:29 +0000386#include <poppack.h>
387
Juan Lang5860cc22006-09-26 22:08:54 -0700388#define WTPF_TRUSTTEST 0x00000020
389#define WTPF_TESTCANBEVALID 0x00000080
390#define WTPF_IGNOREEXPIRATION 0x00000100
391#define WTPF_IGNOREREVOKATION 0x00000200
392#define WTPF_OFFLINEOK_IND 0x00000400
393#define WTPF_OFFLINEOK_COM 0x00000800
394#define WTPF_OFFLINEOKNBU_IND 0x00001000
395#define WTPF_OFFLINEOKNBU_COM 0x00002000
396#define WTPF_VERIFY_V1_OFF 0x00010000
397#define WTPF_IGNOREREVOCATIONONTS 0x00020000
398#define WTPF_ALLOWONLYPERTRUST 0x00040000
399
Paul Vriens3747f222006-08-31 16:37:19 +0200400#define WT_ADD_ACTION_ID_RET_RESULT_FLAG 1
Francois Gouget85ae2552004-10-21 21:00:29 +0000401
402#ifdef __cplusplus
403extern "C" {
404#endif
405
Paul Vriens3943f462006-09-01 16:15:18 +0200406#if defined(__GNUC__)
407#define WT_PROVIDER_CERTTRUST_FUNCTION (const WCHAR []) \
408 {'W','i','n','t','r','u','s','t','C','e','r','t','i','f','i','c','a','t','e','T','r','u','s','t', 0}
409#elif defined(_MSC_VER)
410#define WT_PROVIDER_CERTTRUST_FUNCTION L"WintrustCertificateTrust"
411#else
Michael Stefaniucd7fe9582007-01-09 00:39:10 +0100412static const WCHAR WT_PROVIDER_CERTTRUST_FUNCTION[] =
Paul Vriens3943f462006-09-01 16:15:18 +0200413 {'W','i','n','t','r','u','s','t','C','e','r','t','i','f','i','c','a','t','e','T','r','u','s','t', 0};
414#endif
415
Mike McCormack8ec66822005-06-01 19:49:29 +0000416BOOL WINAPI WintrustAddActionID(GUID*,DWORD,CRYPT_REGISTER_ACTIONID*);
Paul Vriens6f872e52006-08-14 19:30:32 +0200417BOOL WINAPI WintrustRemoveActionID(GUID*);
Paul Vriens80df5322006-08-15 16:47:04 +0200418BOOL WINAPI WintrustLoadFunctionPointers(GUID*,CRYPT_PROVIDER_FUNCTIONS*);
Francois Gouget923c95a2007-01-26 13:18:40 +0100419BOOL WINAPI WintrustAddDefaultForUsage(const char*,CRYPT_PROVIDER_REGDEFUSAGE*);
Mike McCormack8ec66822005-06-01 19:49:29 +0000420void WINAPI WintrustGetRegPolicyFlags(DWORD*);
Juan Lang1af94db2007-05-14 18:15:09 -0700421BOOL WINAPI WintrustSetRegPolicyFlags(DWORD);
Francois Gouget6393fed2006-09-07 20:02:35 +0200422LONG WINAPI WinVerifyTrust(HWND,GUID*,LPVOID);
Juan Lang2c5f20b2006-02-18 15:50:01 +0100423HRESULT WINAPI WinVerifyTrustEx(HWND,GUID*,WINTRUST_DATA*);
424
Francois Gougetf9ee7962007-08-30 16:16:23 +0200425CRYPT_PROVIDER_CERT * WINAPI WTHelperGetProvCertFromChain(
426 CRYPT_PROVIDER_SGNR *pSgnr, DWORD idxCert);
Juan Lang2c5f20b2006-02-18 15:50:01 +0100427CRYPT_PROVIDER_SGNR * WINAPI WTHelperGetProvSignerFromChain(
428 CRYPT_PROVIDER_DATA *pProvData, DWORD idxSigner, BOOL fCounterSigner,
429 DWORD idxCounterSigner);
430CRYPT_PROVIDER_DATA * WINAPI WTHelperProvDataFromStateData(HANDLE hStateData);
Rob Shearman8e0f1252008-04-23 20:09:19 +0100431CRYPT_PROVIDER_PRIVDATA * WINAPI WTHelperGetProvPrivateDataFromChain(CRYPT_PROVIDER_DATA *,GUID *);
Francois Gouget85ae2552004-10-21 21:00:29 +0000432
Paul Vriens2bb7f912006-09-06 12:14:26 +0200433#define SPC_INDIRECT_DATA_OBJID "1.3.6.1.4.1.311.2.1.4"
434#define SPC_SP_AGENCY_INFO_OBJID "1.3.6.1.4.1.311.2.1.10"
435#define SPC_STATEMENT_TYPE_OBJID "1.3.6.1.4.1.311.2.1.11"
436#define SPC_SP_OPUS_INFO_OBJID "1.3.6.1.4.1.311.2.1.12"
Juan Lang98dd6c72007-08-10 11:02:45 -0700437#define SPC_CERT_EXTENSIONS_OBJID "1.3.6.1.4.1.311.2.1.14"
Paul Vriens2bb7f912006-09-06 12:14:26 +0200438#define SPC_PE_IMAGE_DATA_OBJID "1.3.6.1.4.1.311.2.1.15"
Juan Lang98dd6c72007-08-10 11:02:45 -0700439#define SPC_RAW_FILE_DATA_OBJID "1.3.6.1.4.1.311.2.1.18"
440#define SPC_STRUCTURED_STORAGE_DATA_OBJID "1.3.6.1.4.1.311.2.1.19"
Paul Vriens2bb7f912006-09-06 12:14:26 +0200441#define SPC_JAVA_CLASS_DATA_OBJID "1.3.6.1.4.1.311.2.1.20"
Juan Lang98dd6c72007-08-10 11:02:45 -0700442#define SPC_INDIVIDUAL_SP_KEY_PURPOSE_OBJID "1.3.6.1.4.1.311.2.1.21"
443#define SPC_COMMERCIAL_SP_KEY_PURPOSE_OBJID "1.3.6.1.4.1.311.2.1.22"
Paul Vriens2bb7f912006-09-06 12:14:26 +0200444#define SPC_CAB_DATA_OBJID "1.3.6.1.4.1.311.2.1.25"
Juan Lang98dd6c72007-08-10 11:02:45 -0700445#define SPC_GLUE_RDN_OBJID "1.3.6.1.4.1.311.2.1.25"
Paul Vriens2bb7f912006-09-06 12:14:26 +0200446#define SPC_MINIMAL_CRITERIA_OBJID "1.3.6.1.4.1.311.2.1.26"
447#define SPC_FINANCIAL_CRITERIA_OBJID "1.3.6.1.4.1.311.2.1.27"
448#define SPC_LINK_OBJID "1.3.6.1.4.1.311.2.1.28"
449#define SPC_SIGINFO_OBJID "1.3.6.1.4.1.311.2.1.30"
450#define CAT_NAMEVALUE_OBJID "1.3.6.1.4.1.311.12.2.1"
451#define CAT_MEMBERINFO_OBJID "1.3.6.1.4.1.311.12.2.2"
452
453#define SPC_SP_AGENCY_INFO_STRUCT ((LPCSTR) 2000)
454#define SPC_MINIMAL_CRITERIA_STRUCT ((LPCSTR) 2001)
455#define SPC_FINANCIAL_CRITERIA_STRUCT ((LPCSTR) 2002)
456#define SPC_INDIRECT_DATA_CONTENT_STRUCT ((LPCSTR) 2003)
457#define SPC_PE_IMAGE_DATA_STRUCT ((LPCSTR) 2004)
458#define SPC_LINK_STRUCT ((LPCSTR) 2005)
459#define SPC_STATEMENT_TYPE_STRUCT ((LPCSTR) 2006)
460#define SPC_SP_OPUS_INFO_STRUCT ((LPCSTR) 2007)
461#define SPC_CAB_DATA_STRUCT ((LPCSTR) 2008)
462#define SPC_JAVA_CLASS_DATA_STRUCT ((LPCSTR) 2009)
463#define SPC_SIGINFO_STRUCT ((LPCSTR) 2130)
464#define CAT_NAMEVALUE_STRUCT ((LPCSTR) 2221)
465#define CAT_MEMBERINFO_STRUCT ((LPCSTR) 2222)
466
Juan Lang98dd6c72007-08-10 11:02:45 -0700467#define SPC_UUID_LENGTH 16
468typedef BYTE SPC_UUID[SPC_UUID_LENGTH];
469
470typedef struct _SPC_SERIALIZED_OBJECT
471{
472 SPC_UUID ClassId;
473 CRYPT_DATA_BLOB SerializedData;
474} SPC_SERIALIZED_OBJECT, *PSPC_SERIALIZED_OBJECT;
475
476typedef struct SPC_SIGINFO_
477{
478 DWORD dwSipVersion;
479 GUID gSIPGuid;
480 DWORD dwReserved1;
481 DWORD dwReserved2;
482 DWORD dwReserved3;
483 DWORD dwReserved4;
484 DWORD dwReserved5;
485} SPC_SIGINFO, *PSPC_SIGINFO;
486
487#define SPC_URL_LINK_CHOICE 1
488#define SPC_MONIKER_LINK_CHOICE 2
489#define SPC_FILE_LINK_CHOICE 3
490
491typedef struct SPC_LINK_
492{
493 DWORD dwLinkChoice;
494 union
495 {
496 LPWSTR pwszUrl;
497 SPC_SERIALIZED_OBJECT Moniker;
498 LPWSTR pwszFile;
499 } DUMMYUNIONNAME;
500} SPC_LINK, *PSPC_LINK;
501
502typedef struct _SPC_PE_IMAGE_DATA
503{
504 CRYPT_BIT_BLOB Flags;
505 PSPC_LINK pFile;
506} SPC_PE_IMAGE_DATA, *PSPC_PE_IMAGE_DATA;
507
508typedef struct _SPC_INDIRECT_DATA_CONTENT
509{
510 CRYPT_ATTRIBUTE_TYPE_VALUE Data;
511 CRYPT_ALGORITHM_IDENTIFIER DigestAlgorithm;
512 CRYPT_HASH_BLOB Digest;
513} SPC_INDIRECT_DATA_CONTENT, *PSPC_INDIRECT_DATA_CONTENT;
514
515typedef struct _SPC_FINANCIAL_CRITERIA
516{
517 BOOL fFinancialInfoAvailable;
518 BOOL fMeetsCriteria;
519} SPC_FINANCIAL_CRITERIA, *PSPC_FINANCIAL_CRITERIA;
520
521typedef struct _SPC_IMAGE
522{
523 struct SPC_LINK_ *pImageLink;
524 CRYPT_DATA_BLOB Bitmap;
525 CRYPT_DATA_BLOB Metafile;
526 CRYPT_DATA_BLOB EnhancedMetafile;
527 CRYPT_DATA_BLOB GifFile;
528} SPC_IMAGE, *PSPC_IMAGE;
529
530typedef struct _SPC_SP_AGENCY_INFO
531{
532 struct SPC_LINK_ *pPolicyInformation;
533 LPWSTR pwszPolicyDisplayText;
534 PSPC_IMAGE pLogoImage;
535 struct SPC_LINK_ *pLogoLink;
536} SPC_SP_AGENCY_INFO, *PSPC_SP_AGENCY_INFO;
537
538typedef struct _SPC_STATEMENT_TYPE
539{
540 DWORD cKeyPurposeId;
541 LPSTR *rgpszKeyPurposeId;
542} SPC_STATEMENT_TYPE, *PSPC_STATEMENT_TYPE;
543
544typedef struct _SPC_SP_OPUS_INFO
545{
546 LPCWSTR pwszProgramName;
547 struct SPC_LINK_ *pMoreInfo;
548 struct SPC_LINK_ *pPublisherInfo;
549} SPC_SP_OPUS_INFO, *PSPC_SP_OPUS_INFO;
550
551typedef struct _CAT_NAMEVALUE
552{
553 LPWSTR pwszTag;
554 DWORD fdwFlags;
555 CRYPT_DATA_BLOB Value;
556} CAT_NAMEVALUE, *PCAT_NAMEVALUE;
557
558typedef struct _CAT_MEMBERINFO
559{
560 LPWSTR pwszSubjGuid;
561 DWORD dwCertVersion;
562} CAT_MEMBERINFO, *PCAT_MEMBERINFO;
563
Juan Lang01b083c2007-08-27 16:32:29 -0700564/* PSDK protects the remaining defines with WT_DEFINE_ALL_APIS, but it's
565 * defined by default. No need to protect against bad headers from old PSDKs.
566 */
567
568typedef struct _WIN_CERTIFICATE {
569 DWORD dwLength;
Zach Goldberg17651d02008-01-02 20:23:41 -0500570 WORD wRevision; /* WIN_CERT_REVISION_xxx */
Juan Lang01b083c2007-08-27 16:32:29 -0700571 WORD wCertificateType; /* WIN_CERT_TYPE_xxx */
572 BYTE bCertificate[ANYSIZE_ARRAY];
573} WIN_CERTIFICATE, *LPWIN_CERTIFICATE;
574
575#define WIN_CERT_REVISION_1_0 0x0100
576#define WIN_CERT_REVISION_2_0 0x0200
577
578#define WIN_CERT_TYPE_X509 0x0001 /* X.509 Certificate */
579#define WIN_CERT_TYPE_PKCS_SIGNED_DATA 0x0002 /* PKCS SignedData */
580#define WIN_CERT_TYPE_RESERVED_1 0x0003 /* Reserved */
581#define WIN_CERT_TYPE_TS_STACK_SIGNED 0x0004
582
Juan Lang3db50272007-08-28 15:52:55 -0700583typedef LPVOID WIN_TRUST_SUBJECT;
584
585typedef struct _WIN_TRUST_ACTDATA_CONTEXT_WITH_SUBJECT
586{
587 HANDLE hClientToken;
588 GUID *SubjectType;
589 WIN_TRUST_SUBJECT Subject;
590} WIN_TRUST_ACTDATA_CONTEXT_WITH_SUBJECT,
591 *LPWIN_TRUST_ACTDATA_CONTEXT_WITH_SUBJECT;
592
593typedef struct _WIN_TRUST_ACTDATA_CONTEXT_SUBJECT_ONLY
594{
595 GUID *SubjectType;
596 WIN_TRUST_SUBJECT Subject;
597} WIN_TRUST_ACTDATA_CONTEXT_SUBJECT_ONLY,
598 *LPWIN_TRUST_ACTDATA_CONTEXT_SUBJECT_ONLY;
599
600typedef struct _WIN_TRUST_SUBJECT_FILE
601{
602 HANDLE hFile;
603 LPCWSTR lpPath;
604} WIN_TRUST_SUBJECT_FILE, *LPWIN_TRUST_SUBJECT_FILE;
605
606typedef struct _WIN_TRUST_SUBJECT_FILE_AND_DISPLAY
607{
608 HANDLE hFile;
609 LPCWSTR lpPath;
610 LPCWSTR lpDisplayName;
611} WIN_TRUST_SUBJECT_FILE_AND_DISPLAY, *LPWIN_TRUST_SUBJECT_FILE_AND_DISPLAY;
612
Paul Vriens036e4ff2006-09-01 12:48:34 +0200613#define WIN_SPUB_ACTION_PUBLISHED_SOFTWARE \
614 { 0x64b9d180, 0x8da2, 0x11cf, { 0x87,0x36,0x00,0xaa,0x00,0xa4,0x85,0xeb }}
615
Francois Gouget85ae2552004-10-21 21:00:29 +0000616#ifdef __cplusplus
617}
618#endif
619
620#endif