2 * Copyright (C) 2004 Francois Gouget
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.
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.
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
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
19 #ifndef __WINE_WINTRUST_H
20 #define __WINE_WINTRUST_H
27 typedef struct WINTRUST_FILE_INFO_
30 LPCWSTR pcwszFilePath
;
33 } WINTRUST_FILE_INFO
, *PWINTRUST_FILE_INFO
;
35 typedef struct WINTRUST_CATALOG_INFO_
38 DWORD dwCatalogVersion
;
39 LPCWSTR pcwszCatalogFilePath
;
40 LPCWSTR pcwszMemberTag
;
41 LPCWSTR pcwszMemberFilePath
;
43 BYTE
* pbCalculatedFileHash
;
44 DWORD cbCalculatedFileHash
;
45 PCCTL_CONTEXT pcCatalogContext
;
46 } WINTRUST_CATALOG_INFO
, *PWINTRUST_CATALOG_INFO
;
48 typedef struct WINTRUST_BLOB_INFO_
52 LPCWSTR pcwszDisplayName
;
57 } WINTRUST_BLOB_INFO
, *PWINTRUST_BLOB_INFO
;
59 typedef struct WINTRUST_SGNR_INFO_
62 LPCWSTR pcwszDisplayName
;
63 CMSG_SIGNER_INFO
* psSignerInfo
;
65 HCERTSTORE
* pahStores
;
66 } WINTRUST_SGNR_INFO
, *PWINTRUST_SGNR_INFO
;
68 typedef struct WINTRUST_CERT_INFO_
71 LPCWSTR pcwszDisplayName
;
72 CERT_CONTEXT
* psCertContext
;
74 HCERTSTORE
* pahStores
;
76 FILETIME
* psftVerifyAsOf
;
77 } WINTRUST_CERT_INFO
, *PWINTRUST_CERT_INFO
;
82 #define WTD_UI_NOBAD 3
83 #define WTD_UI_NOGOOD 4
84 /* fdwRevocationChecks */
85 #define WTD_REVOKE_NONE 0
86 #define WTD_REVOKE_WHOLECHAIN 1
88 #define WTD_CHOICE_FILE 1
89 #define WTD_CHOICE_CATALOG 2
90 #define WTD_CHOICE_BLOB 3
91 #define WTD_CHOICE_SIGNER 4
92 #define WTD_CHOICE_CERT 5
94 typedef struct _WINTRUST_DATA
97 LPVOID pPolicyCallbackData
;
98 LPVOID pSIPClientData
;
100 DWORD fdwRevocationChecks
;
104 struct WINTRUST_FILE_INFO_
* pFile
;
105 struct WINTRUST_CATALOG_INFO_
* pCatalog
;
106 struct WINTRUST_BLOB_INFO_
* pBlob
;
107 struct WINTRUST_SGNR_INFO_
* pSgnr
;
108 struct WINTRUST_CERT_INFO_
* pCert
;
112 HANDLE hWVTStateData
;
113 WCHAR
* pwszURLReference
;
116 } WINTRUST_DATA
, *PWINTRUST_DATA
;
118 typedef struct _CRYPT_TRUST_REG_ENTRY
122 WCHAR
*pwszFunctionName
;
123 } CRYPT_TRUST_REG_ENTRY
, *PCRYPT_TRUST_REG_ENTRY
;
125 typedef struct _CRYPT_REGISTER_ACTIONID
128 CRYPT_TRUST_REG_ENTRY sInitProvider
;
129 CRYPT_TRUST_REG_ENTRY sObjectProvider
;
130 CRYPT_TRUST_REG_ENTRY sSignatureProvider
;
131 CRYPT_TRUST_REG_ENTRY sCertificateProvider
;
132 CRYPT_TRUST_REG_ENTRY sCertificatePolicyProvider
;
133 CRYPT_TRUST_REG_ENTRY sFinalPolicyProvider
;
134 CRYPT_TRUST_REG_ENTRY sTestPolicyProvider
;
135 CRYPT_TRUST_REG_ENTRY sCleanupProvider
;
136 } CRYPT_REGISTER_ACTIONID
, *PCRYPT_REGISTER_ACTIONID
;
138 typedef struct _CRYPT_PROVIDER_REGDEFUSAGE
143 char *pwszLoadCallbackDataFunctionName
;
144 char *pwszFreeCallbackDataFunctionName
;
145 } CRYPT_PROVIDER_REGDEFUSAGE
, *PCRYPT_PROVIDER_REGDEFUSAGE
;
147 typedef struct _CRYPT_PROVUI_DATA
{
150 WCHAR
*pYesButtonText
;
151 WCHAR
*pNoButtonText
;
152 WCHAR
*pMoreInfoButtonText
;
153 WCHAR
*pAdvancedLinkText
;
154 WCHAR
*pCopyActionText
;
155 WCHAR
*pCopyActionTextNoTS
;
156 WCHAR
*pCopyActionTextNotSigned
;
157 } CRYPT_PROVUI_DATA
, *PCRYPT_PROVUI_DATA
;
159 typedef struct _CRYPT_PROVIDER_CERT
{
161 PCCERT_CONTEXT pCert
;
166 DWORD dwRevokedReason
;
169 CTL_CONTEXT
*pTrustListContext
;
170 BOOL fTrustListSignerCert
;
171 PCCTL_CONTEXT pCtlContext
;
174 PCERT_CHAIN_ELEMENT pChainElement
;
175 } CRYPT_PROVIDER_CERT
, *PCRYPT_PROVIDER_CERT
;
177 typedef struct _CRYPT_PROVIDER_SGNR
{
179 FILETIME sftVerifyAsOf
;
181 CRYPT_PROVIDER_CERT
*pasCertChain
;
183 CMSG_SIGNER_INFO
*psSigner
;
185 DWORD csCounterSigners
;
186 struct _CRYPT_PROVIDER_SGNR
*pasCounterSigners
;
187 PCCERT_CHAIN_CONTEXT pChainContext
;
188 } CRYPT_PROVIDER_SGNR
, *PCRYPT_PROVIDER_SGNR
;
190 typedef struct _CRYPT_PROVIDER_PRIVDATA
{
195 } CRYPT_PROVIDER_PRIVDATA
, *PCRYPT_PROVIDER_PRIVDATA
;
197 struct _CRYPT_PROVIDER_DATA
;
199 typedef void * (*PFN_CPD_MEM_ALLOC
)(DWORD cbSize
);
200 typedef void (*PFN_CPD_MEM_FREE
)(void *pvMem2Free
);
201 typedef BOOL (*PFN_CPD_ADD_STORE
)(struct _CRYPT_PROVIDER_DATA
*pProvData
,
202 HCERTSTORE hStore2Add
);
203 typedef BOOL (*PFN_CPD_ADD_SGNR
)(struct _CRYPT_PROVIDER_DATA
*pProvData
,
204 BOOL fCounterSigner
, DWORD idxSigner
, struct _CRYPT_PROVIDER_SGNR
*pSgnr2Add
);
205 typedef BOOL (*PFN_CPD_ADD_CERT
)(struct _CRYPT_PROVIDER_DATA
*pProvData
,
206 DWORD idxSigner
, BOOL fCounterSigner
, DWORD idxCounterSigner
,
207 PCCERT_CONTEXT pCert2Add
);
208 typedef BOOL (*PFN_CPD_ADD_PRIVDATA
)(struct _CRYPT_PROVIDER_DATA
*pProvData
,
209 struct _CRYPT_PROVIDER_PRIVDATA
*pPrivData2Add
);
210 typedef HRESULT (*PFN_PROVIDER_INIT_CALL
)(
211 struct _CRYPT_PROVIDER_DATA
*pProvData
);
212 typedef HRESULT (*PFN_PROVIDER_OBJTRUST_CALL
)(
213 struct _CRYPT_PROVIDER_DATA
*pProvData
);
214 typedef HRESULT (*PFN_PROVIDER_SIGTRUST_CALL
)(
215 struct _CRYPT_PROVIDER_DATA
*pProvData
);
216 typedef HRESULT (*PFN_PROVIDER_CERTTTRUST_CALL
)(
217 struct _CRYPT_PROVIDER_DATA
*pProvData
);
218 typedef HRESULT (*PFN_PROVIDER_FINALPOLICY_CALL
)(
219 struct _CRYPT_PROVIDER_DATA
*pProvData
);
220 typedef HRESULT (*PFN_PROVIDER_TESTFINALPOLICY_CALL
)(
221 struct _CRYPT_PROVIDER_DATA
*pProvData
);
222 typedef HRESULT (*PFN_PROVIDER_CLEANUP_CALL
)(
223 struct _CRYPT_PROVIDER_DATA
*pProvData
);
224 typedef BOOL (*PFN_PROVIDER_CERTCHKPOLICY_CALL
)(
225 struct _CRYPT_PROVIDER_DATA
*pProvData
, DWORD idxSigner
,
226 BOOL fCounterSignerChain
, DWORD idxCounterSigner
);
228 typedef struct _CRYPT_PROVIDER_FUNCTIONS
{
230 PFN_CPD_MEM_ALLOC pfnAlloc
;
231 PFN_CPD_MEM_FREE pfnFree
;
232 PFN_CPD_ADD_STORE pfnAddStore2Chain
;
233 PFN_CPD_ADD_SGNR pfnAddSgnr2Chain
;
234 PFN_CPD_ADD_CERT pfnAddCert2Chain
;
235 PFN_CPD_ADD_PRIVDATA pfnAddPrivData2Chain
;
236 PFN_PROVIDER_INIT_CALL pfnInitialize
;
237 PFN_PROVIDER_OBJTRUST_CALL pfnObjectTrust
;
238 PFN_PROVIDER_SIGTRUST_CALL pfnSignatureTrust
;
239 PFN_PROVIDER_CERTTTRUST_CALL pfnCertificateTrust
;
240 PFN_PROVIDER_FINALPOLICY_CALL pfnFinalPolicy
;
241 PFN_PROVIDER_CERTCHKPOLICY_CALL pfnCertCheckPolicy
;
242 PFN_PROVIDER_TESTFINALPOLICY_CALL pfnTestFinalPolicy
;
243 struct _CRYPT_PROVUI_FUNCS
*psUIpfns
;
244 PFN_PROVIDER_CLEANUP_CALL pfnCleanupPolicy
;
245 } CRYPT_PROVIDER_FUNCTIONS
, *PCRYPT_PROVIDER_FUNCTIONS
;
247 struct SIP_DISPATCH_INFO_
;
248 struct SIP_SUBJECTINFO_
;
249 struct SIP_INDIRECT_DATA_
;
251 typedef struct _PROVDATA_SIP
{
254 struct SIP_DISPATCH_INFO_
*pSip
;
255 struct SIP_DISPATCH_INFO_
*pCATSip
;
256 struct SIP_SUBJECTINFO_
*psSipSubjectInfo
;
257 struct SIP_SUBJECTINFO_
*psSipCATSubjectInfo
;
258 struct SIP_INDIRECT_DATA_
*psIndirectData
;
259 } PROVDATA_SIP
, *PPROVDATA_SIP
;
261 typedef struct _CRYPT_PROVIDER_DATA
{
263 WINTRUST_DATA
*pWintrustData
;
269 DWORD dwRegSecuritySettings
;
270 DWORD dwRegPolicySettings
;
271 CRYPT_PROVIDER_FUNCTIONS
*psPfns
;
272 DWORD cdwTrustStepErrors
;
273 DWORD
*padwTrustStepErrors
;
275 HCERTSTORE
*pahStores
;
279 CRYPT_PROVIDER_SGNR
*pasSigners
;
280 DWORD dwSubjectChoice
;
282 struct _PROVDATA_SIP
*pPDSip
;
285 BOOL fRecallWithState
;
286 FILETIME sftSystemTime
;
287 char *pszCTLSignerUsageOID
;
290 PCERT_USAGE_MATCH pRequestUsage
;
291 DWORD dwTrustPubSettings
;
292 DWORD dwUIStateFlags
;
293 } CRYPT_PROVIDER_DATA
, *PCRYPT_PROVIDER_DATA
;
295 typedef BOOL (*PFN_PROVUI_CALL
)(HWND hWndSecurityDialog
,
296 struct _CRYPT_PROVIDER_DATA
*pProvData
);
298 typedef struct _CRYPT_PROVUI_FUNCS
{
300 CRYPT_PROVUI_DATA psUIData
;
301 PFN_PROVUI_CALL pfnOnMoreInfoClick
;
302 PFN_PROVUI_CALL pfnOnMoreInfoClickDefault
;
303 PFN_PROVUI_CALL pfnOnAdvancedClick
;
304 PFN_PROVUI_CALL pfnOnAdvancedClickDefault
;
305 } CRYPT_PROVUI_FUNCS
, *PCRYPT_PROVUI_FUNCS
;
309 #define WT_ADD_ACTION_ID_RET_RESULT_FLAG 1
315 #if defined(__GNUC__)
316 #define WT_PROVIDER_CERTTRUST_FUNCTION (const WCHAR []) \
317 {'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}
318 #elif defined(_MSC_VER)
319 #define WT_PROVIDER_CERTTRUST_FUNCTION L"WintrustCertificateTrust"
321 static const WCHAR WT_PROVIDER_CERTTRUST_FUNCTION
[] = \
322 {'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};
325 BOOL WINAPI
WintrustAddActionID(GUID
*,DWORD
,CRYPT_REGISTER_ACTIONID
*);
326 BOOL WINAPI
WintrustRemoveActionID(GUID
*);
327 BOOL WINAPI
WintrustLoadFunctionPointers(GUID
*,CRYPT_PROVIDER_FUNCTIONS
*);
328 BOOL WINAPI
WintrustAddDefaultForUsage(const CHAR
*,CRYPT_PROVIDER_REGDEFUSAGE
*);
329 void WINAPI
WintrustGetRegPolicyFlags(DWORD
*);
330 LONG WINAPI
WinVerifyTrust(HWND
,GUID
*,LPVOID
);
331 HRESULT WINAPI
WinVerifyTrustEx(HWND
,GUID
*,WINTRUST_DATA
*);
333 CRYPT_PROVIDER_SGNR
* WINAPI
WTHelperGetProvSignerFromChain(
334 CRYPT_PROVIDER_DATA
*pProvData
, DWORD idxSigner
, BOOL fCounterSigner
,
335 DWORD idxCounterSigner
);
336 CRYPT_PROVIDER_DATA
* WINAPI
WTHelperProvDataFromStateData(HANDLE hStateData
);
338 #define SPC_INDIRECT_DATA_OBJID "1.3.6.1.4.1.311.2.1.4"
339 #define SPC_SP_AGENCY_INFO_OBJID "1.3.6.1.4.1.311.2.1.10"
340 #define SPC_STATEMENT_TYPE_OBJID "1.3.6.1.4.1.311.2.1.11"
341 #define SPC_SP_OPUS_INFO_OBJID "1.3.6.1.4.1.311.2.1.12"
342 #define SPC_PE_IMAGE_DATA_OBJID "1.3.6.1.4.1.311.2.1.15"
343 #define SPC_JAVA_CLASS_DATA_OBJID "1.3.6.1.4.1.311.2.1.20"
344 #define SPC_CAB_DATA_OBJID "1.3.6.1.4.1.311.2.1.25"
345 #define SPC_MINIMAL_CRITERIA_OBJID "1.3.6.1.4.1.311.2.1.26"
346 #define SPC_FINANCIAL_CRITERIA_OBJID "1.3.6.1.4.1.311.2.1.27"
347 #define SPC_LINK_OBJID "1.3.6.1.4.1.311.2.1.28"
348 #define SPC_SIGINFO_OBJID "1.3.6.1.4.1.311.2.1.30"
349 #define CAT_NAMEVALUE_OBJID "1.3.6.1.4.1.311.12.2.1"
350 #define CAT_MEMBERINFO_OBJID "1.3.6.1.4.1.311.12.2.2"
352 #define SPC_SP_AGENCY_INFO_STRUCT ((LPCSTR) 2000)
353 #define SPC_MINIMAL_CRITERIA_STRUCT ((LPCSTR) 2001)
354 #define SPC_FINANCIAL_CRITERIA_STRUCT ((LPCSTR) 2002)
355 #define SPC_INDIRECT_DATA_CONTENT_STRUCT ((LPCSTR) 2003)
356 #define SPC_PE_IMAGE_DATA_STRUCT ((LPCSTR) 2004)
357 #define SPC_LINK_STRUCT ((LPCSTR) 2005)
358 #define SPC_STATEMENT_TYPE_STRUCT ((LPCSTR) 2006)
359 #define SPC_SP_OPUS_INFO_STRUCT ((LPCSTR) 2007)
360 #define SPC_CAB_DATA_STRUCT ((LPCSTR) 2008)
361 #define SPC_JAVA_CLASS_DATA_STRUCT ((LPCSTR) 2009)
362 #define SPC_SIGINFO_STRUCT ((LPCSTR) 2130)
363 #define CAT_NAMEVALUE_STRUCT ((LPCSTR) 2221)
364 #define CAT_MEMBERINFO_STRUCT ((LPCSTR) 2222)
366 #define WIN_SPUB_ACTION_PUBLISHED_SOFTWARE \
367 { 0x64b9d180, 0x8da2, 0x11cf, { 0x87,0x36,0x00,0xaa,0x00,0xa4,0x85,0xeb }}