mirror of
https://github.com/moparisthebest/curl
synced 2025-01-10 05:28:02 -05:00
9ad282b1ae
This is just fundamentally broken. SPNEGO (RFC4178) is a protocol which allows client and server to negotiate the underlying mechanism which will actually be used to authenticate. This is *often* Kerberos, and can also be NTLM and other things. And to complicate matters, there are various different OIDs which can be used to specify the Kerberos mechanism too. A SPNEGO exchange will identify *which* GSSAPI mechanism is being used, and will exchange GSSAPI tokens which are appropriate for that mechanism. But this SPNEGO implementation just strips the incoming SPNEGO packet and extracts the token, if any. And completely discards the information about *which* mechanism is being used. Then we *assume* it was Kerberos, and feed the token into gss_init_sec_context() with the default mechanism (GSS_S_NO_OID for the mech_type argument). Furthermore... broken as this code is, it was never even *used* for input tokens anyway, because higher layers of curl would just bail out if the server actually said anything *back* to us in the negotiation. We assume that we send a single token to the server, and it accepts it. If the server wants to continue the exchange (as is required for NTLM and for SPNEGO to do anything useful), then curl was broken anyway. So the only bit which actually did anything was the bit in Curl_output_negotiate(), which always generates an *initial* SPNEGO token saying "Hey, I support only the Kerberos mechanism and this is its token". You could have done that by manually just prefixing the Kerberos token with the appropriate bytes, if you weren't going to do any proper SPNEGO handling. There's no need for the FBOpenSSL library at all. The sane way to do SPNEGO is just to *ask* the GSSAPI library to do SPNEGO. That's what the 'mech_type' argument to gss_init_sec_context() is for. And then it should all Just Work™. That 'sane way' will be added in a subsequent patch, as will bug fixes for our failure to handle any exchange other than a single outbound token to the server which results in immediate success.
188 lines
5.3 KiB
C
188 lines
5.3 KiB
C
#ifndef HEADER_CURL_CONFIG_DOS_H
|
|
#define HEADER_CURL_CONFIG_DOS_H
|
|
/***************************************************************************
|
|
* _ _ ____ _
|
|
* Project ___| | | | _ \| |
|
|
* / __| | | | |_) | |
|
|
* | (__| |_| | _ <| |___
|
|
* \___|\___/|_| \_\_____|
|
|
*
|
|
* Copyright (C) 1998 - 2013, 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 http://curl.haxx.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.
|
|
*
|
|
***************************************************************************/
|
|
|
|
|
|
/* ================================================================ */
|
|
/* lib/config-dos.h - Hand crafted config file for DOS */
|
|
/* ================================================================ */
|
|
|
|
#if defined(DJGPP)
|
|
#define OS "MSDOS/djgpp"
|
|
#elif defined(__HIGHC__)
|
|
#define OS "MSDOS/HighC"
|
|
#elif defined(__WATCOMC__)
|
|
#define OS "MSDOS/Watcom"
|
|
#else
|
|
#define OS "MSDOS/?"
|
|
#endif
|
|
|
|
#define PACKAGE "curl"
|
|
|
|
#define HAVE_ARPA_INET_H 1
|
|
#define HAVE_ERRNO_H 1
|
|
#define HAVE_FCNTL_H 1
|
|
#define HAVE_GETADDRINFO 1
|
|
#define HAVE_GETNAMEINFO 1
|
|
#define HAVE_GETPROTOBYNAME 1
|
|
#define HAVE_GETTIMEOFDAY 1
|
|
#define HAVE_IO_H 1
|
|
#define HAVE_IOCTL 1
|
|
#define HAVE_IOCTL_FIONBIO 1
|
|
#define HAVE_IOCTLSOCKET 1
|
|
#define HAVE_IOCTLSOCKET_FIONBIO 1
|
|
#define HAVE_LIMITS_H 1
|
|
#define HAVE_LOCALE_H 1
|
|
#define HAVE_LONGLONG 1
|
|
#define HAVE_MEMORY_H 1
|
|
#define HAVE_NETDB_H 1
|
|
#define HAVE_NETINET_IN_H 1
|
|
#define HAVE_NETINET_TCP_H 1
|
|
#define HAVE_NET_IF_H 1
|
|
#define HAVE_PROCESS_H 1
|
|
#define HAVE_RECV 1
|
|
#define HAVE_RECVFROM 1
|
|
#define HAVE_SELECT 1
|
|
#define HAVE_SEND 1
|
|
#define HAVE_SETJMP_H 1
|
|
#define HAVE_SETLOCALE 1
|
|
#define HAVE_SETMODE 1
|
|
#define HAVE_SIGNAL 1
|
|
#define HAVE_SOCKET 1
|
|
#define HAVE_STRDUP 1
|
|
#define HAVE_STRICMP 1
|
|
#define HAVE_STRTOLL 1
|
|
#define HAVE_STRUCT_TIMEVAL 1
|
|
#define HAVE_STRUCT_IN6_ADDR 1
|
|
#define HAVE_SYS_IOCTL_H 1
|
|
#define HAVE_SYS_SOCKET_H 1
|
|
#define HAVE_SYS_STAT_H 1
|
|
#define HAVE_SYS_TYPES_H 1
|
|
#define HAVE_TIME_H 1
|
|
#define HAVE_UNISTD_H 1
|
|
|
|
#define NEED_MALLOC_H 1
|
|
|
|
#define RETSIGTYPE void
|
|
#define SIZEOF_INT 4
|
|
#define SIZEOF_LONG_DOUBLE 16
|
|
#define SIZEOF_SHORT 2
|
|
#define SIZEOF_SIZE_T 4
|
|
#define STDC_HEADERS 1
|
|
#define TIME_WITH_SYS_TIME 1
|
|
|
|
/* Qualifiers for send(), recv(), recvfrom() and getnameinfo(). */
|
|
|
|
#define SEND_TYPE_ARG1 int
|
|
#define SEND_QUAL_ARG2 const
|
|
#define SEND_TYPE_ARG2 void *
|
|
#define SEND_TYPE_ARG3 int
|
|
#define SEND_TYPE_ARG4 int
|
|
#define SEND_TYPE_RETV int
|
|
|
|
#define RECV_TYPE_ARG1 int
|
|
#define RECV_TYPE_ARG2 void *
|
|
#define RECV_TYPE_ARG3 int
|
|
#define RECV_TYPE_ARG4 int
|
|
#define RECV_TYPE_RETV int
|
|
|
|
#define RECVFROM_TYPE_ARG1 int
|
|
#define RECVFROM_TYPE_ARG2 void
|
|
#define RECVFROM_TYPE_ARG3 int
|
|
#define RECVFROM_TYPE_ARG4 int
|
|
#define RECVFROM_TYPE_ARG5 struct sockaddr
|
|
#define RECVFROM_TYPE_ARG6 int
|
|
#define RECVFROM_TYPE_RETV int
|
|
#define RECVFROM_TYPE_ARG2_IS_VOID 1
|
|
|
|
#define GETNAMEINFO_QUAL_ARG1 const
|
|
#define GETNAMEINFO_TYPE_ARG1 struct sockaddr *
|
|
#define GETNAMEINFO_TYPE_ARG2 int
|
|
#define GETNAMEINFO_TYPE_ARG46 int
|
|
#define GETNAMEINFO_TYPE_ARG7 int
|
|
|
|
#define BSD
|
|
|
|
/* CURLDEBUG definition enables memory tracking */
|
|
/* #define CURLDEBUG */
|
|
|
|
/* USE_ZLIB on cmd-line */
|
|
#ifdef USE_ZLIB
|
|
#define HAVE_ZLIB_H 1
|
|
#define HAVE_LIBZ 1
|
|
#endif
|
|
|
|
/* USE_SSLEAY on cmd-line */
|
|
#ifdef USE_SSLEAY
|
|
#define HAVE_CRYPTO_CLEANUP_ALL_EX_DATA 1
|
|
#define HAVE_OPENSSL_ENGINE_H 1
|
|
#define OPENSSL_NO_KRB5 1
|
|
#define USE_OPENSSL 1
|
|
#endif
|
|
|
|
/* to disable LDAP */
|
|
#define CURL_DISABLE_LDAP 1
|
|
|
|
#define in_addr_t u_long
|
|
|
|
#if defined(__HIGHC__) || \
|
|
(defined(__GNUC__) && (__GNUC__ < 4))
|
|
#define ssize_t int
|
|
#endif
|
|
|
|
#define CURL_CA_BUNDLE getenv("CURL_CA_BUNDLE")
|
|
|
|
/* Target HAVE_x section */
|
|
|
|
#if defined(DJGPP)
|
|
#define HAVE_BASENAME 1
|
|
#define HAVE_STRCASECMP 1
|
|
#define HAVE_SIGACTION 1
|
|
#define HAVE_SIGSETJMP 1
|
|
#define HAVE_SYS_TIME_H 1
|
|
#define HAVE_TERMIOS_H 1
|
|
#define HAVE_VARIADIC_MACROS_GCC 1
|
|
|
|
/* Because djgpp <= 2.03 doesn't have snprintf() etc. */
|
|
#if (DJGPP_MINOR < 4)
|
|
#define _MPRINTF_REPLACE
|
|
#endif
|
|
|
|
#elif defined(__WATCOMC__)
|
|
#define HAVE_STRCASECMP 1
|
|
|
|
#elif defined(__HIGHC__)
|
|
#define HAVE_SYS_TIME_H 1
|
|
#define strerror(e) strerror_s_((e))
|
|
#endif
|
|
|
|
#ifdef MSDOS /* Watt-32 */
|
|
#define HAVE_CLOSE_S 1
|
|
#endif
|
|
|
|
#undef word
|
|
#undef byte
|
|
|
|
#endif /* HEADER_CURL_CONFIG_DOS_H */
|
|
|