23#include <winpr/platform.h>
24#include <winpr/winpr.h>
25#include <winpr/cast.h>
26#include <winpr/wtypes.h>
27#include <winpr/windows.h>
28#include <winpr/security.h>
41#if !defined(_WIN32) || defined(_UWP)
48typedef WCHAR SEC_WCHAR;
60WINPR_PRAGMA_DIAG_IGNORED_RESERVED_ID_MACRO
62#ifndef __SECSTATUS_DEFINED__
63typedef LONG SECURITY_STATUS;
65#define __SECSTATUS_DEFINED__
93#define SecPkgInfo SecPkgInfoW
94#define PSecPkgInfo PSecPkgInfoW
96#define SecPkgInfo SecPkgInfoA
97#define PSecPkgInfo PSecPkgInfoA
102#define NTLM_SSP_NAME _T("NTLM")
103#define KERBEROS_SSP_NAME _T("Kerberos")
104#define NEGO_SSP_NAME _T("Negotiate")
106#define SECPKG_ID_NONE 0xFFFF
108#define SECPKG_FLAG_INTEGRITY 0x00000001
109#define SECPKG_FLAG_PRIVACY 0x00000002
110#define SECPKG_FLAG_TOKEN_ONLY 0x00000004
111#define SECPKG_FLAG_DATAGRAM 0x00000008
112#define SECPKG_FLAG_CONNECTION 0x00000010
113#define SECPKG_FLAG_MULTI_REQUIRED 0x00000020
114#define SECPKG_FLAG_CLIENT_ONLY 0x00000040
115#define SECPKG_FLAG_EXTENDED_ERROR 0x00000080
116#define SECPKG_FLAG_IMPERSONATION 0x00000100
117#define SECPKG_FLAG_ACCEPT_WIN32_NAME 0x00000200
118#define SECPKG_FLAG_STREAM 0x00000400
119#define SECPKG_FLAG_NEGOTIABLE 0x00000800
120#define SECPKG_FLAG_GSS_COMPATIBLE 0x00001000
121#define SECPKG_FLAG_LOGON 0x00002000
122#define SECPKG_FLAG_ASCII_BUFFERS 0x00004000
123#define SECPKG_FLAG_FRAGMENT 0x00008000
124#define SECPKG_FLAG_MUTUAL_AUTH 0x00010000
125#define SECPKG_FLAG_DELEGATION 0x00020000
126#define SECPKG_FLAG_READONLY_WITH_CHECKSUM 0x00040000
127#define SECPKG_FLAG_RESTRICTED_TOKENS 0x00080000
128#define SECPKG_FLAG_NEGO_EXTENDER 0x00100000
129#define SECPKG_FLAG_NEGOTIABLE2 0x00200000
133#define SEC_E_OK WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00000000)
134#define SEC_E_INSUFFICIENT_MEMORY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090300)
135#define SEC_E_INVALID_HANDLE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090301)
136#define SEC_E_UNSUPPORTED_FUNCTION WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090302)
137#define SEC_E_TARGET_UNKNOWN WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090303)
138#define SEC_E_INTERNAL_ERROR WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090304)
139#define SEC_E_SECPKG_NOT_FOUND WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090305)
140#define SEC_E_NOT_OWNER WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090306)
141#define SEC_E_CANNOT_INSTALL WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090307)
142#define SEC_E_INVALID_TOKEN WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090308)
143#define SEC_E_CANNOT_PACK WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090309)
144#define SEC_E_QOP_NOT_SUPPORTED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009030A)
145#define SEC_E_NO_IMPERSONATION WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009030B)
146#define SEC_E_LOGON_DENIED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009030C)
147#define SEC_E_UNKNOWN_CREDENTIALS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009030D)
148#define SEC_E_NO_CREDENTIALS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009030E)
149#define SEC_E_MESSAGE_ALTERED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009030F)
150#define SEC_E_OUT_OF_SEQUENCE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090310)
151#define SEC_E_NO_AUTHENTICATING_AUTHORITY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090311)
152#define SEC_E_BAD_PKGID WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090316)
153#define SEC_E_CONTEXT_EXPIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090317)
154#define SEC_E_INCOMPLETE_MESSAGE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090318)
155#define SEC_E_INCOMPLETE_CREDENTIALS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090320)
156#define SEC_E_BUFFER_TOO_SMALL WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090321)
157#define SEC_E_WRONG_PRINCIPAL WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090322)
158#define SEC_E_TIME_SKEW WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090324)
159#define SEC_E_UNTRUSTED_ROOT WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090325)
160#define SEC_E_ILLEGAL_MESSAGE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090326)
161#define SEC_E_CERT_UNKNOWN WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090327)
162#define SEC_E_CERT_EXPIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090328)
163#define SEC_E_ENCRYPT_FAILURE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090329)
164#define SEC_E_DECRYPT_FAILURE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090330)
165#define SEC_E_ALGORITHM_MISMATCH WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090331)
166#define SEC_E_SECURITY_QOS_FAILED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090332)
167#define SEC_E_UNFINISHED_CONTEXT_DELETED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090333)
168#define SEC_E_NO_TGT_REPLY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090334)
169#define SEC_E_NO_IP_ADDRESSES WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090335)
170#define SEC_E_WRONG_CREDENTIAL_HANDLE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090336)
171#define SEC_E_CRYPTO_SYSTEM_INVALID WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090337)
172#define SEC_E_MAX_REFERRALS_EXCEEDED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090338)
173#define SEC_E_MUST_BE_KDC WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090339)
174#define SEC_E_STRONG_CRYPTO_NOT_SUPPORTED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009033A)
175#define SEC_E_TOO_MANY_PRINCIPALS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009033B)
176#define SEC_E_NO_PA_DATA WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009033C)
177#define SEC_E_PKINIT_NAME_MISMATCH WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009033D)
178#define SEC_E_SMARTCARD_LOGON_REQUIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009033E)
179#define SEC_E_SHUTDOWN_IN_PROGRESS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009033F)
180#define SEC_E_KDC_INVALID_REQUEST WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090340)
181#define SEC_E_KDC_UNABLE_TO_REFER WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090341)
182#define SEC_E_KDC_UNKNOWN_ETYPE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090342)
183#define SEC_E_UNSUPPORTED_PREAUTH WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090343)
184#define SEC_E_DELEGATION_REQUIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090345)
185#define SEC_E_BAD_BINDINGS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090346)
186#define SEC_E_MULTIPLE_ACCOUNTS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090347)
187#define SEC_E_NO_KERB_KEY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090348)
188#define SEC_E_CERT_WRONG_USAGE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090349)
189#define SEC_E_DOWNGRADE_DETECTED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090350)
190#define SEC_E_SMARTCARD_CERT_REVOKED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090351)
191#define SEC_E_ISSUING_CA_UNTRUSTED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090352)
192#define SEC_E_REVOCATION_OFFLINE_C WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090353)
193#define SEC_E_PKINIT_CLIENT_FAILURE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090354)
194#define SEC_E_SMARTCARD_CERT_EXPIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090355)
195#define SEC_E_NO_S4U_PROT_SUPPORT WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090356)
196#define SEC_E_CROSSREALM_DELEGATION_FAILURE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090357)
197#define SEC_E_REVOCATION_OFFLINE_KDC WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090358)
198#define SEC_E_ISSUING_CA_UNTRUSTED_KDC WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090359)
199#define SEC_E_KDC_CERT_EXPIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035A)
200#define SEC_E_KDC_CERT_REVOKED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035B)
201#define SEC_E_INVALID_PARAMETER WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035D)
202#define SEC_E_DELEGATION_POLICY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035E)
203#define SEC_E_POLICY_NLTM_ONLY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035F)
204#define SEC_E_NO_CONTEXT WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090361)
205#define SEC_E_PKU2U_CERT_FAILURE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090362)
206#define SEC_E_MUTUAL_AUTH_FAILED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090363)
208#define SEC_I_CONTINUE_NEEDED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090312)
209#define SEC_I_COMPLETE_NEEDED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090313)
210#define SEC_I_COMPLETE_AND_CONTINUE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090314)
211#define SEC_I_LOCAL_LOGON WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090315)
212#define SEC_I_CONTEXT_EXPIRED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090317)
213#define SEC_I_INCOMPLETE_CREDENTIALS WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090320)
214#define SEC_I_RENEGOTIATE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090321)
215#define SEC_I_NO_LSA_CONTEXT WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090323)
216#define SEC_I_SIGNATURE_NEEDED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x0009035C)
217#define SEC_I_NO_RENEGOTIATION WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090360)
222#ifndef SEC_E_INVALID_PARAMETER
223#define SEC_E_INVALID_PARAMETER WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035D)
226#ifndef SEC_E_DELEGATION_POLICY
227#define SEC_E_DELEGATION_POLICY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035E)
230#ifndef SEC_E_POLICY_NLTM_ONLY
231#define SEC_E_POLICY_NLTM_ONLY WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x8009035F)
234#ifndef SEC_E_NO_CONTEXT
235#define SEC_E_NO_CONTEXT WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090361)
238#ifndef SEC_E_PKU2U_CERT_FAILURE
239#define SEC_E_PKU2U_CERT_FAILURE WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090362)
242#ifndef SEC_E_MUTUAL_AUTH_FAILED
243#define SEC_E_MUTUAL_AUTH_FAILED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x80090363)
246#ifndef SEC_I_SIGNATURE_NEEDED
247#define SEC_I_SIGNATURE_NEEDED WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x0009035C)
250#ifndef SEC_I_NO_RENEGOTIATION
251#define SEC_I_NO_RENEGOTIATION WINPR_CXX_COMPAT_CAST(SECURITY_STATUS, 0x00090360)
256#define SECURITY_NATIVE_DREP 0x00000010
257#define SECURITY_NETWORK_DREP 0x00000000
259#define SECPKG_CRED_INBOUND 0x00000001
260#define SECPKG_CRED_OUTBOUND 0x00000002
261#define SECPKG_CRED_BOTH 0x00000003
262#define SECPKG_CRED_AUTOLOGON_RESTRICTED 0x00000010
263#define SECPKG_CRED_PROCESS_POLICY_ONLY 0x00000020
267#define SECPKG_ATTR_SIZES 0
268#define SECPKG_ATTR_NAMES 1
269#define SECPKG_ATTR_LIFESPAN 2
270#define SECPKG_ATTR_DCE_INFO 3
271#define SECPKG_ATTR_STREAM_SIZES 4
272#define SECPKG_ATTR_KEY_INFO 5
273#define SECPKG_ATTR_AUTHORITY 6
274#define SECPKG_ATTR_PROTO_INFO 7
275#define SECPKG_ATTR_PASSWORD_EXPIRY 8
276#define SECPKG_ATTR_SESSION_KEY 9
277#define SECPKG_ATTR_PACKAGE_INFO 10
278#define SECPKG_ATTR_USER_FLAGS 11
279#define SECPKG_ATTR_NEGOTIATION_INFO 12
280#define SECPKG_ATTR_NATIVE_NAMES 13
281#define SECPKG_ATTR_FLAGS 14
282#define SECPKG_ATTR_USE_VALIDATED 15
283#define SECPKG_ATTR_CREDENTIAL_NAME 16
284#define SECPKG_ATTR_TARGET_INFORMATION 17
285#define SECPKG_ATTR_ACCESS_TOKEN 18
286#define SECPKG_ATTR_TARGET 19
287#define SECPKG_ATTR_AUTHENTICATION_ID 20
288#define SECPKG_ATTR_LOGOFF_TIME 21
289#define SECPKG_ATTR_NEGO_KEYS 22
290#define SECPKG_ATTR_PROMPTING_NEEDED 24
291#define SECPKG_ATTR_UNIQUE_BINDINGS 25
292#define SECPKG_ATTR_ENDPOINT_BINDINGS 26
293#define SECPKG_ATTR_CLIENT_SPECIFIED_TARGET 27
294#define SECPKG_ATTR_LAST_CLIENT_TOKEN_STATUS 30
295#define SECPKG_ATTR_NEGO_PKG_INFO 31
296#define SECPKG_ATTR_NEGO_STATUS 32
297#define SECPKG_ATTR_CONTEXT_DELETED 33
299#if !defined(_WIN32) || defined(_UWP)
315 char* sAuthorityName;
323typedef UINT32 ALG_ID;
329 UINT32 dwCipherStrength;
331 UINT32 dwHashStrength;
333 UINT32 dwExchStrength;
338 UINT32 AuthBufferLen;
350 UINT32 dwInitiatorAddrType;
351 UINT32 cbInitiatorLength;
352 UINT32 dwInitiatorOffset;
353 UINT32 dwAcceptorAddrType;
354 UINT32 cbAcceptorLength;
355 UINT32 dwAcceptorOffset;
356 UINT32 cbApplicationDataLength;
357 UINT32 dwApplicationDataOffset;
373 char* sSignatureAlgorithmName;
374 char* sEncryptAlgorithmName;
376 UINT32 SignatureAlgorithm;
377 UINT32 EncryptAlgorithm;
399 SecPkgInfo* PackageInfo;
400 UINT32 NegotiationState;
405 SecPkgInfo* PackageInfo;
415 UINT32 SessionKeyLength;
423 BYTE rgbSessionId[32];
429 UINT32 cbMaxSignature;
431 UINT32 cbSecurityTrailer;
438 UINT32 cbMaximumMessage;
450 UINT16 cSignatureAndHashAlgorithms;
451 UINT16* pSignatureAndHashAlgorithms;
456 UINT32 MarshalledTargetInfoLength;
457 BYTE* MarshalledTargetInfo;
462#define SECPKG_CRED_ATTR_NAMES 1
463#define SECPKG_CRED_ATTR_SSI_PROVIDER 2
464#define SECPKG_CRED_ATTR_CERT 4
465#define SECPKG_CRED_ATTR_PAC_BYPASS 5
475 SEC_WCHAR* sUserName;
480#define SecPkgCredentials_Names SecPkgCredentials_NamesW
481#define PSecPkgCredentials_Names PSecPkgCredentials_NamesW
483#define SecPkgCredentials_Names SecPkgCredentials_NamesA
484#define PSecPkgCredentials_Names PSecPkgCredentials_NamesA
489 SEC_WCHAR* sProviderName;
490 unsigned long ProviderInfoLength;
496 SEC_CHAR* sProviderName;
497 unsigned long ProviderInfoLength;
502#define SecPkgCredentials_SSIProvider SecPkgCredentials_SSIProviderW
503#define PSecPkgCredentials_SSIProvider PSecPkgCredentials_SSIProviderW
505#define SecPkgCredentials_SSIProvider SecPkgCredentials_SSIProviderA
506#define PSecPkgCredentials_SSIProvider PSecPkgCredentials_SSIProviderA
511 unsigned long EncodedCertSize;
512 unsigned char* EncodedCert;
517#if !defined(_WIN32) || defined(_UWP) || (defined(__MINGW32__) && (__MINGW64_VERSION_MAJOR <= 8))
519#define SECPKG_CRED_ATTR_KDC_PROXY_SETTINGS 3
521#define KDC_PROXY_SETTINGS_V1 1
522#define KDC_PROXY_SETTINGS_FLAGS_FORCEPROXY 0x1
528 USHORT ProxyServerOffset;
529 USHORT ProxyServerLength;
530 USHORT ClientTlsCredOffset;
531 USHORT ClientTlsCredLength;
538 USHORT ProxyServerOffset;
539 USHORT ProxyServerLength;
540 USHORT ClientTlsCredOffset;
541 USHORT ClientTlsCredLength;
545#define SecPkgCredentials_KdcProxySettings SecPkgCredentials_KdcProxySettingsW
546#define PSecPkgCredentials_KdcProxySettings PSecPkgCredentials_KdcProxySettingsW
548#define SecPkgCredentials_KdcProxySettings SecPkgCredentials_KdcProxySettingsA
549#define PSecPkgCredentials_KdcProxySettings SecPkgCredentials_KdcProxySettingsA
554 UINT32 BindingsLength;
561#define ISC_REQ_DELEGATE 0x00000001
562#define ISC_REQ_MUTUAL_AUTH 0x00000002
563#define ISC_REQ_REPLAY_DETECT 0x00000004
564#define ISC_REQ_SEQUENCE_DETECT 0x00000008
565#define ISC_REQ_CONFIDENTIALITY 0x00000010
566#define ISC_REQ_USE_SESSION_KEY 0x00000020
567#define ISC_REQ_PROMPT_FOR_CREDS 0x00000040
568#define ISC_REQ_USE_SUPPLIED_CREDS 0x00000080
569#define ISC_REQ_ALLOCATE_MEMORY 0x00000100
570#define ISC_REQ_USE_DCE_STYLE 0x00000200
571#define ISC_REQ_DATAGRAM 0x00000400
572#define ISC_REQ_CONNECTION 0x00000800
573#define ISC_REQ_CALL_LEVEL 0x00001000
574#define ISC_REQ_FRAGMENT_SUPPLIED 0x00002000
575#define ISC_REQ_EXTENDED_ERROR 0x00004000
576#define ISC_REQ_STREAM 0x00008000
577#define ISC_REQ_INTEGRITY 0x00010000
578#define ISC_REQ_IDENTIFY 0x00020000
579#define ISC_REQ_NULL_SESSION 0x00040000
580#define ISC_REQ_MANUAL_CRED_VALIDATION 0x00080000
581#define ISC_REQ_RESERVED1 0x00100000
582#define ISC_REQ_FRAGMENT_TO_FIT 0x00200000
583#define ISC_REQ_FORWARD_CREDENTIALS 0x00400000
584#define ISC_REQ_NO_INTEGRITY 0x00800000
585#define ISC_REQ_USE_HTTP_STYLE 0x01000000
587#define ISC_RET_DELEGATE 0x00000001
588#define ISC_RET_MUTUAL_AUTH 0x00000002
589#define ISC_RET_REPLAY_DETECT 0x00000004
590#define ISC_RET_SEQUENCE_DETECT 0x00000008
591#define ISC_RET_CONFIDENTIALITY 0x00000010
592#define ISC_RET_USE_SESSION_KEY 0x00000020
593#define ISC_RET_USED_COLLECTED_CREDS 0x00000040
594#define ISC_RET_USED_SUPPLIED_CREDS 0x00000080
595#define ISC_RET_ALLOCATED_MEMORY 0x00000100
596#define ISC_RET_USED_DCE_STYLE 0x00000200
597#define ISC_RET_DATAGRAM 0x00000400
598#define ISC_RET_CONNECTION 0x00000800
599#define ISC_RET_INTERMEDIATE_RETURN 0x00001000
600#define ISC_RET_CALL_LEVEL 0x00002000
601#define ISC_RET_EXTENDED_ERROR 0x00004000
602#define ISC_RET_STREAM 0x00008000
603#define ISC_RET_INTEGRITY 0x00010000
604#define ISC_RET_IDENTIFY 0x00020000
605#define ISC_RET_NULL_SESSION 0x00040000
606#define ISC_RET_MANUAL_CRED_VALIDATION 0x00080000
607#define ISC_RET_RESERVED1 0x00100000
608#define ISC_RET_FRAGMENT_ONLY 0x00200000
609#define ISC_RET_FORWARD_CREDENTIALS 0x00400000
610#define ISC_RET_USED_HTTP_STYLE 0x01000000
614#define ASC_REQ_DELEGATE 0x00000001
615#define ASC_REQ_MUTUAL_AUTH 0x00000002
616#define ASC_REQ_REPLAY_DETECT 0x00000004
617#define ASC_REQ_SEQUENCE_DETECT 0x00000008
618#define ASC_REQ_CONFIDENTIALITY 0x00000010
619#define ASC_REQ_USE_SESSION_KEY 0x00000020
620#define ASC_REQ_ALLOCATE_MEMORY 0x00000100
621#define ASC_REQ_USE_DCE_STYLE 0x00000200
622#define ASC_REQ_DATAGRAM 0x00000400
623#define ASC_REQ_CONNECTION 0x00000800
624#define ASC_REQ_CALL_LEVEL 0x00001000
625#define ASC_REQ_EXTENDED_ERROR 0x00008000
626#define ASC_REQ_STREAM 0x00010000
627#define ASC_REQ_INTEGRITY 0x00020000
628#define ASC_REQ_LICENSING 0x00040000
629#define ASC_REQ_IDENTIFY 0x00080000
630#define ASC_REQ_ALLOW_NULL_SESSION 0x00100000
631#define ASC_REQ_ALLOW_NON_USER_LOGONS 0x00200000
632#define ASC_REQ_ALLOW_CONTEXT_REPLAY 0x00400000
633#define ASC_REQ_FRAGMENT_TO_FIT 0x00800000
634#define ASC_REQ_FRAGMENT_SUPPLIED 0x00002000
635#define ASC_REQ_NO_TOKEN 0x01000000
636#define ASC_REQ_PROXY_BINDINGS 0x04000000
637#define ASC_REQ_ALLOW_MISSING_BINDINGS 0x10000000
639#define ASC_RET_DELEGATE 0x00000001
640#define ASC_RET_MUTUAL_AUTH 0x00000002
641#define ASC_RET_REPLAY_DETECT 0x00000004
642#define ASC_RET_SEQUENCE_DETECT 0x00000008
643#define ASC_RET_CONFIDENTIALITY 0x00000010
644#define ASC_RET_USE_SESSION_KEY 0x00000020
645#define ASC_RET_ALLOCATED_MEMORY 0x00000100
646#define ASC_RET_USED_DCE_STYLE 0x00000200
647#define ASC_RET_DATAGRAM 0x00000400
648#define ASC_RET_CONNECTION 0x00000800
649#define ASC_RET_CALL_LEVEL 0x00002000
650#define ASC_RET_THIRD_LEG_FAILED 0x00004000
651#define ASC_RET_EXTENDED_ERROR 0x00008000
652#define ASC_RET_STREAM 0x00010000
653#define ASC_RET_INTEGRITY 0x00020000
654#define ASC_RET_LICENSING 0x00040000
655#define ASC_RET_IDENTIFY 0x00080000
656#define ASC_RET_NULL_SESSION 0x00100000
657#define ASC_RET_ALLOW_NON_USER_LOGONS 0x00200000
658#define ASC_RET_FRAGMENT_ONLY 0x00800000
659#define ASC_RET_NO_TOKEN 0x01000000
660#define ASC_RET_NO_PROXY_BINDINGS 0x04000000
661#define ASC_RET_MISSING_BINDINGS 0x10000000
663#define SEC_WINNT_AUTH_IDENTITY_ANSI 0x1
664#define SEC_WINNT_AUTH_IDENTITY_UNICODE 0x2
665#define SEC_WINNT_AUTH_IDENTITY_MARSHALLED 0x4
666#define SEC_WINNT_AUTH_IDENTITY_ONLY 0x8
667#define SEC_WINNT_AUTH_IDENTITY_EXTENDED 0x100
669#define SEC_WINPR_AUTH_IDENTITY_PASSWORD_HASH 0x00800000
671#if !defined(_WIN32) || defined(_UWP) || defined(__MINGW32__)
673WINPR_PRAGMA_DIAG_PUSH
674WINPR_PRAGMA_DIAG_IGNORED_RESERVED_ID_MACRO
676#ifndef _AUTH_IDENTITY_DEFINED
678#define _AUTH_IDENTITY_DEFINED
687 ULONG PasswordLength;
698 ULONG PasswordLength;
705#define SEC_WINNT_AUTH_IDENTITY SEC_WINNT_AUTH_IDENTITY_W
706#define PSEC_WINNT_AUTH_IDENTITY PSEC_WINNT_AUTH_IDENTITY_W
708#define SEC_WINNT_AUTH_IDENTITY SEC_WINNT_AUTH_IDENTITY_W
709#define PSEC_WINNT_AUTH_IDENTITY PSEC_WINNT_AUTH_IDENTITY_W
714#ifndef SEC_WINNT_AUTH_IDENTITY_VERSION
715#define SEC_WINNT_AUTH_IDENTITY_VERSION 0x200
726 UINT32 PasswordLength;
729 UINT32 PackageListLength;
741 UINT32 PasswordLength;
744 UINT32 PackageListLength;
748#define SEC_WINNT_AUTH_IDENTITY_EX SEC_WINNT_AUTH_IDENTITY_EXW
749#define PSEC_WINNT_AUTH_IDENTITY_EX PSEC_WINNT_AUTH_IDENTITY_EXW
751#define SEC_WINNT_AUTH_IDENTITY_EX SEC_WINNT_AUTH_IDENTITY_EXA
752#define PSEC_WINNT_AUTH_IDENTITY_EX PSEC_WINNT_AUTH_IDENTITY_EXA
757#ifndef SEC_WINNT_AUTH_IDENTITY_VERSION_2
758#define SEC_WINNT_AUTH_IDENTITY_VERSION_2 0x201
763 UINT16 cbHeaderLength;
764 UINT32 cbStructureLength;
769 UINT32 PackedCredentialsOffset;
770 UINT16 PackedCredentialsLength;
772 UINT32 PackageListOffset;
773 UINT16 PackageListLength;
778#ifndef _AUTH_IDENTITY_INFO_DEFINED
780#define _AUTH_IDENTITY_INFO_DEFINED
793#define SEC_WINNT_AUTH_IDENTITY_FLAGS_PROCESS_ENCRYPTED 0x10
794#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SYSTEM_PROTECTED 0x20
795#define SEC_WINNT_AUTH_IDENTITY_FLAGS_USER_PROTECTED 0x40
796#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SYSTEM_ENCRYPTED 0x80
797#define SEC_WINNT_AUTH_IDENTITY_FLAGS_RESERVED 0x10000
798#define SEC_WINNT_AUTH_IDENTITY_FLAGS_NULL_USER 0x20000
799#define SEC_WINNT_AUTH_IDENTITY_FLAGS_NULL_DOMAIN 0x40000
800#define SEC_WINNT_AUTH_IDENTITY_FLAGS_ID_PROVIDER 0x80000
802#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_USE_MASK 0xFF000000
803#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_CREDPROV_DO_NOT_SAVE 0x80000000
804#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_SAVE_CRED_CHECKED 0x40000000
805#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_NO_CHECKBOX 0x20000000
806#define SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_CREDPROV_DO_NOT_LOAD 0x10000000
808#define SEC_WINNT_AUTH_IDENTITY_FLAGS_VALID_SSPIPFC_FLAGS \
809 (SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_CREDPROV_DO_NOT_SAVE | \
810 SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_SAVE_CRED_CHECKED | \
811 SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_NO_CHECKBOX | \
812 SEC_WINNT_AUTH_IDENTITY_FLAGS_SSPIPFC_CREDPROV_DO_NOT_LOAD)
818#if !defined(__MINGW32__)
831#define SecInvalidateHandle(x) \
832 ((PSecHandle)(x))->dwLower = ((PSecHandle)(x))->dwUpper = ((ULONG_PTR)((INT_PTR)-1))
834#define SecIsValidHandle(x) \
835 ((((PSecHandle)(x))->dwLower != ((ULONG_PTR)((INT_PTR)-1))) && \
836 (((PSecHandle)(x))->dwUpper != ((ULONG_PTR)((INT_PTR)-1))))
877typedef SECURITY_STATUS (*psSspiNtlmHashCallback)(
void* client,
878 const SEC_WINNT_AUTH_IDENTITY* authIdentity,
880 const BYTE* randkey,
const BYTE* mic,
881 const SecBuffer* micvalue, BYTE* ntlmhash);
886 WINPR_ATTR_NODISCARD psSspiNtlmHashCallback
897 char* pkinitX509Anchors;
898 char* pkinitX509Identity;
913#define SECBUFFER_VERSION 0
916#define SECBUFFER_EMPTY 0
917#define SECBUFFER_DATA 1
918#define SECBUFFER_TOKEN 2
919#define SECBUFFER_PKG_PARAMS 3
920#define SECBUFFER_MISSING 4
921#define SECBUFFER_EXTRA 5
922#define SECBUFFER_STREAM_TRAILER 6
923#define SECBUFFER_STREAM_HEADER 7
924#define SECBUFFER_NEGOTIATION_INFO 8
925#define SECBUFFER_PADDING 9
926#define SECBUFFER_STREAM 10
927#define SECBUFFER_MECHLIST 11
928#define SECBUFFER_MECHLIST_SIGNATURE 12
929#define SECBUFFER_TARGET 13
930#define SECBUFFER_CHANNEL_BINDINGS 14
931#define SECBUFFER_CHANGE_PASS_RESPONSE 15
932#define SECBUFFER_TARGET_HOST 16
933#define SECBUFFER_ALERT 17
936#define SECBUFFER_ATTRMASK 0xF0000000
937#define SECBUFFER_READONLY 0x80000000
938#define SECBUFFER_READONLY_WITH_CHECKSUM 0x10000000
939#define SECBUFFER_RESERVED 0x60000000
941#if !defined(_WIN32) || defined(_UWP)
943typedef void(SEC_ENTRY* SEC_GET_KEY_FN)(
void* Arg,
void* Principal, UINT32 KeyVer,
void** Key,
944 SECURITY_STATUS* pStatus);
946typedef SECURITY_STATUS(SEC_ENTRY* ENUMERATE_SECURITY_PACKAGES_FN_A)(ULONG* pcPackages,
948typedef SECURITY_STATUS(SEC_ENTRY* ENUMERATE_SECURITY_PACKAGES_FN_W)(ULONG* pcPackages,
952#define EnumerateSecurityPackages EnumerateSecurityPackagesW
953#define ENUMERATE_SECURITY_PACKAGES_FN ENUMERATE_SECURITY_PACKAGES_FN_W
955#define EnumerateSecurityPackages EnumerateSecurityPackagesA
956#define ENUMERATE_SECURITY_PACKAGES_FN ENUMERATE_SECURITY_PACKAGES_FN_A
959typedef SECURITY_STATUS(SEC_ENTRY* QUERY_CREDENTIALS_ATTRIBUTES_FN_A)(
PCredHandle phCredential,
962typedef SECURITY_STATUS(SEC_ENTRY* QUERY_CREDENTIALS_ATTRIBUTES_FN_W)(
PCredHandle phCredential,
967#define QueryCredentialsAttributes QueryCredentialsAttributesW
968#define QUERY_CREDENTIALS_ATTRIBUTES_FN QUERY_CREDENTIALS_ATTRIBUTES_FN_W
970#define QueryCredentialsAttributes QueryCredentialsAttributesA
971#define QUERY_CREDENTIALS_ATTRIBUTES_FN QUERY_CREDENTIALS_ATTRIBUTES_FN_A
974typedef SECURITY_STATUS(SEC_ENTRY* ACQUIRE_CREDENTIALS_HANDLE_FN_A)(
975 LPSTR pszPrincipal, LPSTR pszPackage, ULONG fCredentialUse,
void* pvLogonID,
void* pAuthData,
976 SEC_GET_KEY_FN pGetKeyFn,
void* pvGetKeyArgument,
PCredHandle phCredential,
978typedef SECURITY_STATUS(SEC_ENTRY* ACQUIRE_CREDENTIALS_HANDLE_FN_W)(
979 LPWSTR pszPrincipal, LPWSTR pszPackage, ULONG fCredentialUse,
void* pvLogonID,
void* pAuthData,
980 SEC_GET_KEY_FN pGetKeyFn,
void* pvGetKeyArgument,
PCredHandle phCredential,
984#define AcquireCredentialsHandle AcquireCredentialsHandleW
985#define ACQUIRE_CREDENTIALS_HANDLE_FN ACQUIRE_CREDENTIALS_HANDLE_FN_W
987#define AcquireCredentialsHandle AcquireCredentialsHandleA
988#define ACQUIRE_CREDENTIALS_HANDLE_FN ACQUIRE_CREDENTIALS_HANDLE_FN_A
991typedef SECURITY_STATUS(SEC_ENTRY* FREE_CREDENTIALS_HANDLE_FN)(
PCredHandle phCredential);
993typedef SECURITY_STATUS(SEC_ENTRY* INITIALIZE_SECURITY_CONTEXT_FN_A)(
995 ULONG Reserved1, ULONG TargetDataRep,
PSecBufferDesc pInput, ULONG Reserved2,
997typedef SECURITY_STATUS(SEC_ENTRY* INITIALIZE_SECURITY_CONTEXT_FN_W)(
999 ULONG Reserved1, ULONG TargetDataRep,
PSecBufferDesc pInput, ULONG Reserved2,
1003#define InitializeSecurityContext InitializeSecurityContextW
1004#define INITIALIZE_SECURITY_CONTEXT_FN INITIALIZE_SECURITY_CONTEXT_FN_W
1006#define InitializeSecurityContext InitializeSecurityContextA
1007#define INITIALIZE_SECURITY_CONTEXT_FN INITIALIZE_SECURITY_CONTEXT_FN_A
1010typedef SECURITY_STATUS(SEC_ENTRY* ACCEPT_SECURITY_CONTEXT_FN)(
1015typedef SECURITY_STATUS(SEC_ENTRY* COMPLETE_AUTH_TOKEN_FN)(
PCtxtHandle phContext,
1018typedef SECURITY_STATUS(SEC_ENTRY* DELETE_SECURITY_CONTEXT_FN)(
PCtxtHandle phContext);
1020typedef SECURITY_STATUS(SEC_ENTRY* APPLY_CONTROL_TOKEN_FN)(
PCtxtHandle phContext,
1023typedef SECURITY_STATUS(SEC_ENTRY* QUERY_CONTEXT_ATTRIBUTES_FN_A)(
PCtxtHandle phContext,
1024 ULONG ulAttribute,
void* pBuffer);
1025typedef SECURITY_STATUS(SEC_ENTRY* QUERY_CONTEXT_ATTRIBUTES_FN_W)(
PCtxtHandle phContext,
1026 ULONG ulAttribute,
void* pBuffer);
1029#define QueryContextAttributes QueryContextAttributesW
1030#define QUERY_CONTEXT_ATTRIBUTES_FN QUERY_CONTEXT_ATTRIBUTES_FN_W
1032#define QueryContextAttributes QueryContextAttributesA
1033#define QUERY_CONTEXT_ATTRIBUTES_FN QUERY_CONTEXT_ATTRIBUTES_FN_A
1036typedef SECURITY_STATUS(SEC_ENTRY* IMPERSONATE_SECURITY_CONTEXT_FN)(
PCtxtHandle phContext);
1038typedef SECURITY_STATUS(SEC_ENTRY* REVERT_SECURITY_CONTEXT_FN)(
PCtxtHandle phContext);
1040typedef SECURITY_STATUS(SEC_ENTRY* MAKE_SIGNATURE_FN)(
PCtxtHandle phContext, ULONG fQOP,
1043typedef SECURITY_STATUS(SEC_ENTRY* VERIFY_SIGNATURE_FN)(
PCtxtHandle phContext,
1047typedef SECURITY_STATUS(SEC_ENTRY* FREE_CONTEXT_BUFFER_FN)(
void* pvContextBuffer);
1049typedef SECURITY_STATUS(SEC_ENTRY* QUERY_SECURITY_PACKAGE_INFO_FN_A)(SEC_CHAR* pszPackageName,
1051typedef SECURITY_STATUS(SEC_ENTRY* QUERY_SECURITY_PACKAGE_INFO_FN_W)(SEC_WCHAR* pszPackageName,
1055#define QuerySecurityPackageInfo QuerySecurityPackageInfoW
1056#define QUERY_SECURITY_PACKAGE_INFO_FN QUERY_SECURITY_PACKAGE_INFO_FN_W
1058#define QuerySecurityPackageInfo QuerySecurityPackageInfoA
1059#define QUERY_SECURITY_PACKAGE_INFO_FN QUERY_SECURITY_PACKAGE_INFO_FN_A
1062typedef SECURITY_STATUS(SEC_ENTRY* EXPORT_SECURITY_CONTEXT_FN)(
PCtxtHandle phContext, ULONG fFlags,
1066typedef SECURITY_STATUS(SEC_ENTRY* IMPORT_SECURITY_CONTEXT_FN_A)(SEC_CHAR* pszPackage,
1070typedef SECURITY_STATUS(SEC_ENTRY* IMPORT_SECURITY_CONTEXT_FN_W)(SEC_WCHAR* pszPackage,
1076#define ImportSecurityContext ImportSecurityContextW
1077#define IMPORT_SECURITY_CONTEXT_FN IMPORT_SECURITY_CONTEXT_FN_W
1079#define ImportSecurityContext ImportSecurityContextA
1080#define IMPORT_SECURITY_CONTEXT_FN IMPORT_SECURITY_CONTEXT_FN_A
1083typedef SECURITY_STATUS(SEC_ENTRY* ADD_CREDENTIALS_FN_A)(
1084 PCredHandle hCredentials, SEC_CHAR* pszPrincipal, SEC_CHAR* pszPackage, UINT32 fCredentialUse,
1085 void* pAuthData, SEC_GET_KEY_FN pGetKeyFn,
void* pvGetKeyArgument,
PTimeStamp ptsExpiry);
1086typedef SECURITY_STATUS(SEC_ENTRY* ADD_CREDENTIALS_FN_W)(
1087 PCredHandle hCredentials, SEC_WCHAR* pszPrincipal, SEC_WCHAR* pszPackage, UINT32 fCredentialUse,
1088 void* pAuthData, SEC_GET_KEY_FN pGetKeyFn,
void* pvGetKeyArgument,
PTimeStamp ptsExpiry);
1091#define AddCredentials AddCredentialsW
1092#define ADD_CREDENTIALS_FN ADD_CREDENTIALS_FN_W
1094#define AddCredentials AddCredentialsA
1095#define ADD_CREDENTIALS_FN ADD_CREDENTIALS_FN_A
1098typedef SECURITY_STATUS(SEC_ENTRY* QUERY_SECURITY_CONTEXT_TOKEN_FN)(
PCtxtHandle phContext,
1101typedef SECURITY_STATUS(SEC_ENTRY* ENCRYPT_MESSAGE_FN)(
PCtxtHandle phContext, ULONG fQOP,
1104typedef SECURITY_STATUS(SEC_ENTRY* DECRYPT_MESSAGE_FN)(
PCtxtHandle phContext,
1108typedef SECURITY_STATUS(SEC_ENTRY* SET_CONTEXT_ATTRIBUTES_FN_A)(
PCtxtHandle phContext,
1109 ULONG ulAttribute,
void* pBuffer,
1111typedef SECURITY_STATUS(SEC_ENTRY* SET_CONTEXT_ATTRIBUTES_FN_W)(
PCtxtHandle phContext,
1112 ULONG ulAttribute,
void* pBuffer,
1116#define SetContextAttributes SetContextAttributesW
1117#define SET_CONTEXT_ATTRIBUTES_FN SET_CONTEXT_ATTRIBUTES_FN_W
1119#define SetContextAttributes SetContextAttributesA
1120#define SET_CONTEXT_ATTRIBUTES_FN SET_CONTEXT_ATTRIBUTES_FN_A
1123typedef SECURITY_STATUS(SEC_ENTRY* SET_CREDENTIALS_ATTRIBUTES_FN_A)(
PCredHandle phCredential,
1125 void* pBuffer, ULONG cbBuffer);
1127typedef SECURITY_STATUS(SEC_ENTRY* SET_CREDENTIALS_ATTRIBUTES_FN_W)(
PCredHandle phCredential,
1129 void* pBuffer, ULONG cbBuffer);
1132#define SetCredentialsAttributes SetCredentialsAttributesW
1133#define SET_CREDENTIALS_ATTRIBUTES_FN SET_CREDENTIALS_ATTRIBUTES_FN_W
1135#define SetCredentialsAttributes SetCredentialsAttributesA
1136#define SET_CREDENTIALS_ATTRIBUTES_FN SET_CREDENTIALS_ATTRIBUTES_FN_A
1139#define SECURITY_SUPPORT_PROVIDER_INTERFACE_VERSION \
1141#define SECURITY_SUPPORT_PROVIDER_INTERFACE_VERSION_2 \
1143#define SECURITY_SUPPORT_PROVIDER_INTERFACE_VERSION_3 \
1145#define SECURITY_SUPPORT_PROVIDER_INTERFACE_VERSION_4 \
1151 WINPR_ATTR_NODISCARD ENUMERATE_SECURITY_PACKAGES_FN_A EnumerateSecurityPackagesA;
1152 WINPR_ATTR_NODISCARD QUERY_CREDENTIALS_ATTRIBUTES_FN_A QueryCredentialsAttributesA;
1153 WINPR_ATTR_NODISCARD ACQUIRE_CREDENTIALS_HANDLE_FN_A AcquireCredentialsHandleA;
1154 FREE_CREDENTIALS_HANDLE_FN FreeCredentialsHandle;
1156 WINPR_ATTR_NODISCARD INITIALIZE_SECURITY_CONTEXT_FN_A InitializeSecurityContextA;
1157 WINPR_ATTR_NODISCARD ACCEPT_SECURITY_CONTEXT_FN AcceptSecurityContext;
1158 WINPR_ATTR_NODISCARD COMPLETE_AUTH_TOKEN_FN CompleteAuthToken;
1159 DELETE_SECURITY_CONTEXT_FN DeleteSecurityContext;
1160 WINPR_ATTR_NODISCARD APPLY_CONTROL_TOKEN_FN ApplyControlToken;
1161 WINPR_ATTR_NODISCARD QUERY_CONTEXT_ATTRIBUTES_FN_A QueryContextAttributesA;
1162 WINPR_ATTR_NODISCARD IMPERSONATE_SECURITY_CONTEXT_FN ImpersonateSecurityContext;
1163 WINPR_ATTR_NODISCARD REVERT_SECURITY_CONTEXT_FN RevertSecurityContext;
1164 WINPR_ATTR_NODISCARD MAKE_SIGNATURE_FN MakeSignature;
1165 WINPR_ATTR_NODISCARD VERIFY_SIGNATURE_FN VerifySignature;
1166 FREE_CONTEXT_BUFFER_FN FreeContextBuffer;
1167 WINPR_ATTR_NODISCARD QUERY_SECURITY_PACKAGE_INFO_FN_A QuerySecurityPackageInfoA;
1170 WINPR_ATTR_NODISCARD EXPORT_SECURITY_CONTEXT_FN ExportSecurityContext;
1171 WINPR_ATTR_NODISCARD IMPORT_SECURITY_CONTEXT_FN_A ImportSecurityContextA;
1172 WINPR_ATTR_NODISCARD ADD_CREDENTIALS_FN_A AddCredentialsA;
1174 WINPR_ATTR_NODISCARD QUERY_SECURITY_CONTEXT_TOKEN_FN QuerySecurityContextToken;
1175 WINPR_ATTR_NODISCARD ENCRYPT_MESSAGE_FN EncryptMessage;
1176 WINPR_ATTR_NODISCARD DECRYPT_MESSAGE_FN DecryptMessage;
1177 WINPR_ATTR_NODISCARD SET_CONTEXT_ATTRIBUTES_FN_A SetContextAttributesA;
1178 WINPR_ATTR_NODISCARD SET_CREDENTIALS_ATTRIBUTES_FN_A SetCredentialsAttributesA;
1185 WINPR_ATTR_NODISCARD ENUMERATE_SECURITY_PACKAGES_FN_W EnumerateSecurityPackagesW;
1186 WINPR_ATTR_NODISCARD QUERY_CREDENTIALS_ATTRIBUTES_FN_W QueryCredentialsAttributesW;
1187 WINPR_ATTR_NODISCARD ACQUIRE_CREDENTIALS_HANDLE_FN_W AcquireCredentialsHandleW;
1188 FREE_CREDENTIALS_HANDLE_FN FreeCredentialsHandle;
1190 WINPR_ATTR_NODISCARD INITIALIZE_SECURITY_CONTEXT_FN_W InitializeSecurityContextW;
1191 WINPR_ATTR_NODISCARD ACCEPT_SECURITY_CONTEXT_FN AcceptSecurityContext;
1192 WINPR_ATTR_NODISCARD COMPLETE_AUTH_TOKEN_FN CompleteAuthToken;
1193 DELETE_SECURITY_CONTEXT_FN DeleteSecurityContext;
1194 WINPR_ATTR_NODISCARD APPLY_CONTROL_TOKEN_FN ApplyControlToken;
1195 WINPR_ATTR_NODISCARD QUERY_CONTEXT_ATTRIBUTES_FN_W QueryContextAttributesW;
1196 WINPR_ATTR_NODISCARD IMPERSONATE_SECURITY_CONTEXT_FN ImpersonateSecurityContext;
1197 WINPR_ATTR_NODISCARD REVERT_SECURITY_CONTEXT_FN RevertSecurityContext;
1198 WINPR_ATTR_NODISCARD MAKE_SIGNATURE_FN MakeSignature;
1199 WINPR_ATTR_NODISCARD VERIFY_SIGNATURE_FN VerifySignature;
1200 FREE_CONTEXT_BUFFER_FN FreeContextBuffer;
1201 WINPR_ATTR_NODISCARD QUERY_SECURITY_PACKAGE_INFO_FN_W QuerySecurityPackageInfoW;
1204 WINPR_ATTR_NODISCARD EXPORT_SECURITY_CONTEXT_FN ExportSecurityContext;
1205 WINPR_ATTR_NODISCARD IMPORT_SECURITY_CONTEXT_FN_W ImportSecurityContextW;
1206 WINPR_ATTR_NODISCARD ADD_CREDENTIALS_FN_W AddCredentialsW;
1208 WINPR_ATTR_NODISCARD QUERY_SECURITY_CONTEXT_TOKEN_FN QuerySecurityContextToken;
1209 WINPR_ATTR_NODISCARD ENCRYPT_MESSAGE_FN EncryptMessage;
1210 WINPR_ATTR_NODISCARD DECRYPT_MESSAGE_FN DecryptMessage;
1211 WINPR_ATTR_NODISCARD SET_CONTEXT_ATTRIBUTES_FN_W SetContextAttributesW;
1212 WINPR_ATTR_NODISCARD SET_CREDENTIALS_ATTRIBUTES_FN_W SetCredentialsAttributesW;
1220#define InitSecurityInterface InitSecurityInterfaceW
1221#define SecurityFunctionTable SecurityFunctionTableW
1222#define PSecurityFunctionTable PSecurityFunctionTableW
1223#define INIT_SECURITY_INTERFACE INIT_SECURITY_INTERFACE_W
1225#define InitSecurityInterface InitSecurityInterfaceA
1226#define SecurityFunctionTable SecurityFunctionTableA
1227#define PSecurityFunctionTable PSecurityFunctionTableA
1228#define INIT_SECURITY_INTERFACE INIT_SECURITY_INTERFACE_A
1240 WINPR_ATTR_NODISCARD
1241 WINPR_API SECURITY_STATUS SEC_ENTRY EnumerateSecurityPackagesA(ULONG* pcPackages,
1244 WINPR_ATTR_NODISCARD
1245 WINPR_API SECURITY_STATUS SEC_ENTRY EnumerateSecurityPackagesW(ULONG* pcPackages,
1248 WINPR_ATTR_NODISCARD
1251 WINPR_ATTR_NODISCARD
1254 WINPR_ATTR_NODISCARD
1255 WINPR_API SECURITY_STATUS SEC_ENTRY QuerySecurityPackageInfoA(SEC_CHAR* pszPackageName,
1258 WINPR_ATTR_NODISCARD
1259 WINPR_API SECURITY_STATUS SEC_ENTRY QuerySecurityPackageInfoW(SEC_WCHAR* pszPackageName,
1264 WINPR_ATTR_NODISCARD
1265 WINPR_API SECURITY_STATUS SEC_ENTRY AcquireCredentialsHandleA(
1266 SEC_CHAR* pszPrincipal, SEC_CHAR* pszPackage, ULONG fCredentialUse,
void* pvLogonID,
1267 void* pAuthData, SEC_GET_KEY_FN pGetKeyFn,
void* pvGetKeyArgument,
PCredHandle phCredential,
1270 WINPR_ATTR_NODISCARD
1271 WINPR_API SECURITY_STATUS SEC_ENTRY AcquireCredentialsHandleW(
1272 SEC_WCHAR* pszPrincipal, SEC_WCHAR* pszPackage, ULONG fCredentialUse,
void* pvLogonID,
1273 void* pAuthData, SEC_GET_KEY_FN pGetKeyFn,
void* pvGetKeyArgument,
PCredHandle phCredential,
1276 WINPR_ATTR_NODISCARD
1277 WINPR_API SECURITY_STATUS SEC_ENTRY ExportSecurityContext(
PCtxtHandle phContext, ULONG fFlags,
1281 WINPR_ATTR_NODISCARD
1282 WINPR_API SECURITY_STATUS SEC_ENTRY FreeCredentialsHandle(
PCredHandle phCredential);
1284 WINPR_ATTR_NODISCARD
1285 WINPR_API SECURITY_STATUS SEC_ENTRY ImportSecurityContextA(SEC_CHAR* pszPackage,
1290 WINPR_ATTR_NODISCARD
1291 WINPR_API SECURITY_STATUS SEC_ENTRY ImportSecurityContextW(SEC_WCHAR* pszPackage,
1296 WINPR_ATTR_NODISCARD
1297 WINPR_API SECURITY_STATUS SEC_ENTRY QueryCredentialsAttributesA(
PCredHandle phCredential,
1301 WINPR_ATTR_NODISCARD
1302 WINPR_API SECURITY_STATUS SEC_ENTRY QueryCredentialsAttributesW(
PCredHandle phCredential,
1308 WINPR_ATTR_NODISCARD
1309 WINPR_API SECURITY_STATUS SEC_ENTRY
1311 ULONG fContextReq, ULONG TargetDataRep,
PCtxtHandle phNewContext,
1314 WINPR_ATTR_NODISCARD
1315 WINPR_API SECURITY_STATUS SEC_ENTRY ApplyControlToken(
PCtxtHandle phContext,
1318 WINPR_ATTR_NODISCARD
1319 WINPR_API SECURITY_STATUS SEC_ENTRY CompleteAuthToken(
PCtxtHandle phContext,
1322 WINPR_ATTR_NODISCARD
1323 WINPR_API SECURITY_STATUS SEC_ENTRY DeleteSecurityContext(
PCtxtHandle phContext);
1325 WINPR_ATTR_NODISCARD
1326 WINPR_API SECURITY_STATUS SEC_ENTRY FreeContextBuffer(
void* pvContextBuffer);
1328 WINPR_ATTR_NODISCARD
1329 WINPR_API SECURITY_STATUS SEC_ENTRY ImpersonateSecurityContext(
PCtxtHandle phContext);
1331 WINPR_ATTR_NODISCARD
1332 WINPR_API SECURITY_STATUS SEC_ENTRY InitializeSecurityContextA(
1334 ULONG Reserved1, ULONG TargetDataRep,
PSecBufferDesc pInput, ULONG Reserved2,
1338 WINPR_ATTR_NODISCARD
1339 WINPR_API SECURITY_STATUS SEC_ENTRY InitializeSecurityContextW(
1341 ULONG fContextReq, ULONG Reserved1, ULONG TargetDataRep,
PSecBufferDesc pInput,
1345 WINPR_ATTR_NODISCARD
1346 WINPR_API SECURITY_STATUS SEC_ENTRY QueryContextAttributes(
PCtxtHandle phContext,
1347 ULONG ulAttribute,
void* pBuffer);
1349 WINPR_ATTR_NODISCARD
1350 WINPR_API SECURITY_STATUS SEC_ENTRY QuerySecurityContextToken(
PCtxtHandle phContext,
1353 WINPR_ATTR_NODISCARD
1354 WINPR_API SECURITY_STATUS SEC_ENTRY SetContextAttributes(
PCtxtHandle phContext,
1355 ULONG ulAttribute,
void* pBuffer,
1358 WINPR_ATTR_NODISCARD
1359 WINPR_API SECURITY_STATUS SEC_ENTRY RevertSecurityContext(
PCtxtHandle phContext);
1363 WINPR_ATTR_NODISCARD
1364 WINPR_API SECURITY_STATUS SEC_ENTRY DecryptMessage(
PCtxtHandle phContext,
1368 WINPR_ATTR_NODISCARD
1369 WINPR_API SECURITY_STATUS SEC_ENTRY EncryptMessage(
PCtxtHandle phContext, ULONG fQOP,
1372 WINPR_ATTR_NODISCARD
1373 WINPR_API SECURITY_STATUS SEC_ENTRY MakeSignature(
PCtxtHandle phContext, ULONG fQOP,
1376 WINPR_ATTR_NODISCARD
1377 WINPR_API SECURITY_STATUS SEC_ENTRY VerifySignature(
PCtxtHandle phContext,
1397#define SECPKG_ATTR_AUTH_IDENTITY 1001
1398#define SECPKG_ATTR_AUTH_PASSWORD 1002
1399#define SECPKG_ATTR_AUTH_NTLM_HASH 1003
1400#define SECPKG_ATTR_AUTH_NTLM_MESSAGE 1100
1401#define SECPKG_ATTR_AUTH_NTLM_TIMESTAMP 1101
1402#define SECPKG_ATTR_AUTH_NTLM_CLIENT_CHALLENGE 1102
1403#define SECPKG_ATTR_AUTH_NTLM_SERVER_CHALLENGE 1103
1404#define SECPKG_ATTR_AUTH_NTLM_NTPROOF_VALUE 1104
1405#define SECPKG_ATTR_AUTH_NTLM_RANDKEY 1105
1406#define SECPKG_ATTR_AUTH_NTLM_MIC 1106
1407#define SECPKG_ATTR_AUTH_NTLM_MIC_VALUE 1107
1409#define SECPKG_CRED_ATTR_TICKET_LOGON 1200
1414 char Domain[256 + 1];
1419 char Password[256 + 1];
1431 BOOL ChallengeOrResponse;
1436 BYTE ClientChallenge[8];
1441 BYTE ServerChallenge[8];
1451#define SSPI_INTERFACE_WINPR 0x00000001
1452#define SSPI_INTERFACE_NATIVE 0x00000002
1457 WINPR_API
void sspi_GlobalInit(
void);
1458 WINPR_API
void sspi_GlobalFinish(
void);
1460 WINPR_ATTR_NODISCARD
1464#define sspi_SetAuthIdentity sspi_SetAuthIdentityA
1465 WINPR_ATTR_NODISCARD
1466 WINPR_API
int sspi_SetAuthIdentityA(SEC_WINNT_AUTH_IDENTITY* identity,
const char* user,
1467 const char* domain,
const char* password);
1469 WINPR_ATTR_NODISCARD
1470 WINPR_API
int sspi_SetAuthIdentityW(SEC_WINNT_AUTH_IDENTITY* identity,
const WCHAR* user,
1471 const WCHAR* domain,
const WCHAR* password);
1473 WINPR_ATTR_NODISCARD
1474 WINPR_API
int sspi_SetAuthIdentityWithLengthW(SEC_WINNT_AUTH_IDENTITY* identity,
1475 const WCHAR* user,
size_t userLen,
1476 const WCHAR* domain,
size_t domainLen,
1477 const WCHAR* password,
size_t passwordLen);
1479 WINPR_ATTR_NODISCARD
1480 WINPR_API UINT32 sspi_GetAuthIdentityVersion(
const void* identity);
1482 WINPR_ATTR_NODISCARD
1483 WINPR_API UINT32 sspi_GetAuthIdentityFlags(
const void* identity);
1485 WINPR_ATTR_NODISCARD
1486 WINPR_API BOOL sspi_GetAuthIdentityUserDomainW(
const void* identity,
const WCHAR** pUser,
1487 UINT32* pUserLength,
const WCHAR** pDomain,
1488 UINT32* pDomainLength);
1490 WINPR_ATTR_NODISCARD
1491 WINPR_API BOOL sspi_GetAuthIdentityUserDomainA(
const void* identity,
const char** pUser,
1492 UINT32* pUserLength,
const char** pDomain,
1493 UINT32* pDomainLength);
1495 WINPR_ATTR_NODISCARD
1496 WINPR_API BOOL sspi_GetAuthIdentityPasswordW(
const void* identity,
const WCHAR** pPassword,
1497 UINT32* pPasswordLength);
1499 WINPR_ATTR_NODISCARD
1500 WINPR_API BOOL sspi_GetAuthIdentityPasswordA(
const void* identity,
const char** pPassword,
1501 UINT32* pPasswordLength);
1503 WINPR_ATTR_NODISCARD
1505 char** pUser,
char** pDomain,
char** pPassword);
1507 WINPR_ATTR_NODISCARD
1509 WCHAR** pUser, WCHAR** pDomain, WCHAR** pPassword);
1511 WINPR_ATTR_NODISCARD
1513 char** pPackageList);
1515 WINPR_ATTR_NODISCARD
1516 WINPR_API
int sspi_CopyAuthIdentity(SEC_WINNT_AUTH_IDENTITY* identity,
1519 WINPR_API
void sspi_FreeAuthIdentity(SEC_WINNT_AUTH_IDENTITY* identity);
1521 WINPR_ATTR_NODISCARD
1522 WINPR_API
const char* GetSecurityStatusString(SECURITY_STATUS status);
1524 WINPR_ATTR_NODISCARD
1527 WINPR_ATTR_NODISCARD
1531#define InitSecurityInterfaceEx InitSecurityInterfaceExW
1532#define INIT_SECURITY_INTERFACE_EX INIT_SECURITY_INTERFACE_EX_W
1534#define InitSecurityInterfaceEx InitSecurityInterfaceExA
1535#define INIT_SECURITY_INTERFACE_EX INIT_SECURITY_INTERFACE_EX_A
WINPR_ATTR_NODISCARD psSspiNtlmHashCallback hashCallback