diff options
author | Jens-Heiner Rechtien <hr@openoffice.org> | 2009-07-27 15:26:29 +0000 |
---|---|---|
committer | Jens-Heiner Rechtien <hr@openoffice.org> | 2009-07-27 15:26:29 +0000 |
commit | a1bedf02c3973755dc5f9870d39bab827c4f07b4 (patch) | |
tree | c1f0ebcd71e525c7ca44496c1eaef20889191bee /neon/neon.patch | |
parent | 22b7626699093fe82fe931510dd5209e8d67cce8 (diff) |
CWS-TOOLING: integrate CWS kso32fixes
2009-07-10 15:25:24 +0200 kso r273899 : #i53184# - fix probs with UNC server names containing underscores.
2009-07-10 14:31:59 +0200 kso r273893 : CWS-TOOLING: rebase CWS kso32fixes to trunk@273858 (milestone: DEV300:m52)
2009-07-09 13:46:16 +0200 kso r273861 : #i53184# - withdrew patch.
2009-07-08 13:39:00 +0200 kso r273829 : #i63159# - added license header
2009-07-08 11:44:08 +0200 kso r273824 : i53184 - cannot open files from shell if UNC server has a _ (underscore)
2009-07-08 11:21:12 +0200 kso r273822 : #i93271# - mingw build error
2009-07-08 11:13:48 +0200 kso r273821 : #i91247 - Adhere to one more xdg spec
2009-07-08 11:02:53 +0200 kso r273820 : #i89017# - osl_trace now emits trailing line feed to the debugger
2009-07-08 10:55:04 +0200 kso r273819 : #i88663# - not waiting on successful forks but subsequent process failure
2009-07-07 17:05:27 +0200 kso r273810 : #i88382# - It's nice to leave the modal mode in gtk+ too ;-)
2009-07-07 16:53:34 +0200 kso r273808 : i88331# - Typo in include guard
2009-07-07 16:48:17 +0200 kso r273807 : i82831# - crashrep: warnings when size_t != int
2009-07-07 16:39:49 +0200 kso r273806 : i63159# - Patch to use d_type field in dirent structure if possible
2009-06-24 12:52:27 +0200 kso r273333 : #i100274# - solved win2k missing symbol problem (again).
2009-05-20 13:58:48 +0200 kso r272124 : CWS-TOOLING: rebase CWS kso32fixes to trunk@271830 (milestone: DEV300:m48)
2009-04-17 14:50:54 +0200 kso r270950 : CWS-TOOLING: rebase CWS kso32fixes to trunk@270723 (milestone: DEV300:m46)
2009-03-26 09:27:28 +0100 kso r270054 : #i100274# NTLM code cleanup.
2009-03-20 14:13:38 +0100 kso r269807 : #i100274# - Fixed potential buffer overflow in NTLM code.
2009-03-19 14:53:03 +0100 kso r269748 : #i100274. Added NTLM support for Non-Windows platforms.
2009-03-17 15:52:44 +0100 kso r269613 : CWS-TOOLING: rebase CWS kso32fixes to trunk@269297 (milestone: DEV300:m43)
Diffstat (limited to 'neon/neon.patch')
-rw-r--r-- | neon/neon.patch | 2436 |
1 files changed, 1641 insertions, 795 deletions
diff --git a/neon/neon.patch b/neon/neon.patch index b62a64ab23f4..b9776097ecbb 100644 --- a/neon/neon.patch +++ b/neon/neon.patch @@ -1,795 +1,1641 @@ ---- misc/neon-0.28.2/src/config.h 2008-08-25 14:36:05.062500000 +0200
-+++ misc/build/neon-0.28.2/src/config.h 2008-08-25 14:32:17.656250000 +0200
-@@ -1 +1,479 @@
--dummy
-+
-+/* Define to specific EGD socket path */
-+/* #undef EGD_PATH */
-+
-+/* Define if EGD should be supported */
-+/* #undef ENABLE_EGD */
-+
-+/* Define if GSS_C_NT_HOSTBASED_SERVICE is not defined otherwise */
-+/* #undef GSS_C_NT_HOSTBASED_SERVICE */
-+
-+/* Define to 1 if you have the <arpa/inet.h> header file. */
-+#ifdef UNX
-+#define HAVE_ARPA_INET_H 1
-+#endif
-+
-+/* Define to 1 if you have the `bind_textdomain_codeset' function. */
-+/* #undef HAVE_BIND_TEXTDOMAIN_CODESET 1 */
-+
-+/* Define to 1 if you have the declaration of `h_errno', and to 0 if you
-+ don't. */
-+#ifdef WIN32
-+#define HAVE_DECL_H_ERRNO 1
-+#endif
-+
-+/* Define to 1 if you have the declaration of `stpcpy', and to 0 if you don't.
-+ */
-+#ifdef LINUX
-+#define HAVE_DECL_STPCPY 1
-+#endif
-+
-+/* Define to 1 if you have the declaration of `strerror_r', and to 0 if you
-+ don't. */
-+#ifdef LINUX
-+#define HAVE_DECL_STRERROR_R 1
-+#endif
-+
-+/* Define to 1 if you have the <dlfcn.h> header file. */
-+#ifdef UNX
-+#define HAVE_DLFCN_H 1
-+#endif
-+
-+/* Define to 1 if you have the <errno.h> header file. */
-+#define HAVE_ERRNO_H 1
-+
-+/* Define if you have expat */
-+/* #undef HAVE_EXPAT */
-+
-+/* Define to 1 if you have the `fstat64' function. */
-+#define HAVE_FSTAT64
-+
-+/* Define to 1 if you have the `gai_strerror' function. */
-+#define HAVE_GAI_STRERROR 1
-+
-+/* Define if GnuTLS support is enabled */
-+/* #undef HAVE_GNUTLS */
-+
-+/* Define to 1 if you have the `gnutls_session_get_data2' function. */
-+/* #undef HAVE_GNUTLS_SESSION_GET_DATA2 */
-+
-+/* Define if GSSAPI support is enabled */
-+/* #undef HAVE_GSSAPI */
-+
-+/* Define to 1 if you have the <gssapi/gssapi_generic.h> header file. */
-+/* #undef HAVE_GSSAPI_GSSAPI_GENERIC_H */
-+
-+/* Define to 1 if you have the <gssapi/gssapi.h> header file. */
-+/* #undef HAVE_GSSAPI_GSSAPI_H */
-+
-+/* Define to 1 if you have the <gssapi.h> header file. */
-+/* #undef HAVE_GSSAPI_H */
-+
-+/* Define to 1 if you have the `gss_init_sec_context' function. */
-+/* #undef HAVE_GSS_INIT_SEC_CONTEXT */
-+
-+/* Define to 1 if you have the `hstrerror' function. */
-+/* #undef HAVE_HSTRERROR */
-+
-+/* Define to 1 if you have the `inet_ntop' function. */
-+#ifdef UNX
-+#define HAVE_INET_NTOP 1
-+#endif
-+
-+/* Define to 1 if you have the <inttypes.h> header file. */
-+#ifdef UNX
-+#define HAVE_INTTYPES_H 1
-+#endif
-+
-+/* Define to 1 if you have the `isatty' function. */
-+#define HAVE_ISATTY 1
-+
-+/* Define to 1 if you have the <libintl.h> header file. */
-+/* #undef HAVE_LIBINTL_H */
-+
-+/* Define if you have libxml */
-+#define HAVE_LIBXML 1
-+
-+/* Define to 1 if you have the <libxml/parser.h> header file. */
-+#define HAVE_LIBXML_PARSER_H 1
-+
-+/* Define to 1 if you have the <libxml/xmlversion.h> header file. */
-+#define HAVE_LIBXML_XMLVERSION_H 1
-+
-+/* Define to 1 if you have the <limits.h> header file. */
-+#define HAVE_LIMITS_H 1
-+
-+/* Define to 1 if you have the <locale.h> header file. */
-+#define HAVE_LOCALE_H 1
-+
-+/* Define to 1 if you have the `lseek64' function. */
-+#define HAVE_LSEEK64 1
-+
-+/* Define to 1 if you have the <memory.h> header file. */
-+#define HAVE_MEMORY_H 1
-+
-+/* Define to 1 if you have the <netdb.h> header file. */
-+#ifdef UNX
-+#define HAVE_NETDB_H 1
-+#endif
-+
-+/* Define to 1 if you have the <netinet/in.h> header file. */
-+#ifdef UNX
-+#define HAVE_NETINET_IN_H 1
-+#endif
-+
-+/* Define to 1 if you have the <netinet/tcp.h> header file. */
-+#ifdef UNX
-+#define HAVE_NETINET_TCP_H 1
-+#endif
-+
-+/* Define if OpenSSL support is enabled */
-+/* #undef HAVE_OPENSSL */
-+#define HAVE_OPENSSL
-+/* Define to 1 if you have the <openssl/opensslv.h> header file. */
-+/* #undef HAVE_OPENSSL_OPENSSLV_H */
-+#define HAVE_OPENSSL_OPENSSLV_H 1
-+/* Define to 1 if you have the <openssl/ssl.h> header file. */
-+/* #undef HAVE_OPENSSL_SSL_H */
-+#define HAVE_OPENSSL_SSL_H 1
-+/* Define to 1 if you have the `pipe' function. */
-+#define HAVE_PIPE 1
-+
-+/* Define to 1 if you have the `poll' function. */
-+#define HAVE_POLL 1
-+
-+/* Define to 1 if you have the `pthread_mutex_init' function. */
-+/* #undef HAVE_PTHREAD_MUTEX_INIT */
-+
-+/* Define to 1 if you have the `pthread_mutex_lock' function. */
-+/* #undef HAVE_PTHREAD_MUTEX_LOCK */
-+
-+/* Define to 1 if you have the `setlocale' function. */
-+#define HAVE_SETLOCALE 1
-+
-+/* Define to 1 if you have the `setsockopt' function. */
-+#if defined (LINUX) || defined (WIN32)
-+#define HAVE_SETSOCKOPT 1
-+#endif
-+
-+/* Define to 1 if you have the `setvbuf' function. */
-+#define HAVE_SETVBUF 1
-+
-+/* Define to 1 if you have the `shutdown' function. */
-+#ifdef LINUX
-+#define HAVE_SHUTDOWN 1
-+#endif
-+
-+/* Define to 1 if you have the `signal' function. */
-+#define HAVE_SIGNAL 1
-+
-+/* Define to 1 if you have the <signal.h> header file. */
-+#define HAVE_SIGNAL_H 1
-+
-+/* Define to 1 if you have the `snprintf' function. */
-+#ifdef UNX
-+#define HAVE_SNPRINTF 1
-+#endif
-+
-+#ifdef WIN32
-+#define snprintf _snprintf
-+#endif
-+
-+/* Define to 1 if you have the <socks.h> header file. */
-+/* #undef HAVE_SOCKS_H */
-+
-+/* Define to 1 if you have the <stdarg.h> header file. */
-+#define HAVE_STDARG_H 1
-+
-+/* Define to 1 if you have the <stdint.h> header file. */
-+#define HAVE_STDINT_H 1
-+
-+/* Define to 1 if you have the <stdlib.h> header file. */
-+#define HAVE_STDLIB_H 1
-+
-+/* Define to 1 if you have the `stpcpy' function. */
-+#ifdef LINUX
-+#define HAVE_STPCPY 1
-+#endif
-+
-+/* Define to 1 if you have the `strcasecmp' function. */
-+#ifdef UNX
-+#define HAVE_STRCASECMP 1
-+#endif
-+
-+#ifdef WIN32
-+#define strcasecmp strcmpi
-+#endif
-+
-+/* Define to 1 if you have the `strerror_r' function. */
-+#ifdef LINUX
-+#define HAVE_STRERROR_R 1
-+#endif
-+
-+/* Define to 1 if you have the <strings.h> header file. */
-+#ifdef UNX
-+#define HAVE_STRINGS_H 1
-+#endif
-+
-+/* Define to 1 if you have the <string.h> header file. */
-+#define HAVE_STRING_H 1
-+
-+/* Define to 1 if you have the `strtoll' function. */
-+#define HAVE_STRTOLL 1
-+
-+/* Define to 1 if you have the `strtoq' function. */
-+/* #undef HAVE_STRTOQ */
-+
-+/* Define to 1 if `tm_gmtoff' is member of `struct tm'. */
-+#ifdef LINUX
-+#define HAVE_STRUCT_TM_TM_GMTOFF 1
-+#endif
-+
-+/* Define to 1 if `__tm_gmtoff' is member of `struct tm'. */
-+/* #undef HAVE_STRUCT_TM___TM_GMTOFF */
-+
-+/* Define to 1 if you have the <sys/limits.h> header file. */
-+/* #undef HAVE_SYS_LIMITS_H */
-+
-+/* Define to 1 if you have the <sys/poll.h> header file. */
-+#ifdef UNX
-+#define HAVE_SYS_POLL_H 1
-+#endif
-+
-+/* Define to 1 if you have the <sys/select.h> header file. */
-+#ifdef UNX
-+#define HAVE_SYS_SELECT_H 1
-+#endif
-+
-+/* Define to 1 if you have the <sys/socket.h> header file. */
-+#ifdef UNX
-+#define HAVE_SYS_SOCKET_H 1
-+#endif
-+
-+/* Define to 1 if you have the <sys/stat.h> header file. */
-+#define HAVE_SYS_STAT_H 1
-+
-+/* Define to 1 if you have the <sys/time.h> header file. */
-+#ifdef UNX
-+#define HAVE_SYS_TIME_H 1
-+#endif
-+
-+/* Define to 1 if you have the <sys/types.h> header file. */
-+#define HAVE_SYS_TYPES_H 1
-+
-+/* Define if the timezone global is available */
-+#ifndef MACOSX
-+#define HAVE_TIMEZONE 1
-+#endif
-+
-+/* Use trio printf replacement library */
-+/* #undef HAVE_TRIO */
-+
-+/* Define to 1 if you have the <trio.h> header file. */
-+/* #undef HAVE_TRIO_H */
-+
-+/* Define to 1 if you have the <unistd.h> header file. */
-+#ifdef UNX
-+#define HAVE_UNISTD_H 1
-+#endif
-+
-+/* Define to 1 if you have the `usleep' function. */
-+#ifdef UNX
-+#define HAVE_USLEEP 1
-+#endif
-+
-+/* Define to 1 if you have the `vsnprintf' function. */
-+#if defined( UNX ) || (defined(_MSC_VER) && (_MSC_VER > 1400))
-+#define HAVE_VSNPRINTF 1
-+#endif
-+
-+#ifdef WIN32
-+#if (defined(_MSC_VER) && (_MSC_VER < 1500)) || defined(__MINGW32__)
-+#define vsnprintf _vsnprintf
-+#endif
-+#endif
-+
-+/* Define to be location of localedir */
-+/* #undef LOCALEDIR */
-+
-+/* Defined when neon is built as a library */
-+#define NEON_IS_LIBRARY 1
-+
-+/* Define to be the neon version string */
-+#define NEON_VERSION "0.26.3"
-+
-+/* Define to enable debugging */
-+/* #undef NE_DEBUGGING */
-+
-+/* Define to be printf format string for off64_t */
-+#define NE_FMT_OFF64_T "lld"
-+
-+/* Define to be printf format string for off_t */
-+#define NE_FMT_OFF_T "ld"
-+
-+/* Define to be printf format string for size_t */
-+#define NE_FMT_SIZE_T "u"
-+
-+/* Define to be printf format string for ssize_t */
-+#define NE_FMT_SSIZE_T "d"
-+
-+/* Define to be printf format string for time_t */
-+#define NE_FMT_TIME_T "ld"
-+
-+/* Defined if DAV is supported */
-+#define NE_HAVE_DAV 1
-+
-+/* Defined if I18N is supported */
-+/* #undef NE_HAVE_I18N 1 */
-+
-+/* Defined if IPV6 is supported */
-+#define NE_HAVE_IPV6 1
-+
-+/* Defined if LFS is supported */
-+#define NE_HAVE_LFS 1
-+
-+/* Defined if SOCKS is supported */
-+/* #undef NE_HAVE_SOCKS */
-+
-+/* Defined if SSL is supported */
-+/* #undef NE_HAVE_SSL */
-+#define NE_HAVE_SSL
-+/* Defined if TS_SSL is supported */
-+/* #undef NE_HAVE_TS_SSL */
-+
-+/* Defined if ZLIB is supported */
-+/* #undef NE_HAVE_ZLIB */
-+
-+/* Define to be filename of an SSL CA root bundle */
-+/* #undef NE_SSL_CA_BUNDLE */
-+
-+/* Define if poll() should be used */
-+#ifdef UNX
-+#define NE_USE_POLL 1
-+#endif
-+
-+/* Define to be neon library major version */
-+#define NE_VERSION_MAJOR (0)
-+
-+/* Define to be neon library minor version */
-+#define NE_VERSION_MINOR (26)
-+
-+/* Define to be neon library patch version */
-+#define NE_VERSION_PATCH (3)
-+
-+/* Define to the address where bug reports for this package should be sent. */
-+#define PACKAGE_BUGREPORT "neon@webdav.org"
-+
-+/* Define to the full name of this package. */
-+#define PACKAGE_NAME "neon"
-+
-+/* Define to the full name and version of this package. */
-+#define PACKAGE_STRING "neon 0.26.3"
-+
-+/* Define to the one symbol short name of this package. */
-+#define PACKAGE_TARNAME "neon"
-+
-+/* Define to the version of this package. */
-+#define PACKAGE_VERSION "0.26.3"
-+
-+/* The size of a `int', as computed by sizeof. */
-+#define SIZEOF_INT 4
-+
-+/* The size of a `long', as computed by sizeof. */
-+#define SIZEOF_LONG 4
-+
-+/* The size of a `long long', as computed by sizeof. */
-+#define SIZEOF_LONG_LONG 8
-+
-+/* The size of a `off64_t', as computed by sizeof. */
-+#define SIZEOF_OFF64_T 8
-+
-+/* The size of a `off_t', as computed by sizeof. */
-+#define SIZEOF_OFF_T 4
-+
-+/* The size of a `size_t', as computed by sizeof. */
-+#define SIZEOF_SIZE_T 4
-+
-+/* The size of a `ssize_t', as computed by sizeof. */
-+#define SIZEOF_SSIZE_T 4
-+
-+/* The size of a `time_t', as computed by sizeof. */
-+#define SIZEOF_TIME_T 4
-+
-+/* Define to 1 if you have the ANSI C header files. */
-+#ifdef SOLARIS
-+#define STDC_HEADERS 1
-+#endif
-+
-+/* Define to 1 if strerror_r returns char *. */
-+#ifdef LINUX
-+#define STRERROR_R_CHAR_P 1
-+#endif
-+
-+/* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */
-+#define TIME_WITH_SYS_TIME 1
-+
-+/* Define if getaddrinfo supports AI_ADDRCONFIG */
-+/* #undef USE_GAI_ADDRCONFIG */
-+
-+/* Define if getaddrinfo() should be used */
-+#define USE_GETADDRINFO 1
-+
-+/* Define to 1 if your processor stores words with the most significant byte
-+ first (like Motorola and SPARC, unlike Intel and VAX). */
-+#if defined (SOLARIS) && defined (SPARC)
-+#define WORDS_BIGENDIAN 1
-+#endif
-+
-+/* Always defined to enable GNU extensions */
-+#define _GNU_SOURCE 1
-+
-+/* Define to empty if `const' does not conform to ANSI C. */
-+/* #undef const */
-+
-+/* Define if in_addr_t is not available */
-+/* #undef in_addr_t */
-+
-+/* Define to `__inline__' or `__inline' if that's what the C compiler
-+ calls it, or to nothing if 'inline' is not supported under any name. */
-+#ifndef __cplusplus
-+#if defined (SOLARIS) && defined (__SUNPRO_C)
-+#define inline
-+#endif
-+#endif
-+
-+/* Define to `long' if <sys/types.h> does not define. */
-+/* #undef off_t */
-+
-+/* Define to `int' if <sys/types.h> does not define. */
-+/* #undef pid_t */
-+
-+/* Define to `unsigned' if <sys/types.h> does not define. */
-+/* #undef size_t */
-+
-+
-+/* Enable leak-tracking versions of ne_*alloc when NEON_MEMLEAK is enabled */
-+#ifdef NEON_MEMLEAK
-+# include "memleak.h"
-+#endif
-+
-+#if defined(HAVE_STPCPY) && defined(HAVE_DECL_STPCPY) && !HAVE_DECL_STPCPY && !defined(stpcpy)
-+char *stpcpy(char *, const char *);
-+#endif
-+
-+#ifdef WIN32
-+
-+#include <io.h>
-+
-+#define HAVE_SSPI 1
-+
-+#define HAVE_MEMCPY 1
-+
-+#define strncasecmp strnicmp
-+#define inline __inline
-+#define WIN32_LEAN_AND_MEAN
-+#define NOUSER
-+#define NOGDI
-+#define NONLS
-+#define NOCRYPT
-+#endif
---- misc/neon-0.28.2/src/makefile.mk 2008-08-25 14:36:04.640625000 +0200
-+++ misc/build/neon-0.28.2/src/makefile.mk 2008-08-25 14:32:17.671875000 +0200
-@@ -1 +1,54 @@
--dummy
-+PRJ=..$/..$/..$/..$/..
-+
-+PRJNAME=neon
-+TARGET=neon
-+LIBTARGET=NO
-+EXTERNAL_WARNINGS_NOT_ERRORS := TRUE
-+
-+# --- Settings -----------------------------------------------------
-+
-+.INCLUDE : settings.mk
-+
-+# --- Files --------------------------------------------------------
-+
-+CDEFS+=-DHAVE_CONFIG_H
-+
-+.IF "$(SYSTEM_LIBXML)" == "YES"
-+CFLAGS+=-DSYSTEM_LIBXML $(LIBXML_CFLAGS)
-+.ENDIF
-+
-+
-+SLOFILES= \
-+ $(SLO)$/ne_207.obj \
-+ $(SLO)$/ne_acl.obj \
-+ $(SLO)$/ne_alloc.obj \
-+ $(SLO)$/ne_auth.obj \
-+ $(SLO)$/ne_basic.obj \
-+ $(SLO)$/ne_compress.obj \
-+ $(SLO)$/ne_dates.obj \
-+ $(SLO)$/ne_i18n.obj \
-+ $(SLO)$/ne_locks.obj \
-+ $(SLO)$/ne_md5.obj \
-+ $(SLO)$/ne_props.obj \
-+ $(SLO)$/ne_redirect.obj \
-+ $(SLO)$/ne_request.obj \
-+ $(SLO)$/ne_session.obj \
-+ $(SLO)$/ne_socket.obj \
-+ $(SLO)$/ne_sspi.obj \
-+ $(SLO)$/ne_string.obj \
-+ $(SLO)$/ne_uri.obj \
-+ $(SLO)$/ne_utils.obj \
-+ $(SLO)$/ne_xml.obj \
-+ $(SLO)$/ne_xmlreq.obj \
-+ $(SLO)$/ne_openssl.obj
-+
-+# $(SLO)$/ne_gnutls.obj \
-+# $(SLO)$/ne_stubssl.obj
-+
-+LIB1TARGET=$(SLB)$/$(TARGET).lib
-+LIB1ARCHIV=$(LB)$/lib$(TARGET).a
-+LIB1OBJFILES=$(SLOFILES)
-+
-+# --- Targets ------------------------------------------------------
-+
-+.INCLUDE : target.mk
---- misc/neon-0.28.2/src/ne_207.c 2006-01-02 12:43:19.000000000 +0100
-+++ misc/build/neon-0.28.2/src/ne_207.c 2009-01-09 10:12:39.563530700 +0100
-@@ -177,7 +177,6 @@
- /* Now we have the href, begin the response */
- if (p->start_response && HAVE_CDATA(p)) {
- ne_uri ref, resolved;
--
- if (ne_uri_parse(cdata, &ref) == 0) {
- ne_uri_resolve(&p->base, &ref, &resolved);
-
-@@ -367,5 +366,4 @@
- ne_request_destroy(req);
-
- return ret;
--}
--
-+}
---- misc/neon-0.28.2/src/ne_auth.c 2008-02-29 17:30:12.000000000 +0100
-+++ misc/build/neon-0.28.2/src/ne_auth.c 2008-08-25 14:35:18.453125000 +0200
-@@ -598,9 +598,10 @@
- int ntlm = ne_strcasecmp(parms->protocol->name, "NTLM") == 0;
- int status;
- char *response = NULL;
--
-+ char password[NE_ABUFSIZ];
-+
- NE_DEBUG(NE_DBG_HTTPAUTH, "auth: SSPI challenge.\n");
--
-+
- if (!sess->sspi_context) {
- ne_uri uri = {0};
-
-@@ -614,8 +615,17 @@
- return status;
- }
- }
-+
-+ /* Authentification needs more than one http request.
-+ * As long as authentification in progress use the existing credentials.
-+ * Otherwise get new credentials.*/
-+ if (!parms->opaque)
-+ if (get_credentials(sess, errmsg, attempt, parms, password)) {
-+ /* Failed to get credentials */
-+ return -1;
-+ }
-
-- status = ne_sspi_authenticate(sess->sspi_context, parms->opaque, &response);
-+ status = ne_sspi_authenticate(sess->sspi_context, parms->opaque, &response, sess->username, password);
- if (status) {
- return status;
- }
-@@ -1413,6 +1423,7 @@
- /* note above: allow a 401 in response to a CONNECT request
- * from a proxy since some buggy proxies send that. */
- NE_DEBUG(NE_DBG_HTTPAUTH, "auth: Got challenge (code %d).\n", status->code);
-+
- if (!auth_challenge(sess, areq->attempt++, auth_hdr)) {
- ret = NE_RETRY;
- } else {
---- misc/neon-0.28.2/src/ne_defs.h 2006-10-24 21:40:09.000000000 +0200
-+++ misc/build/neon-0.28.2/src/ne_defs.h 2008-08-25 14:32:17.875000000 +0200
-@@ -41,7 +41,7 @@
- #endif
-
- /* define ssize_t for Win32 */
--#if defined(WIN32) && !defined(ssize_t)
-+#if defined(WIN32) && !defined(ssize_t) && !defined(__MINGW32__)
- #define ssize_t int
- #endif
-
---- misc/neon-0.28.2/src/ne_locks.h 2006-01-02 12:43:19.000000000 +0100
-+++ misc/build/neon-0.28.2/src/ne_locks.h 2008-08-25 14:32:17.937500000 +0200
-@@ -22,6 +22,10 @@
- #ifndef NE_LOCKS_H
- #define NE_LOCKS_H
-
-+# if defined __GNUC__
-+# pragma GCC system_header
-+# endif
-+
- #include "ne_request.h" /* for ne_session + ne_request */
- #include "ne_uri.h" /* for ne_uri */
-
---- misc/neon-0.28.2/src/ne_socket.c 2006-10-30 14:18:51.000000000 +0100
-+++ misc/build/neon-0.28.2/src/ne_socket.c 2008-07-16 13:32:11.022546400 +0200
-@@ -60,6 +60,7 @@
- #include <stddef.h>
- #ifdef USE_GETADDRINFO
- #include <ws2tcpip.h>
-+#include <Wspiapi.h>
- #endif
- #endif
-
---- misc/neon-0.28.2/src/ne_sspi.c 2007-08-10 17:26:08.000000000 +0200
-+++ misc/build/neon-0.28.2/src/ne_sspi.c 2009-01-09 10:31:05.752056400 +0100
-@@ -202,9 +202,48 @@
- return -1;
- }
-
-+ return 0;
-+}
-+
-+/*
-+ * Simplification wrapper arround AcquireCredentialsHandle as most of
-+ * the parameters do not change.
-+ */
-+static int acquireCredentialsHandleForUsername(CredHandle * credentials, char *package, const char *username, const char *password)
-+{
-+ SECURITY_STATUS status;
-+ TimeStamp timestamp;
-+
-+ const char *domain = "";
-+
-+ int rc, rcISC;
-+ SecPkgInfo *secPackInfo;
-+ SEC_WINNT_AUTH_IDENTITY *nameAndPwd = NULL;
-+ int bytesReceived = 0, bytesSent = 0;
-+
-+ nameAndPwd = (SEC_WINNT_AUTH_IDENTITY *) malloc( sizeof(SEC_WINNT_AUTH_IDENTITY) );
-+ memset( nameAndPwd, '\0', sizeof (*nameAndPwd) );
-+ nameAndPwd->Domain = (unsigned char *) _strdup( domain? domain: "" );
-+ nameAndPwd->DomainLength = domain? strlen( domain ): 0;
-+ nameAndPwd->User = (unsigned char *) _strdup( username? username: "" );
-+ nameAndPwd->UserLength = username? strlen( username ): 0;
-+ nameAndPwd->Password = (unsigned char *) _strdup( password? password: "" );
-+ nameAndPwd->PasswordLength = password? strlen( password ): 0;
-+ nameAndPwd->Flags = SEC_WINNT_AUTH_IDENTITY_ANSI;
-+
-+ status = pSFT->AcquireCredentialsHandle( NULL, package, SECPKG_CRED_OUTBOUND,
-+ NULL, nameAndPwd, NULL, NULL, credentials, ×tamp );
-+
-+ if (status != SEC_E_OK) {
-+ NE_DEBUG(NE_DBG_HTTPAUTH,
-+ "sspi: AcquireCredentialsHandle [fail] [%x].\n", status);
-+ return -1;
-+ }
-+
- return 0;
- }
-
-+
- /*
- * Wrapper arround initializeSecurityContext. Supplies several
- * default parameters as well as logging in case of errors.
-@@ -483,7 +522,7 @@
- * Processes received authentication tokens as well as supplies the
- * response token.
- */
--int ne_sspi_authenticate(void *context, const char *base64Token, char **responseToken)
-+int ne_sspi_authenticate(void *context, const char *base64Token, char **responseToken, const char* username, const char* password)
- {
- SecBufferDesc outBufferDesc;
- SecBuffer outBuffer;
-@@ -552,7 +591,7 @@
- {
- freeBuffer(&outBufferDesc);
- sspiContext->authfinished = 0;
-- NE_DEBUG(NE_DBG_HTTPAUTH,"sspi: failing because starting over from failed try.\n");
-+ NE_DEBUG(NE_DBG_HTTPAUTH,"sspi: fai6 over from failed try.\n");
- return -1;
- }
- sspiContext->authfinished = 0;
-@@ -560,14 +599,26 @@
-
- /* Reset any existing context since we are starting over */
- resetContext(sspiContext);
-+
-+ if (strlen(username) != 0) {
-+ if (acquireCredentialsHandleForUsername
-+ (&sspiContext->credentials, sspiContext->mechanism, username, password) != SEC_E_OK) {
-+ freeBuffer(&outBufferDesc);
-+ NE_DEBUG(NE_DBG_HTTPAUTH,
-+ "sspi: acquireCredentialsHandleForUsername failed.\n");
-+ return -1;
-+ }
-+ } else {
-+ if (acquireCredentialsHandle
-+ (&sspiContext->credentials, sspiContext->mechanism) != SEC_E_OK) {
-+ freeBuffer(&outBufferDesc);
-+ NE_DEBUG(NE_DBG_HTTPAUTH,
-+ "sspi: acquireCredentialsHandle failed.\n");
-+ return -1;
-+ }
-+ }
-
-- if (acquireCredentialsHandle
-- (&sspiContext->credentials, sspiContext->mechanism) != SEC_E_OK) {
-- freeBuffer(&outBufferDesc);
-- NE_DEBUG(NE_DBG_HTTPAUTH,
-- "sspi: acquireCredentialsHandle failed.\n");
-- return -1;
-- }
-+
-
- securityStatus =
- initializeSecurityContext(&sspiContext->credentials, NULL,
---- misc/neon-0.28.2/src/ne_sspi.h 2006-02-12 13:05:14.000000000 +0100
-+++ misc/build/neon-0.28.2/src/ne_sspi.h 2008-08-25 14:32:18.000000000 +0200
-@@ -41,7 +41,7 @@
- int ne_sspi_clear_context(void *context);
-
- int ne_sspi_authenticate(void *context, const char *base64Token,
-- char **responseToken);
-+ char **responseToken, const char* username, const char* password);
-
- #endif /* HAVE_SSPI */
-
---- misc/neon-0.28.2/src/ne_uri.c 2007-12-05 12:04:47.000000000 +0100
-+++ misc/build/neon-0.28.2/src/ne_uri.c 2009-01-09 10:21:45.201720200 +0100
-@@ -42,7 +42,7 @@
- #include "ne_alloc.h"
- #include "ne_uri.h"
-
--/* URI ABNF from RFC 3986: */
-+/* URI ABNF from RFC 3986: (TKR: SharePoint is contradictory to this RFC. So I fix it here. )*/
-
- #define PS (0x0001) /* "+" */
- #define PC (0x0002) /* "%" */
-@@ -67,6 +67,9 @@
-
- #define OT (0x4000) /* others */
-
-+/* TKR new symbol */
-+#define WS (0x8000) /* Whitespaces ( Space, Tab ) */
-+
- #define URI_ALPHA (AL)
- #define URI_DIGIT (DG)
-
-@@ -83,20 +86,21 @@
- /* pchar = unreserved / pct-encoded / sub-delims / ":" / "@" */
- #define URI_PCHAR (URI_UNRESERVED | PC | URI_SUBDELIM | CL | AT)
- /* invented: segchar = pchar / "/" */
--#define URI_SEGCHAR (URI_PCHAR | FS)
-+/* (TKR) WS added */
-+#define URI_SEGCHAR (URI_PCHAR | FS | WS)
- /* query = *( pchar / "/" / "?" ) */
- #define URI_QUERY (URI_PCHAR | FS | QU)
- /* fragment == query */
- #define URI_FRAGMENT URI_QUERY
-
- /* any characters which should be path-escaped: */
--#define URI_ESCAPE ((URI_GENDELIM & ~(FS)) | URI_SUBDELIM | OT | PC)
-+#define URI_ESCAPE ((URI_GENDELIM & ~(FS)) | URI_SUBDELIM | OT | WS | PC)
-
- static const unsigned int uri_chars[256] = {
- /* 0xXX x0 x2 x4 x6 x8 xA xC xE */
--/* 0x */ OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT,
-+/* 0x */ OT, OT, OT, OT, OT, OT, OT, OT, OT, WS, OT, OT, OT, OT, OT, OT,
- /* 1x */ OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT,
--/* 2x */ OT, SD, OT, GD, SD, PC, SD, SD, SD, SD, SD, PS, SD, DS, DT, FS,
-+/* 2x */ WS, SD, OT, GD, SD, PC, SD, SD, SD, SD, SD, PS, SD, DS, DT, FS,
- /* 3x */ DG, DG, DG, DG, DG, DG, DG, DG, DG, DG, CL, SD, OT, SD, OT, QU,
- /* 4x */ AT, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL,
- /* 5x */ AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, GD, OT, GD, OT, US,
+--- misc/neon-0.28.2/src/config.h 2009-06-24 12:49:38.000000000 +0200 ++++ misc/build/neon-0.28.2/src/config.h 2009-06-24 12:46:45.000000000 +0200 +@@ -1 +1,484 @@ +-dummy ++ ++/* Define to specific EGD socket path */ ++/* #undef EGD_PATH */ ++ ++/* Define if EGD should be supported */ ++/* #undef ENABLE_EGD */ ++ ++/* Define if GSS_C_NT_HOSTBASED_SERVICE is not defined otherwise */ ++/* #undef GSS_C_NT_HOSTBASED_SERVICE */ ++ ++/* Define to 1 if you have the <arpa/inet.h> header file. */ ++#ifdef UNX ++#define HAVE_ARPA_INET_H 1 ++#endif ++ ++/* Define to 1 if you have the `bind_textdomain_codeset' function. */ ++/* #undef HAVE_BIND_TEXTDOMAIN_CODESET 1 */ ++ ++/* Define to 1 if you have the declaration of `h_errno', and to 0 if you ++ don't. */ ++#ifdef WIN32 ++#define HAVE_DECL_H_ERRNO 1 ++#endif ++ ++/* Define to 1 if you have the declaration of `stpcpy', and to 0 if you don't. ++ */ ++#ifdef LINUX ++#define HAVE_DECL_STPCPY 1 ++#endif ++ ++/* Define to 1 if you have the declaration of `strerror_r', and to 0 if you ++ don't. */ ++#ifdef LINUX ++#define HAVE_DECL_STRERROR_R 1 ++#endif ++ ++/* Define to 1 if you have the <dlfcn.h> header file. */ ++#ifdef UNX ++#define HAVE_DLFCN_H 1 ++#endif ++ ++/* Define to 1 if you have the <errno.h> header file. */ ++#define HAVE_ERRNO_H 1 ++ ++/* Define if you have expat */ ++/* #undef HAVE_EXPAT */ ++ ++/* Define to 1 if you have the `fstat64' function. */ ++#define HAVE_FSTAT64 ++ ++/* Define to 1 if you have the `gai_strerror' function. */ ++#define HAVE_GAI_STRERROR 1 ++ ++/* Define if GnuTLS support is enabled */ ++/* #undef HAVE_GNUTLS */ ++ ++/* Define to 1 if you have the `gnutls_session_get_data2' function. */ ++/* #undef HAVE_GNUTLS_SESSION_GET_DATA2 */ ++ ++/* Define if GSSAPI support is enabled */ ++/* #undef HAVE_GSSAPI */ ++ ++/* Define to 1 if you have the <gssapi/gssapi_generic.h> header file. */ ++/* #undef HAVE_GSSAPI_GSSAPI_GENERIC_H */ ++ ++/* Define to 1 if you have the <gssapi/gssapi.h> header file. */ ++/* #undef HAVE_GSSAPI_GSSAPI_H */ ++ ++/* Define to 1 if you have the <gssapi.h> header file. */ ++/* #undef HAVE_GSSAPI_H */ ++ ++/* Define to 1 if you have the `gss_init_sec_context' function. */ ++/* #undef HAVE_GSS_INIT_SEC_CONTEXT */ ++ ++/* Define to 1 if you have the `hstrerror' function. */ ++/* #undef HAVE_HSTRERROR */ ++ ++/* Define to 1 if you have the `inet_ntop' function. */ ++#ifdef UNX ++#define HAVE_INET_NTOP 1 ++#endif ++ ++/* Define to 1 if you have the <inttypes.h> header file. */ ++#ifdef UNX ++#define HAVE_INTTYPES_H 1 ++#endif ++ ++/* Define to 1 if you have the `isatty' function. */ ++#define HAVE_ISATTY 1 ++ ++/* Define to 1 if you have the <libintl.h> header file. */ ++/* #undef HAVE_LIBINTL_H */ ++ ++/* Define if you have libxml */ ++#define HAVE_LIBXML 1 ++ ++/* Define to 1 if you have the <libxml/parser.h> header file. */ ++#define HAVE_LIBXML_PARSER_H 1 ++ ++/* Define to 1 if you have the <libxml/xmlversion.h> header file. */ ++#define HAVE_LIBXML_XMLVERSION_H 1 ++ ++/* Define to 1 if you have the <limits.h> header file. */ ++#define HAVE_LIMITS_H 1 ++ ++/* Define to 1 if you have the <locale.h> header file. */ ++#define HAVE_LOCALE_H 1 ++ ++/* Define to 1 if you have the `lseek64' function. */ ++#define HAVE_LSEEK64 1 ++ ++/* Define to 1 if you have the <memory.h> header file. */ ++#define HAVE_MEMORY_H 1 ++ ++/* Define to 1 if you have the <netdb.h> header file. */ ++#ifdef UNX ++#define HAVE_NETDB_H 1 ++#endif ++ ++/* Define to 1 if you have the <netinet/in.h> header file. */ ++#ifdef UNX ++#define HAVE_NETINET_IN_H 1 ++#endif ++ ++/* Define to 1 if you have the <netinet/tcp.h> header file. */ ++#ifdef UNX ++#define HAVE_NETINET_TCP_H 1 ++#endif ++ ++/* Define if OpenSSL support is enabled */ ++/* #undef HAVE_OPENSSL */ ++#define HAVE_OPENSSL ++/* Define to 1 if you have the <openssl/opensslv.h> header file. */ ++/* #undef HAVE_OPENSSL_OPENSSLV_H */ ++#define HAVE_OPENSSL_OPENSSLV_H 1 ++/* Define to 1 if you have the <openssl/ssl.h> header file. */ ++/* #undef HAVE_OPENSSL_SSL_H */ ++#define HAVE_OPENSSL_SSL_H 1 ++/* Define to 1 if you have the `pipe' function. */ ++#define HAVE_PIPE 1 ++ ++/* Define to 1 if you have the `poll' function. */ ++#define HAVE_POLL 1 ++ ++/* Define to 1 if you have the `pthread_mutex_init' function. */ ++/* #undef HAVE_PTHREAD_MUTEX_INIT */ ++ ++/* Define to 1 if you have the `pthread_mutex_lock' function. */ ++/* #undef HAVE_PTHREAD_MUTEX_LOCK */ ++ ++/* Define to 1 if you have the `setlocale' function. */ ++#define HAVE_SETLOCALE 1 ++ ++/* Define to 1 if you have the `setsockopt' function. */ ++#if defined (LINUX) || defined (WIN32) ++#define HAVE_SETSOCKOPT 1 ++#endif ++ ++/* Define to 1 if you have the `setvbuf' function. */ ++#define HAVE_SETVBUF 1 ++ ++/* Define to 1 if you have the `shutdown' function. */ ++#ifdef LINUX ++#define HAVE_SHUTDOWN 1 ++#endif ++ ++/* Define to 1 if you have the `signal' function. */ ++#define HAVE_SIGNAL 1 ++ ++/* Define to 1 if you have the <signal.h> header file. */ ++#define HAVE_SIGNAL_H 1 ++ ++/* Define to 1 if you have the `snprintf' function. */ ++#ifdef UNX ++#define HAVE_SNPRINTF 1 ++#endif ++ ++#ifdef WIN32 ++#define snprintf _snprintf ++#endif ++ ++/* Define to 1 if you have the <socks.h> header file. */ ++/* #undef HAVE_SOCKS_H */ ++ ++/* Define to 1 if you have the <stdarg.h> header file. */ ++#define HAVE_STDARG_H 1 ++ ++/* Define to 1 if you have the <stdint.h> header file. */ ++#define HAVE_STDINT_H 1 ++ ++/* Define to 1 if you have the <stdlib.h> header file. */ ++#define HAVE_STDLIB_H 1 ++ ++/* Define to 1 if you have the `stpcpy' function. */ ++#ifdef LINUX ++#define HAVE_STPCPY 1 ++#endif ++ ++/* Define to 1 if you have the `strcasecmp' function. */ ++#ifdef UNX ++#define HAVE_STRCASECMP 1 ++#endif ++ ++#ifdef WIN32 ++#define strcasecmp strcmpi ++#endif ++ ++/* Define to 1 if you have the `strerror_r' function. */ ++#ifdef LINUX ++#define HAVE_STRERROR_R 1 ++#endif ++ ++/* Define to 1 if you have the <strings.h> header file. */ ++#ifdef UNX ++#define HAVE_STRINGS_H 1 ++#endif ++ ++/* Define to 1 if you have the <string.h> header file. */ ++#define HAVE_STRING_H 1 ++ ++/* Define to 1 if you have the `strtoll' function. */ ++#define HAVE_STRTOLL 1 ++ ++/* Define to 1 if you have the `strtoq' function. */ ++/* #undef HAVE_STRTOQ */ ++ ++/* Define to 1 if `tm_gmtoff' is member of `struct tm'. */ ++#ifdef LINUX ++#define HAVE_STRUCT_TM_TM_GMTOFF 1 ++#endif ++ ++/* Define to 1 if `__tm_gmtoff' is member of `struct tm'. */ ++/* #undef HAVE_STRUCT_TM___TM_GMTOFF */ ++ ++/* Define to 1 if you have the <sys/limits.h> header file. */ ++/* #undef HAVE_SYS_LIMITS_H */ ++ ++/* Define to 1 if you have the <sys/poll.h> header file. */ ++#ifdef UNX ++#define HAVE_SYS_POLL_H 1 ++#endif ++ ++/* Define to 1 if you have the <sys/select.h> header file. */ ++#ifdef UNX ++#define HAVE_SYS_SELECT_H 1 ++#endif ++ ++/* Define to 1 if you have the <sys/socket.h> header file. */ ++#ifdef UNX ++#define HAVE_SYS_SOCKET_H 1 ++#endif ++ ++/* Define to 1 if you have the <sys/stat.h> header file. */ ++#define HAVE_SYS_STAT_H 1 ++ ++/* Define to 1 if you have the <sys/time.h> header file. */ ++#ifdef UNX ++#define HAVE_SYS_TIME_H 1 ++#endif ++ ++/* Define to 1 if you have the <sys/types.h> header file. */ ++#define HAVE_SYS_TYPES_H 1 ++ ++/* Define if the timezone global is available */ ++#ifndef MACOSX ++#define HAVE_TIMEZONE 1 ++#endif ++ ++/* Use trio printf replacement library */ ++/* #undef HAVE_TRIO */ ++ ++/* Define to 1 if you have the <trio.h> header file. */ ++/* #undef HAVE_TRIO_H */ ++ ++/* Define to 1 if you have the <unistd.h> header file. */ ++#ifdef UNX ++#define HAVE_UNISTD_H 1 ++#endif ++ ++/* Define to 1 if you have the `usleep' function. */ ++#ifdef UNX ++#define HAVE_USLEEP 1 ++#endif ++ ++/* Define to 1 if you have the `vsnprintf' function. */ ++#if defined( UNX ) || (defined(_MSC_VER) && (_MSC_VER > 1400)) ++#define HAVE_VSNPRINTF 1 ++#endif ++ ++#ifdef WIN32 ++#if (defined(_MSC_VER) && (_MSC_VER < 1500)) || defined(__MINGW32__) ++#define vsnprintf _vsnprintf ++#endif ++#endif ++ ++/* Define to be location of localedir */ ++/* #undef LOCALEDIR */ ++ ++/* Defined when neon is built as a library */ ++#define NEON_IS_LIBRARY 1 ++ ++/* Define to be the neon version string */ ++#define NEON_VERSION "0.28.2" ++ ++/* Define to enable debugging */ ++/* #undef NE_DEBUGGING */ ++ ++/* Define to be printf format string for off64_t */ ++#define NE_FMT_OFF64_T "lld" ++ ++/* Define to be printf format string for off_t */ ++#define NE_FMT_OFF_T "ld" ++ ++/* Define to be printf format string for size_t */ ++#define NE_FMT_SIZE_T "u" ++ ++/* Define to be printf format string for ssize_t */ ++#define NE_FMT_SSIZE_T "d" ++ ++/* Define to be printf format string for time_t */ ++#define NE_FMT_TIME_T "ld" ++ ++/* Defined if DAV is supported */ ++#define NE_HAVE_DAV 1 ++ ++/* Defined if I18N is supported */ ++/* #undef NE_HAVE_I18N 1 */ ++ ++/* Defined if IPV6 is supported */ ++#define NE_HAVE_IPV6 1 ++ ++/* Defined if LFS is supported */ ++#define NE_HAVE_LFS 1 ++ ++/* Defined if SOCKS is supported */ ++/* #undef NE_HAVE_SOCKS */ ++ ++/* Defined if SSL is supported */ ++/* #undef NE_HAVE_SSL */ ++#define NE_HAVE_SSL ++/* Defined if TS_SSL is supported */ ++/* #undef NE_HAVE_TS_SSL */ ++ ++/* Defined if ZLIB is supported */ ++/* #undef NE_HAVE_ZLIB */ ++ ++/* Define to be filename of an SSL CA root bundle */ ++/* #undef NE_SSL_CA_BUNDLE */ ++ ++/* Define if poll() should be used */ ++#ifdef UNX ++#define NE_USE_POLL 1 ++#endif ++ ++/* Define to be neon library major version */ ++#define NE_VERSION_MAJOR (0) ++ ++/* Define to be neon library minor version */ ++#define NE_VERSION_MINOR (28) ++ ++/* Define to be neon library patch version */ ++#define NE_VERSION_PATCH (2) ++ ++/* Define to the address where bug reports for this package should be sent. */ ++#define PACKAGE_BUGREPORT "neon@webdav.org" ++ ++/* Define to the full name of this package. */ ++#define PACKAGE_NAME "neon" ++ ++/* Define to the full name and version of this package. */ ++#define PACKAGE_STRING "neon 0.28.2" ++ ++/* Define to the one symbol short name of this package. */ ++#define PACKAGE_TARNAME "neon" ++ ++/* Define to the version of this package. */ ++#define PACKAGE_VERSION "0.28.2" ++ ++/* The size of a `int', as computed by sizeof. */ ++#define SIZEOF_INT 4 ++ ++/* The size of a `long', as computed by sizeof. */ ++#define SIZEOF_LONG 4 ++ ++/* The size of a `long long', as computed by sizeof. */ ++#define SIZEOF_LONG_LONG 8 ++ ++/* The size of a `off64_t', as computed by sizeof. */ ++#define SIZEOF_OFF64_T 8 ++ ++/* The size of a `off_t', as computed by sizeof. */ ++#define SIZEOF_OFF_T 4 ++ ++/* The size of a `size_t', as computed by sizeof. */ ++#define SIZEOF_SIZE_T 4 ++ ++/* The size of a `ssize_t', as computed by sizeof. */ ++#define SIZEOF_SSIZE_T 4 ++ ++/* The size of a `time_t', as computed by sizeof. */ ++#define SIZEOF_TIME_T 4 ++ ++/* Define to 1 if you have the ANSI C header files. */ ++#ifdef SOLARIS ++#define STDC_HEADERS 1 ++#endif ++ ++/* Define to 1 if strerror_r returns char *. */ ++#ifdef LINUX ++#define STRERROR_R_CHAR_P 1 ++#endif ++ ++/* Define to 1 if you can safely include both <sys/time.h> and <time.h>. */ ++#define TIME_WITH_SYS_TIME 1 ++ ++/* Define if getaddrinfo supports AI_ADDRCONFIG */ ++/* #undef USE_GAI_ADDRCONFIG */ ++ ++/* Define if getaddrinfo() should be used */ ++#define USE_GETADDRINFO 1 ++ ++/* Define to 1 if your processor stores words with the most significant byte ++ first (like Motorola and SPARC, unlike Intel and VAX). */ ++#if defined (SOLARIS) && defined (SPARC) ++#define WORDS_BIGENDIAN 1 ++#endif ++ ++/* Always defined to enable GNU extensions */ ++#define _GNU_SOURCE 1 ++ ++/* Define to empty if `const' does not conform to ANSI C. */ ++/* #undef const */ ++ ++/* Define if in_addr_t is not available */ ++/* #undef in_addr_t */ ++ ++/* Define to `__inline__' or `__inline' if that's what the C compiler ++ calls it, or to nothing if 'inline' is not supported under any name. */ ++#ifndef __cplusplus ++#if defined (SOLARIS) && defined (__SUNPRO_C) ++#define inline ++#endif ++#endif ++ ++/* Define to `long' if <sys/types.h> does not define. */ ++/* #undef off_t */ ++ ++/* Define to `int' if <sys/types.h> does not define. */ ++/* #undef pid_t */ ++ ++/* Define to `unsigned' if <sys/types.h> does not define. */ ++/* #undef size_t */ ++ ++ ++/* Enable leak-tracking versions of ne_*alloc when NEON_MEMLEAK is enabled */ ++#ifdef NEON_MEMLEAK ++# include "memleak.h" ++#endif ++ ++#if defined(HAVE_STPCPY) && defined(HAVE_DECL_STPCPY) && !HAVE_DECL_STPCPY && !defined(stpcpy) ++char *stpcpy(char *, const char *); ++#endif ++ ++#ifdef WIN32 ++ ++#include <io.h> ++ ++#define HAVE_MEMCPY 1 ++ ++#define strncasecmp strnicmp ++#define inline __inline ++#define WIN32_LEAN_AND_MEAN ++#define NOUSER ++#define NOGDI ++#define NONLS ++#define NOCRYPT ++ ++#endif ++ ++#ifdef WIN32 ++#define HAVE_SSPI 1 ++#else ++#define HAVE_NTLM 1 ++#endif +--- misc/neon-0.28.2/src/makefile.mk 2009-06-24 12:49:38.000000000 +0200 ++++ misc/build/neon-0.28.2/src/makefile.mk 2009-06-24 12:46:45.000000000 +0200 +@@ -1 +1,59 @@ +-dummy ++PRJ=..$/..$/..$/..$/.. ++ ++PRJNAME=neon ++TARGET=neon ++LIBTARGET=NO ++EXTERNAL_WARNINGS_NOT_ERRORS := TRUE ++ ++# --- Settings ----------------------------------------------------- ++ ++.INCLUDE : settings.mk ++ ++# --- Files -------------------------------------------------------- ++ ++CDEFS+=-DHAVE_CONFIG_H ++ ++.IF "$(SYSTEM_LIBXML)" == "YES" ++CFLAGS+=-DSYSTEM_LIBXML $(LIBXML_CFLAGS) ++.ENDIF ++ ++ ++SLOFILES= \ ++ $(SLO)$/ne_207.obj \ ++ $(SLO)$/ne_acl.obj \ ++ $(SLO)$/ne_alloc.obj \ ++ $(SLO)$/ne_auth.obj \ ++ $(SLO)$/ne_basic.obj \ ++ $(SLO)$/ne_compress.obj \ ++ $(SLO)$/ne_dates.obj \ ++ $(SLO)$/ne_i18n.obj \ ++ $(SLO)$/ne_locks.obj \ ++ $(SLO)$/ne_md5.obj \ ++ $(SLO)$/ne_props.obj \ ++ $(SLO)$/ne_redirect.obj \ ++ $(SLO)$/ne_request.obj \ ++ $(SLO)$/ne_session.obj \ ++ $(SLO)$/ne_socket.obj \ ++ $(SLO)$/ne_string.obj \ ++ $(SLO)$/ne_uri.obj \ ++ $(SLO)$/ne_utils.obj \ ++ $(SLO)$/ne_xml.obj \ ++ $(SLO)$/ne_xmlreq.obj \ ++ $(SLO)$/ne_openssl.obj ++ ++.IF "$(OS)"=="WNT" ++SLOFILES+=$(SLO)$/ne_sspi.obj ++.ELSE ++SLOFILES+=$(SLO)$/ne_ntlm.obj ++.ENDIF ++ ++# $(SLO)$/ne_gnutls.obj \ ++# $(SLO)$/ne_stubssl.obj ++ ++LIB1TARGET=$(SLB)$/$(TARGET).lib ++LIB1ARCHIV=$(LB)$/lib$(TARGET).a ++LIB1OBJFILES=$(SLOFILES) ++ ++# --- Targets ------------------------------------------------------ ++ ++.INCLUDE : target.mk +--- misc/neon-0.28.2/src/ne_auth.c 2008-02-29 17:30:12.000000000 +0100 ++++ misc/build/neon-0.28.2/src/ne_auth.c 2009-06-24 12:46:45.000000000 +0200 +@@ -77,6 +77,10 @@ + #include "ne_sspi.h" + #endif + ++#ifdef HAVE_NTLM ++#include "ne_ntlm.h" ++#endif ++ + #define HOOK_SERVER_ID "http://webdav.org/neon/hooks/server-auth" + #define HOOK_PROXY_ID "http://webdav.org/neon/hooks/proxy-auth" + +@@ -173,6 +177,10 @@ + char *sspi_token; + void *sspi_context; + #endif ++#ifdef HAVE_NTLM ++ /* This is used for NTLM auth */ ++ ne_ntlm_context *ntlm_context; ++#endif + /* These all used for Digest auth */ + char *realm; + char *nonce; +@@ -287,6 +295,11 @@ + ne_sspi_destroy_context(sess->sspi_context); + sess->sspi_context = NULL; + #endif ++#ifdef HAVE_NTLM ++ ne_ntlm_destroy_context(sess->ntlm_context); ++ sess->ntlm_context = NULL; ++#endif ++ sess->protocol = NULL; + } + + /* Returns client nonce string. */ +@@ -598,9 +611,10 @@ + int ntlm = ne_strcasecmp(parms->protocol->name, "NTLM") == 0; + int status; + char *response = NULL; +- ++ char password[NE_ABUFSIZ]; ++ + NE_DEBUG(NE_DBG_HTTPAUTH, "auth: SSPI challenge.\n"); +- ++ + if (!sess->sspi_context) { + ne_uri uri = {0}; + +@@ -614,8 +628,17 @@ + return status; + } + } ++ ++ /* Authentification needs more than one http request. ++ * As long as authentification in progress use the existing credentials. ++ * Otherwise get new credentials.*/ ++ if (!parms->opaque) ++ if (get_credentials(sess, errmsg, attempt, parms, password)) { ++ /* Failed to get credentials */ ++ return -1; ++ } + +- status = ne_sspi_authenticate(sess->sspi_context, parms->opaque, &response); ++ status = ne_sspi_authenticate(sess->sspi_context, parms->opaque, &response, sess->username, password); + if (status) { + return status; + } +@@ -685,6 +708,62 @@ + return invalid; + } + ++#ifdef HAVE_NTLM ++ ++static char *request_ntlm(auth_session *sess, struct auth_request *request) ++{ ++ char *token = ne_ntlm_getRequestToken(sess->ntlm_context); ++ if (token) { ++ char * req = ne_concat(sess->protocol->name, " ", token, "\r\n", NULL); ++ ne_free(token); ++ return req; ++ } else { ++ return NULL; ++ } ++} ++ ++static int ntlm_challenge(auth_session *sess, int attempt, ++ struct auth_challenge *parms, ++ ne_buffer **errmsg) ++{ ++ int status; ++ ++ NE_DEBUG(NE_DBG_HTTPAUTH, "auth: NTLM challenge.\n"); ++ ++ if (!parms->opaque) { ++ char password[NE_ABUFSIZ]; ++ ++ if (get_credentials(sess, errmsg, attempt, parms, password)) { ++ /* Failed to get credentials */ ++ return -1; ++ } ++ ++ if (sess->ntlm_context) { ++ status = ne_ntlm_destroy_context(sess->ntlm_context); ++ sess->ntlm_context = NULL; ++ if (status) { ++ return status; ++ } ++ } ++ ++ status = ne_ntlm_create_context(&sess->ntlm_context, ++ sess->username, ++ password); ++ if (status) { ++ return status; ++ } ++ } ++ ++ status = ne_ntlm_authenticate(sess->ntlm_context, parms->opaque); ++ if (status) { ++ return status; ++ } ++ ++ return 0; ++} ++#endif /* HAVE_NTLM */ ++ ++ + /* Examine a digest challenge: return 0 if it is a valid Digest challenge, + * else non-zero. */ + static int digest_challenge(auth_session *sess, int attempt, +@@ -1134,6 +1213,11 @@ + sspi_challenge, request_sspi, NULL, + AUTH_FLAG_OPAQUE_PARAM|AUTH_FLAG_VERIFY_NON40x|AUTH_FLAG_CONN_AUTH }, + #endif ++#ifdef HAVE_NTLM ++ { NE_AUTH_NEGOTIATE, 30, "NTLM", ++ ntlm_challenge, request_ntlm, NULL, ++ AUTH_FLAG_OPAQUE_PARAM|AUTH_FLAG_VERIFY_NON40x|AUTH_FLAG_CONN_AUTH }, ++#endif + { 0 } + }; + +@@ -1431,6 +1515,11 @@ + ne_sspi_clear_context(sess->sspi_context); + } + #endif ++#ifdef HAVE_NTLM ++ if (sess->ntlm_context) { ++ ne_ntlm_clear_context(sess->ntlm_context); ++ } ++#endif + + return ret; + } +--- misc/neon-0.28.2/src/ne_defs.h 2006-10-24 21:40:09.000000000 +0200 ++++ misc/build/neon-0.28.2/src/ne_defs.h 2009-06-24 12:46:45.000000000 +0200 +@@ -41,7 +41,7 @@ + #endif + + /* define ssize_t for Win32 */ +-#if defined(WIN32) && !defined(ssize_t) ++#if defined(WIN32) && !defined(ssize_t) && !defined(__MINGW32__) + #define ssize_t int + #endif + +--- misc/neon-0.28.2/src/ne_locks.h 2006-01-02 12:43:19.000000000 +0100 ++++ misc/build/neon-0.28.2/src/ne_locks.h 2009-06-24 12:46:45.000000000 +0200 +@@ -22,6 +22,10 @@ + #ifndef NE_LOCKS_H + #define NE_LOCKS_H + ++# if defined __GNUC__ ++# pragma GCC system_header ++# endif ++ + #include "ne_request.h" /* for ne_session + ne_request */ + #include "ne_uri.h" /* for ne_uri */ + +--- misc/neon-0.28.2/src/ne_ntlm.c 2009-06-24 12:49:38.000000000 +0200 ++++ misc/build/neon-0.28.2/src/ne_ntlm.c 2009-06-24 12:46:45.000000000 +0200 +@@ -1 +1,700 @@ +-dummy ++/* ++ Handling of NTLM Authentication ++ Copyright (C) 2003, Daniel Stenberg <daniel@haxx.se> ++ Copyright (C) 2009, Kai Sommerfeld <kso@openoffice.org> ++ ++ This library is free software; you can redistribute it and/or ++ modify it under the terms of the GNU Library General Public ++ License as published by the Free Software Foundation; either ++ version 2 of the License, or (at your option) any later version. ++ ++ This library is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ Library General Public License for more details. ++ ++ You should have received a copy of the GNU Library General Public ++ License along with this library; if not, write to the Free ++ Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, ++ MA 02111-1307, USA ++ ++*/ ++ ++/* NTLM details: ++ ++ http://davenport.sourceforge.net/ntlm.html ++ http://www.innovation.ch/java/ntlm.html ++ ++*/ ++ ++#include "ne_ntlm.h" ++ ++#ifdef HAVE_NTLM ++ ++#include "ne_string.h" ++ ++typedef enum { ++ NTLMSTATE_NONE, ++ NTLMSTATE_TYPE1, ++ NTLMSTATE_TYPE2, ++ NTLMSTATE_TYPE3, ++ NTLMSTATE_LAST ++} NTLMState; ++ ++struct ne_ntlm_context_s { ++ NTLMState state; ++ unsigned char nonce[8]; ++ char *user; ++ char *passwd; ++ char *requestToken; ++}; ++ ++typedef enum { ++ NTLM_NONE, /* not a ntlm */ ++ NTLM_BAD, /* an ntlm, but one we don't like */ ++ NTLM_FIRST, /* the first 401-reply we got with NTLM */ ++ NTLM_FINE, /* an ntlm we act on */ ++ ++ NTLM_LAST /* last entry in this enum, don't use */ ++} ntlm; ++ ++/* Flag bits definitions based on http://davenport.sourceforge.net/ntlm.html */ ++ ++#define NTLMFLAG_NEGOTIATE_UNICODE (1<<0) ++/* Indicates that Unicode strings are supported for use in security buffer ++ data. */ ++ ++#define NTLMFLAG_NEGOTIATE_OEM (1<<1) ++/* Indicates that OEM strings are supported for use in security buffer data. */ ++ ++#define NTLMFLAG_REQUEST_TARGET (1<<2) ++/* Requests that the server's authentication realm be included in the Type 2 ++ message. */ ++ ++/* unknown (1<<3) */ ++#define NTLMFLAG_NEGOTIATE_SIGN (1<<4) ++/* Specifies that authenticated communication between the client and server ++ should carry a digital signature (message integrity). */ ++ ++#define NTLMFLAG_NEGOTIATE_SEAL (1<<5) ++/* Specifies that authenticated communication between the client and server ++ should be encrypted (message confidentiality). */ ++ ++#define NTLMFLAG_NEGOTIATE_DATAGRAM_STYLE (1<<6) ++/* unknown purpose */ ++ ++#define NTLMFLAG_NEGOTIATE_LM_KEY (1<<7) ++/* Indicates that the LAN Manager session key should be used for signing and ++ sealing authenticated communications. */ ++ ++#define NTLMFLAG_NEGOTIATE_NETWARE (1<<8) ++/* unknown purpose */ ++ ++#define NTLMFLAG_NEGOTIATE_NTLM_KEY (1<<9) ++/* Indicates that NTLM authentication is being used. */ ++ ++/* unknown (1<<10) */ ++/* unknown (1<<11) */ ++ ++#define NTLMFLAG_NEGOTIATE_DOMAIN_SUPPLIED (1<<12) ++/* Sent by the client in the Type 1 message to indicate that a desired ++ authentication realm is included in the message. */ ++ ++#define NTLMFLAG_NEGOTIATE_WORKSTATION_SUPPLIED (1<<13) ++/* Sent by the client in the Type 1 message to indicate that the client ++ workstation's name is included in the message. */ ++ ++#define NTLMFLAG_NEGOTIATE_LOCAL_CALL (1<<14) ++/* Sent by the server to indicate that the server and client are on the same ++ machine. Implies that the client may use a pre-established local security ++ context rather than responding to the challenge. */ ++ ++#define NTLMFLAG_NEGOTIATE_ALWAYS_SIGN (1<<15) ++/* Indicates that authenticated communication between the client and server ++ should be signed with a "dummy" signature. */ ++ ++#define NTLMFLAG_TARGET_TYPE_DOMAIN (1<<16) ++/* Sent by the server in the Type 2 message to indicate that the target ++ authentication realm is a domain. */ ++ ++#define NTLMFLAG_TARGET_TYPE_SERVER (1<<17) ++/* Sent by the server in the Type 2 message to indicate that the target ++ authentication realm is a server. */ ++ ++#define NTLMFLAG_TARGET_TYPE_SHARE (1<<18) ++/* Sent by the server in the Type 2 message to indicate that the target ++ authentication realm is a share. Presumably, this is for share-level ++ authentication. Usage is unclear. */ ++ ++#define NTLMFLAG_NEGOTIATE_NTLM2_KEY (1<<19) ++/* Indicates that the NTLM2 signing and sealing scheme should be used for ++ protecting authenticated communications. */ ++ ++#define NTLMFLAG_REQUEST_INIT_RESPONSE (1<<20) ++/* unknown purpose */ ++ ++#define NTLMFLAG_REQUEST_ACCEPT_RESPONSE (1<<21) ++/* unknown purpose */ ++ ++#define NTLMFLAG_REQUEST_NONNT_SESSION_KEY (1<<22) ++/* unknown purpose */ ++ ++#define NTLMFLAG_NEGOTIATE_TARGET_INFO (1<<23) ++/* Sent by the server in the Type 2 message to indicate that it is including a ++ Target Information block in the message. */ ++ ++/* unknown (1<24) */ ++/* unknown (1<25) */ ++/* unknown (1<26) */ ++/* unknown (1<27) */ ++/* unknown (1<28) */ ++ ++#define NTLMFLAG_NEGOTIATE_128 (1<<29) ++/* Indicates that 128-bit encryption is supported. */ ++ ++#define NTLMFLAG_NEGOTIATE_KEY_EXCHANGE (1<<30) ++/* unknown purpose */ ++ ++#define NTLMFLAG_NEGOTIATE_56 (1<<31) ++/* Indicates that 56-bit encryption is supported. */ ++ ++#ifdef HAVE_OPENSSL ++/* We need OpenSSL for the crypto lib to provide us with MD4 and DES */ ++ ++/* -- WIN32 approved -- */ ++#include <stdio.h> ++#include <string.h> ++#include <stdarg.h> ++#include <stdlib.h> ++#include <ctype.h> ++ ++#include <openssl/des.h> ++#include <openssl/md4.h> ++#include <openssl/ssl.h> ++ ++#if OPENSSL_VERSION_NUMBER < 0x00907001L ++#define DES_key_schedule des_key_schedule ++#define DES_cblock des_cblock ++#define DES_set_odd_parity des_set_odd_parity ++#define DES_set_key des_set_key ++#define DES_ecb_encrypt des_ecb_encrypt ++ ++/* This is how things were done in the old days */ ++#define DESKEY(x) x ++#define DESKEYARG(x) x ++#else ++/* Modern version */ ++#define DESKEYARG(x) *x ++#define DESKEY(x) &x ++#endif ++ ++/* Define this to make the type-3 message include the NT response message */ ++#define USE_NTRESPONSES 1 ++ ++/* ++ (*) = A "security buffer" is a triplet consisting of two shorts and one ++ long: ++ ++ 1. a 'short' containing the length of the buffer in bytes ++ 2. a 'short' containing the allocated space for the buffer in bytes ++ 3. a 'long' containing the offset to the start of the buffer from the ++ beginning of the NTLM message, in bytes. ++*/ ++ ++static ntlm ne_input_ntlm(ne_ntlm_context *ctx, ++ const char *responseToken) ++{ ++ if(responseToken) { ++ /* We got a type-2 message here: ++ ++ Index Description Content ++ 0 NTLMSSP Signature Null-terminated ASCII "NTLMSSP" ++ (0x4e544c4d53535000) ++ 8 NTLM Message Type long (0x02000000) ++ 12 Target Name security buffer(*) ++ 20 Flags long ++ 24 Challenge 8 bytes ++ (32) Context (optional) 8 bytes (two consecutive longs) ++ (40) Target Information (optional) security buffer(*) ++ 32 (48) start of data block ++ */ ++ unsigned char * buffer = NULL; ++ ++ int size = ne_unbase64(responseToken, &buffer); ++ ++ ctx->state = NTLMSTATE_TYPE2; /* we got a type-2 */ ++ ++ if(size >= 48) ++ /* the nonce of interest is index [24 .. 31], 8 bytes */ ++ memcpy(ctx->nonce, &buffer[24], 8); ++ ++ /* at index decimal 20, there's a 32bit NTLM flag field */ ++ ++ if (buffer) ne_free(buffer); ++ } ++ else { ++ if(ctx->state >= NTLMSTATE_TYPE1) ++ return NTLM_BAD; ++ ++ ctx->state = NTLMSTATE_TYPE1; /* we should sent away a type-1 */ ++ } ++ return NTLM_FINE; ++} ++ ++/* ++ * Turns a 56 bit key into the 64 bit, odd parity key and sets the key. The ++ * key schedule ks is also set. ++ */ ++static void setup_des_key(unsigned char *key_56, ++ DES_key_schedule DESKEYARG(ks)) ++{ ++ DES_cblock key; ++ ++ key[0] = key_56[0]; ++ key[1] = ((key_56[0] << 7) & 0xFF) | (key_56[1] >> 1); ++ key[2] = ((key_56[1] << 6) & 0xFF) | (key_56[2] >> 2); ++ key[3] = ((key_56[2] << 5) & 0xFF) | (key_56[3] >> 3); ++ key[4] = ((key_56[3] << 4) & 0xFF) | (key_56[4] >> 4); ++ key[5] = ((key_56[4] << 3) & 0xFF) | (key_56[5] >> 5); ++ key[6] = ((key_56[5] << 2) & 0xFF) | (key_56[6] >> 6); ++ key[7] = (key_56[6] << 1) & 0xFF; ++ ++ DES_set_odd_parity(&key); ++ DES_set_key(&key, ks); ++} ++ ++ /* ++ * takes a 21 byte array and treats it as 3 56-bit DES keys. The ++ * 8 byte plaintext is encrypted with each key and the resulting 24 ++ * bytes are stored in the results array. ++ */ ++static void calc_resp(unsigned char *keys, ++ unsigned char *plaintext, ++ unsigned char *results) ++{ ++ DES_key_schedule ks; ++ ++ setup_des_key(keys, DESKEY(ks)); ++ DES_ecb_encrypt((DES_cblock*) plaintext, (DES_cblock*) results, ++ DESKEY(ks), DES_ENCRYPT); ++ ++ setup_des_key(keys+7, DESKEY(ks)); ++ DES_ecb_encrypt((DES_cblock*) plaintext, (DES_cblock*) (results+8), ++ DESKEY(ks), DES_ENCRYPT); ++ ++ setup_des_key(keys+14, DESKEY(ks)); ++ DES_ecb_encrypt((DES_cblock*) plaintext, (DES_cblock*) (results+16), ++ DESKEY(ks), DES_ENCRYPT); ++} ++ ++/* ++ * Set up lanmanager and nt hashed passwords ++ */ ++static void mkhash(char *password, ++ unsigned char *nonce, /* 8 bytes */ ++ unsigned char *lmresp /* must fit 0x18 bytes */ ++#ifdef USE_NTRESPONSES ++ , unsigned char *ntresp /* must fit 0x18 bytes */ ++#endif ++ ) ++{ ++ unsigned char lmbuffer[21]; ++#ifdef USE_NTRESPONSES ++ unsigned char ntbuffer[21]; ++#endif ++ unsigned char *pw; ++ static const unsigned char magic[] = { ++ 0x4B, 0x47, 0x53, 0x21, 0x40, 0x23, 0x24, 0x25 ++ }; ++ int i; ++ int len = strlen(password); ++ ++ /* make it fit at least 14 bytes */ ++ pw = malloc(len<7?14:len*2); ++ if(!pw) ++ return; /* this will lead to a badly generated package */ ++ ++ if (len > 14) ++ len = 14; ++ ++ for (i=0; i<len; i++) ++ pw[i] = toupper(password[i]); ++ ++ for (; i<14; i++) ++ pw[i] = 0; ++ ++ { ++ /* create LanManager hashed password */ ++ DES_key_schedule ks; ++ ++ setup_des_key(pw, DESKEY(ks)); ++ DES_ecb_encrypt((DES_cblock *)magic, (DES_cblock *)lmbuffer, ++ DESKEY(ks), DES_ENCRYPT); ++ ++ setup_des_key(pw+7, DESKEY(ks)); ++ DES_ecb_encrypt((DES_cblock *)magic, (DES_cblock *)(lmbuffer+8), ++ DESKEY(ks), DES_ENCRYPT); ++ ++ memset(lmbuffer+16, 0, 5); ++ } ++ /* create LM responses */ ++ calc_resp(lmbuffer, nonce, lmresp); ++ ++#ifdef USE_NTRESPONSES ++ { ++ /* create NT hashed password */ ++ MD4_CTX MD4; ++ ++ len = strlen(password); ++ ++ for (i=0; i<len; i++) { ++ pw[2*i] = password[i]; ++ pw[2*i+1] = 0; ++ } ++ ++ MD4_Init(&MD4); ++ MD4_Update(&MD4, pw, 2*len); ++ MD4_Final(ntbuffer, &MD4); ++ ++ memset(ntbuffer+16, 0, 8); ++ } ++ ++ calc_resp(ntbuffer, nonce, ntresp); ++#endif ++ ++ free(pw); ++} ++ ++#define SHORTPAIR(x) ((x) & 0xff), ((x) >> 8) ++#define LONGQUARTET(x) ((x) & 0xff), (((x) >> 8)&0xff), \ ++ (((x) >>16)&0xff), ((x)>>24) ++ ++/* this is for creating ntlm header output */ ++static int ne_output_ntlm(ne_ntlm_context *ctx) ++{ ++ const char *domain=""; /* empty */ ++ const char *host=""; /* empty */ ++ int domlen=strlen(domain); ++ int hostlen = strlen(host); ++ int hostoff; /* host name offset */ ++ int domoff; /* domain name offset */ ++ int size; ++ unsigned char ntlmbuf[256]; /* enough, unless the host/domain is very long */ ++ ++ if(!ctx->user || !ctx->passwd) ++ /* no user, no auth */ ++ return 0; /* OK */ ++ ++ switch(ctx->state) { ++ case NTLMSTATE_TYPE1: ++ default: /* for the weird cases we (re)start here */ ++ hostoff = 32; ++ domoff = hostoff + hostlen; ++ ++ /* Create and send a type-1 message: ++ ++ Index Description Content ++ 0 NTLMSSP Signature Null-terminated ASCII "NTLMSSP" ++ (0x4e544c4d53535000) ++ 8 NTLM Message Type long (0x01000000) ++ 12 Flags long ++ 16 Supplied Domain security buffer(*) ++ 24 Supplied Workstation security buffer(*) ++ 32 start of data block ++ ++ */ ++ ++ snprintf((char *)ntlmbuf, sizeof(ntlmbuf), "NTLMSSP%c" ++ "\x01%c%c%c" /* 32-bit type = 1 */ ++ "%c%c%c%c" /* 32-bit NTLM flag field */ ++ "%c%c" /* domain length */ ++ "%c%c" /* domain allocated space */ ++ "%c%c" /* domain name offset */ ++ "%c%c" /* 2 zeroes */ ++ "%c%c" /* host length */ ++ "%c%c" /* host allocated space */ ++ "%c%c" /* host name offset */ ++ "%c%c" /* 2 zeroes */ ++ "%s" /* host name */ ++ "%s", /* domain string */ ++ 0, /* trailing zero */ ++ 0,0,0, /* part of type-1 long */ ++ ++ LONGQUARTET( ++ NTLMFLAG_NEGOTIATE_OEM| /* 2 */ ++ NTLMFLAG_NEGOTIATE_NTLM_KEY /* 200 */ ++ /* equals 0x0202 */ ++ ), ++ SHORTPAIR(domlen), ++ SHORTPAIR(domlen), ++ SHORTPAIR(domoff), ++ 0,0, ++ SHORTPAIR(hostlen), ++ SHORTPAIR(hostlen), ++ SHORTPAIR(hostoff), ++ 0,0, ++ host, domain); ++ ++ /* initial packet length */ ++ size = 32 + hostlen + domlen; ++ ++ /* now keeper of the base64 encoded package size */ ++ if (ctx->requestToken) ne_free(ctx->requestToken); ++ ctx->requestToken = ne_base64(ntlmbuf, size); ++ ++ break; ++ ++ case NTLMSTATE_TYPE2: ++ /* We received the type-2 already, create a type-3 message: ++ ++ Index Description Content ++ 0 NTLMSSP Signature Null-terminated ASCII "NTLMSSP" ++ (0x4e544c4d53535000) ++ 8 NTLM Message Type long (0x03000000) ++ 12 LM/LMv2 Response security buffer(*) ++ 20 NTLM/NTLMv2 Response security buffer(*) ++ 28 Domain Name security buffer(*) ++ 36 User Name security buffer(*) ++ 44 Workstation Name security buffer(*) ++ (52) Session Key (optional) security buffer(*) ++ (60) Flags (optional) long ++ 52 (64) start of data block ++ ++ */ ++ ++ { ++ int lmrespoff; ++ int ntrespoff; ++ int useroff; ++ unsigned char lmresp[0x18]; /* fixed-size */ ++#ifdef USE_NTRESPONSES ++ unsigned char ntresp[0x18]; /* fixed-size */ ++#endif ++ const char *user; ++ int userlen; ++ ++ user = strchr(ctx->user, '\\'); ++ if(!user) ++ user = strchr(ctx->user, '/'); ++ ++ if (user) { ++ domain = ctx->user; ++ domlen = user - domain; ++ user++; ++ } ++ else ++ user = ctx->user; ++ userlen = strlen(user); ++ ++ mkhash(ctx->passwd, &ctx->nonce[0], lmresp ++#ifdef USE_NTRESPONSES ++ , ntresp ++#endif ++ ); ++ ++ domoff = 64; /* always */ ++ useroff = domoff + domlen; ++ hostoff = useroff + userlen; ++ lmrespoff = hostoff + hostlen; ++ ntrespoff = lmrespoff + 0x18; ++ ++ /* Create the big type-3 message binary blob */ ++ size = snprintf((char *)ntlmbuf, sizeof(ntlmbuf), ++ "NTLMSSP%c" ++ "\x03%c%c%c" /* type-3, 32 bits */ ++ ++ "%c%c%c%c" /* LanManager length + allocated space */ ++ "%c%c" /* LanManager offset */ ++ "%c%c" /* 2 zeroes */ ++ ++ "%c%c" /* NT-response length */ ++ "%c%c" /* NT-response allocated space */ ++ "%c%c" /* NT-response offset */ ++ "%c%c" /* 2 zeroes */ ++ ++ "%c%c" /* domain length */ ++ "%c%c" /* domain allocated space */ ++ "%c%c" /* domain name offset */ ++ "%c%c" /* 2 zeroes */ ++ ++ "%c%c" /* user length */ ++ "%c%c" /* user allocated space */ ++ "%c%c" /* user offset */ ++ "%c%c" /* 2 zeroes */ ++ ++ "%c%c" /* host length */ ++ "%c%c" /* host allocated space */ ++ "%c%c" /* host offset */ ++ "%c%c%c%c%c%c" /* 6 zeroes */ ++ ++ "\xff\xff" /* message length */ ++ "%c%c" /* 2 zeroes */ ++ ++ "\x01\x82" /* flags */ ++ "%c%c" /* 2 zeroes */ ++ ++ /* domain string */ ++ /* user string */ ++ /* host string */ ++ /* LanManager response */ ++ /* NT response */ ++ , ++ 0, /* zero termination */ ++ 0,0,0, /* type-3 long, the 24 upper bits */ ++ ++ SHORTPAIR(0x18), /* LanManager response length, twice */ ++ SHORTPAIR(0x18), ++ SHORTPAIR(lmrespoff), ++ 0x0, 0x0, ++ ++#ifdef USE_NTRESPONSES ++ SHORTPAIR(0x18), /* NT-response length, twice */ ++ SHORTPAIR(0x18), ++#else ++ 0x0, 0x0, ++ 0x0, 0x0, ++#endif ++ SHORTPAIR(ntrespoff), ++ 0x0, 0x0, ++ ++ SHORTPAIR(domlen), ++ SHORTPAIR(domlen), ++ SHORTPAIR(domoff), ++ 0x0, 0x0, ++ ++ SHORTPAIR(userlen), ++ SHORTPAIR(userlen), ++ SHORTPAIR(useroff), ++ 0x0, 0x0, ++ ++ SHORTPAIR(hostlen), ++ SHORTPAIR(hostlen), ++ SHORTPAIR(hostoff), ++ 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, ++ ++ 0x0, 0x0, ++ ++ 0x0, 0x0); ++ ++ /* size is now 64 */ ++ size=64; ++ ntlmbuf[62]=ntlmbuf[63]=0; ++ ++ /* Make sure that the user and domain strings fit in the target buffer ++ before we copy them there. */ ++ if(size + userlen + domlen >= sizeof(ntlmbuf)) { ++ return -1; ++ } ++ ++ memcpy(&ntlmbuf[size], domain, domlen); ++ size += domlen; ++ ++ memcpy(&ntlmbuf[size], user, userlen); ++ size += userlen; ++ ++ /* we append the binary hashes to the end of the blob */ ++ if(size < ((int)sizeof(ntlmbuf) - 0x18)) { ++ memcpy(&ntlmbuf[size], lmresp, 0x18); ++ size += 0x18; ++ } ++ ++#ifdef USE_NTRESPONSES ++ if(size < ((int)sizeof(ntlmbuf) - 0x18)) { ++ memcpy(&ntlmbuf[size], ntresp, 0x18); ++ size += 0x18; ++ } ++#endif ++ ++ ntlmbuf[56] = size & 0xff; ++ ntlmbuf[57] = size >> 8; ++ ++ /* convert the binary blob into base64 */ ++ ctx->requestToken = ne_base64(ntlmbuf, size); ++ ++ ctx->state = NTLMSTATE_TYPE3; /* we sent a type-3 */ ++ } ++ break; ++ ++ case NTLMSTATE_TYPE3: ++ /* connection is already authenticated, ++ * don't send a header in future requests */ ++ if (ctx->requestToken) ne_free(ctx->requestToken); ++ ctx->requestToken = NULL; ++ break; ++ } ++ ++ return 0; /* OK */ ++} ++ ++int ne_ntlm_create_context(ne_ntlm_context **context, const char *userName, const char *password) ++{ ++ if (context == NULL) { ++ return -1; ++ } else { ++ ne_ntlm_context *ctx = ne_calloc(sizeof(ne_ntlm_context)); ++ ++ ctx->state = NTLMSTATE_NONE; ++ ctx->user = ne_strdup(userName); ++ ctx->passwd = ne_strdup(password); ++ ++ *context = ctx; ++ return 0; ++ } ++} ++ ++int ne_ntlm_destroy_context(ne_ntlm_context *context) ++{ ++ if (context != NULL) { ++ if (context->user) ++ ne_free(context->user); ++ ++ if (context->passwd) ++ ne_free(context->passwd); ++ ++ if (context->requestToken) ++ ne_free(context->requestToken); ++ ++ ne_free(context); ++ } ++ return 0; ++} ++ ++int ne_ntlm_clear_context(ne_ntlm_context *context) ++{ ++ return 0; ++} ++ ++int ne_ntlm_authenticate(ne_ntlm_context *context, const char *responseToken) ++{ ++ if (context == NULL) { ++ return -1; ++ } else { ++ if (context->state <= NTLMSTATE_TYPE3) { ++ ntlm ntlmstatus = ne_input_ntlm(context, responseToken); ++ ++ if (ntlmstatus != NTLM_FINE) { ++ return -1; ++ } ++ } ++ } ++ return ne_output_ntlm(context); ++} ++ ++char *ne_ntlm_getRequestToken(ne_ntlm_context *context) ++{ ++ if (context == NULL) { ++ return NULL; ++ } else { ++ if (context->requestToken) { ++ char *ret = ne_strdup(context->requestToken); ++ ne_free(context->requestToken); ++ context->requestToken = NULL; ++ return ret; ++ } else { ++ return NULL; ++ } ++ } ++} ++ ++#endif /* HAVE_OPENSSL */ ++#endif /* HAVE_NTLM */ +--- misc/neon-0.28.2/src/ne_ntlm.h 2009-06-24 12:49:38.000000000 +0200 ++++ misc/build/neon-0.28.2/src/ne_ntlm.h 2009-06-24 12:46:45.000000000 +0200 +@@ -1 +1,44 @@ +-dummy ++/* ++ Handling of NTLM Authentication ++ Copyright (C) 2009, Kai Sommerfeld <kso@openoffice.org> ++ ++ This library is free software; you can redistribute it and/or ++ modify it under the terms of the GNU Library General Public ++ License as published by the Free Software Foundation; either ++ version 2 of the License, or (at your option) any later version. ++ ++ This library is distributed in the hope that it will be useful, ++ but WITHOUT ANY WARRANTY; without even the implied warranty of ++ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ++ Library General Public License for more details. ++ ++ You should have received a copy of the GNU Library General Public ++ License along with this library; if not, write to the Free ++ Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, ++ MA 02111-1307, USA ++ ++*/ ++#ifndef NE_NTLM_H ++#define NE_NTLM_H ++ ++#include "config.h" ++ ++/* PRIVATE TO NEON -- NOT PART OF THE EXTERNAL API. */ ++ ++#ifdef HAVE_NTLM ++ ++typedef struct ne_ntlm_context_s ne_ntlm_context; ++ ++int ne_ntlm_create_context(ne_ntlm_context **context, const char *userName, const char *password); ++ ++int ne_ntlm_destroy_context(ne_ntlm_context *context); ++ ++int ne_ntlm_clear_context(ne_ntlm_context *context); ++ ++int ne_ntlm_authenticate(ne_ntlm_context *context, const char *responseToken); ++ ++char *ne_ntlm_getRequestToken(ne_ntlm_context *context); ++ ++#endif /* HAVE_NTLM */ ++ ++#endif /* NE_NTLM_H */ +--- misc/neon-0.28.2/src/ne_socket.c 2008-02-28 14:19:19.000000000 +0100 ++++ misc/build/neon-0.28.2/src/ne_socket.c 2009-06-24 12:49:13.000000000 +0200 +@@ -60,6 +60,7 @@ + #include <stddef.h> + #ifdef USE_GETADDRINFO + #include <ws2tcpip.h> ++#include <Wspiapi.h> + #endif + #endif + +--- misc/neon-0.28.2/src/ne_sspi.c 2007-08-10 17:26:08.000000000 +0200 ++++ misc/build/neon-0.28.2/src/ne_sspi.c 2009-06-24 12:46:45.000000000 +0200 +@@ -202,9 +202,48 @@ + return -1; + } + ++ return 0; ++} ++ ++/* ++ * Simplification wrapper arround AcquireCredentialsHandle as most of ++ * the parameters do not change. ++ */ ++static int acquireCredentialsHandleForUsername(CredHandle * credentials, char *package, const char *username, const char *password) ++{ ++ SECURITY_STATUS status; ++ TimeStamp timestamp; ++ ++ const char *domain = ""; ++ ++ int rc, rcISC; ++ SecPkgInfo *secPackInfo; ++ SEC_WINNT_AUTH_IDENTITY *nameAndPwd = NULL; ++ int bytesReceived = 0, bytesSent = 0; ++ ++ nameAndPwd = (SEC_WINNT_AUTH_IDENTITY *) malloc( sizeof(SEC_WINNT_AUTH_IDENTITY) ); ++ memset( nameAndPwd, '\0', sizeof (*nameAndPwd) ); ++ nameAndPwd->Domain = (unsigned char *) _strdup( domain? domain: "" ); ++ nameAndPwd->DomainLength = domain? strlen( domain ): 0; ++ nameAndPwd->User = (unsigned char *) _strdup( username? username: "" ); ++ nameAndPwd->UserLength = username? strlen( username ): 0; ++ nameAndPwd->Password = (unsigned char *) _strdup( password? password: "" ); ++ nameAndPwd->PasswordLength = password? strlen( password ): 0; ++ nameAndPwd->Flags = SEC_WINNT_AUTH_IDENTITY_ANSI; ++ ++ status = pSFT->AcquireCredentialsHandle( NULL, package, SECPKG_CRED_OUTBOUND, ++ NULL, nameAndPwd, NULL, NULL, credentials, ×tamp ); ++ ++ if (status != SEC_E_OK) { ++ NE_DEBUG(NE_DBG_HTTPAUTH, ++ "sspi: AcquireCredentialsHandle [fail] [%x].\n", status); ++ return -1; ++ } ++ + return 0; + } + ++ + /* + * Wrapper arround initializeSecurityContext. Supplies several + * default parameters as well as logging in case of errors. +@@ -483,7 +522,7 @@ + * Processes received authentication tokens as well as supplies the + * response token. + */ +-int ne_sspi_authenticate(void *context, const char *base64Token, char **responseToken) ++int ne_sspi_authenticate(void *context, const char *base64Token, char **responseToken, const char* username, const char* password) + { + SecBufferDesc outBufferDesc; + SecBuffer outBuffer; +@@ -560,14 +599,23 @@ + + /* Reset any existing context since we are starting over */ + resetContext(sspiContext); ++ ++ if (strlen(username) != 0) { ++ if (acquireCredentialsHandleForUsername ++ (&sspiContext->credentials, sspiContext->mechanism, username, password) != SEC_E_OK) { ++ freeBuffer(&outBufferDesc); ++ NE_DEBUG(NE_DBG_HTTPAUTH, "sspi: acquireCredentialsHandleForUsername failed.\n"); ++ return -1; ++ } ++ } else { ++ if (acquireCredentialsHandle ++ (&sspiContext->credentials, sspiContext->mechanism) != SEC_E_OK) { ++ freeBuffer(&outBufferDesc); ++ NE_DEBUG(NE_DBG_HTTPAUTH, "sspi: acquireCredentialsHandle failed.\n"); ++ return -1; ++ } ++ } + +- if (acquireCredentialsHandle +- (&sspiContext->credentials, sspiContext->mechanism) != SEC_E_OK) { +- freeBuffer(&outBufferDesc); +- NE_DEBUG(NE_DBG_HTTPAUTH, +- "sspi: acquireCredentialsHandle failed.\n"); +- return -1; +- } + + securityStatus = + initializeSecurityContext(&sspiContext->credentials, NULL, +--- misc/neon-0.28.2/src/ne_sspi.h 2006-02-12 13:05:14.000000000 +0100 ++++ misc/build/neon-0.28.2/src/ne_sspi.h 2009-06-24 12:46:45.000000000 +0200 +@@ -41,7 +41,7 @@ + int ne_sspi_clear_context(void *context); + + int ne_sspi_authenticate(void *context, const char *base64Token, +- char **responseToken); ++ char **responseToken, const char* username, const char* password); + + #endif /* HAVE_SSPI */ + +--- misc/neon-0.28.2/src/ne_uri.c 2007-12-05 12:04:47.000000000 +0100 ++++ misc/build/neon-0.28.2/src/ne_uri.c 2009-06-24 12:46:45.000000000 +0200 +@@ -42,7 +42,7 @@ + #include "ne_alloc.h" + #include "ne_uri.h" + +-/* URI ABNF from RFC 3986: */ ++/* URI ABNF from RFC 3986: (TKR: SharePoint is contradictory to this RFC. So I fix it here. )*/ + + #define PS (0x0001) /* "+" */ + #define PC (0x0002) /* "%" */ +@@ -67,6 +67,9 @@ + + #define OT (0x4000) /* others */ + ++/* TKR new symbol */ ++#define WS (0x8000) /* Whitespaces ( Space, Tab ) */ ++ + #define URI_ALPHA (AL) + #define URI_DIGIT (DG) + +@@ -83,20 +86,21 @@ + /* pchar = unreserved / pct-encoded / sub-delims / ":" / "@" */ + #define URI_PCHAR (URI_UNRESERVED | PC | URI_SUBDELIM | CL | AT) + /* invented: segchar = pchar / "/" */ +-#define URI_SEGCHAR (URI_PCHAR | FS) ++/* (TKR) WS added */ ++#define URI_SEGCHAR (URI_PCHAR | FS | WS) + /* query = *( pchar / "/" / "?" ) */ + #define URI_QUERY (URI_PCHAR | FS | QU) + /* fragment == query */ + #define URI_FRAGMENT URI_QUERY + + /* any characters which should be path-escaped: */ +-#define URI_ESCAPE ((URI_GENDELIM & ~(FS)) | URI_SUBDELIM | OT | PC) ++#define URI_ESCAPE ((URI_GENDELIM & ~(FS)) | URI_SUBDELIM | OT | WS | PC) + + static const unsigned int uri_chars[256] = { + /* 0xXX x0 x2 x4 x6 x8 xA xC xE */ +-/* 0x */ OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, ++/* 0x */ OT, OT, OT, OT, OT, OT, OT, OT, OT, WS, OT, OT, OT, OT, OT, OT, + /* 1x */ OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, OT, +-/* 2x */ OT, SD, OT, GD, SD, PC, SD, SD, SD, SD, SD, PS, SD, DS, DT, FS, ++/* 2x */ WS, SD, OT, GD, SD, PC, SD, SD, SD, SD, SD, PS, SD, DS, DT, FS, + /* 3x */ DG, DG, DG, DG, DG, DG, DG, DG, DG, DG, CL, SD, OT, SD, OT, QU, + /* 4x */ AT, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, + /* 5x */ AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, AL, GD, OT, GD, OT, US, |