123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123 |
- #ifndef HEADER_CURL_SSPI_H
- #define HEADER_CURL_SSPI_H
- /***************************************************************************
- * _ _ ____ _
- * Project ___| | | | _ \| |
- * / __| | | | |_) | |
- * | (__| |_| | _ <| |___
- * \___|\___/|_| \_\_____|
- *
- * Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
- *
- * This software is licensed as described in the file COPYING, which
- * you should have received as part of this distribution. The terms
- * are also available at https://curl.se/docs/copyright.html.
- *
- * You may opt to use, copy, modify, merge, publish, distribute and/or sell
- * copies of the Software, and permit persons to whom the Software is
- * furnished to do so, under the terms of the COPYING file.
- *
- * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
- * KIND, either express or implied.
- *
- * SPDX-License-Identifier: curl
- *
- ***************************************************************************/
- #include "curl_setup.h"
- #ifdef USE_WINDOWS_SSPI
- #include <curl/curl.h>
- /*
- * When including the following three headers, it is mandatory to define either
- * SECURITY_WIN32 or SECURITY_KERNEL, indicating who is compiling the code.
- */
- #undef SECURITY_WIN32
- #undef SECURITY_KERNEL
- #define SECURITY_WIN32 1
- #include <security.h>
- #include <sspi.h>
- #include <rpc.h>
- CURLcode Curl_sspi_global_init(void);
- void Curl_sspi_global_cleanup(void);
- /* This is used to populate the domain in a SSPI identity structure */
- CURLcode Curl_override_sspi_http_realm(const char *chlg,
- SEC_WINNT_AUTH_IDENTITY *identity);
- /* This is used to generate an SSPI identity structure */
- CURLcode Curl_create_sspi_identity(const char *userp, const char *passwdp,
- SEC_WINNT_AUTH_IDENTITY *identity);
- /* This is used to free an SSPI identity structure */
- void Curl_sspi_free_identity(SEC_WINNT_AUTH_IDENTITY *identity);
- /* Forward-declaration of global variables defined in curl_sspi.c */
- extern HMODULE s_hSecDll;
- extern PSecurityFunctionTable s_pSecFn;
- /* Provide some definitions missing in old headers */
- #define SP_NAME_DIGEST "WDigest"
- #define SP_NAME_NTLM "NTLM"
- #define SP_NAME_NEGOTIATE "Negotiate"
- #define SP_NAME_KERBEROS "Kerberos"
- #ifndef ISC_REQ_USE_HTTP_STYLE
- #define ISC_REQ_USE_HTTP_STYLE 0x01000000
- #endif
- #ifndef SEC_E_INVALID_PARAMETER
- # define SEC_E_INVALID_PARAMETER ((HRESULT)0x8009035DL)
- #endif
- #ifndef SEC_E_DELEGATION_POLICY
- # define SEC_E_DELEGATION_POLICY ((HRESULT)0x8009035EL)
- #endif
- #ifndef SEC_E_POLICY_NLTM_ONLY
- # define SEC_E_POLICY_NLTM_ONLY ((HRESULT)0x8009035FL)
- #endif
- #ifndef SEC_I_SIGNATURE_NEEDED
- # define SEC_I_SIGNATURE_NEEDED ((HRESULT)0x0009035CL)
- #endif
- #ifndef CRYPT_E_REVOKED
- # define CRYPT_E_REVOKED ((HRESULT)0x80092010L)
- #endif
- #ifndef CRYPT_E_NO_REVOCATION_DLL
- # define CRYPT_E_NO_REVOCATION_DLL ((HRESULT)0x80092011L)
- #endif
- #ifndef CRYPT_E_NO_REVOCATION_CHECK
- # define CRYPT_E_NO_REVOCATION_CHECK ((HRESULT)0x80092012L)
- #endif
- #ifndef CRYPT_E_REVOCATION_OFFLINE
- # define CRYPT_E_REVOCATION_OFFLINE ((HRESULT)0x80092013L)
- #endif
- #ifndef CRYPT_E_NOT_IN_REVOCATION_DATABASE
- # define CRYPT_E_NOT_IN_REVOCATION_DATABASE ((HRESULT)0x80092014L)
- #endif
- #ifdef UNICODE
- # define SECFLAG_WINNT_AUTH_IDENTITY \
- (unsigned long)SEC_WINNT_AUTH_IDENTITY_UNICODE
- #else
- # define SECFLAG_WINNT_AUTH_IDENTITY \
- (unsigned long)SEC_WINNT_AUTH_IDENTITY_ANSI
- #endif
- /*
- * Definitions required from ntsecapi.h are directly provided below this point
- * to avoid including ntsecapi.h due to a conflict with OpenSSL's safestack.h
- */
- #define KERB_WRAP_NO_ENCRYPT 0x80000001
- #endif /* USE_WINDOWS_SSPI */
- #endif /* HEADER_CURL_SSPI_H */
|