Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-cw
Commits
364ac678
Commit
364ac678
authored
Mar 23, 2020
by
Dmitry Timoshkov
Committed by
Alexandre Julliard
Mar 24, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wldap32: Add support for ldap_bind_s(LDAP_AUTH_NEGOTIATE).
Signed-off-by:
Dmitry Timoshkov
<
dmitry@baikal.ru
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
3d37d45e
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
155 additions
and
15 deletions
+155
-15
configure
configure
+1
-0
configure.ac
configure.ac
+1
-0
bind.c
dlls/wldap32/bind.c
+116
-15
winldap_private.h
dlls/wldap32/winldap_private.h
+2
-0
wldap32.h
dlls/wldap32/wldap32.h
+32
-0
config.h.in
include/config.h.in
+3
-0
No files found.
configure
View file @
364ac678
...
@@ -7427,6 +7427,7 @@ for ac_header in \
...
@@ -7427,6 +7427,7 @@ for ac_header in \
port.h
\
port.h
\
pthread.h
\
pthread.h
\
pwd.h
\
pwd.h
\
sasl/sasl.h
\
sched.h
\
sched.h
\
scsi/scsi.h
\
scsi/scsi.h
\
scsi/scsi_ioctl.h
\
scsi/scsi_ioctl.h
\
...
...
configure.ac
View file @
364ac678
...
@@ -487,6 +487,7 @@ AC_CHECK_HEADERS(\
...
@@ -487,6 +487,7 @@ AC_CHECK_HEADERS(\
port.h \
port.h \
pthread.h \
pthread.h \
pwd.h \
pwd.h \
sasl/sasl.h \
sched.h \
sched.h \
scsi/scsi.h \
scsi/scsi.h \
scsi/scsi_ioctl.h \
scsi/scsi_ioctl.h \
...
...
dlls/wldap32/bind.c
View file @
364ac678
...
@@ -25,10 +25,14 @@
...
@@ -25,10 +25,14 @@
#ifdef HAVE_LDAP_H
#ifdef HAVE_LDAP_H
#include <ldap.h>
#include <ldap.h>
#endif
#endif
#ifdef HAVE_SASL_SASL_H
#include <sasl/sasl.h>
#endif
#include "windef.h"
#include "windef.h"
#include "winbase.h"
#include "winbase.h"
#include "winnls.h"
#include "winnls.h"
#include "rpc.h"
#include "winldap_private.h"
#include "winldap_private.h"
#include "wldap32.h"
#include "wldap32.h"
...
@@ -156,20 +160,67 @@ ULONG CDECL ldap_bind_sA( WLDAP32_LDAP *ld, PCHAR dn, PCHAR cred, ULONG method )
...
@@ -156,20 +160,67 @@ ULONG CDECL ldap_bind_sA( WLDAP32_LDAP *ld, PCHAR dn, PCHAR cred, ULONG method )
if
(
!
dnW
)
goto
exit
;
if
(
!
dnW
)
goto
exit
;
}
}
if
(
cred
)
{
if
(
cred
)
{
credW
=
strAtoW
(
cred
);
if
(
method
==
LDAP_AUTH_SIMPLE
)
if
(
!
credW
)
goto
exit
;
{
credW
=
strAtoW
(
cred
);
if
(
!
credW
)
goto
exit
;
}
else
credW
=
(
WCHAR
*
)
cred
/* SEC_WINNT_AUTH_IDENTITY_A */
;
}
}
ret
=
ldap_bind_sW
(
ld
,
dnW
,
credW
,
method
);
ret
=
ldap_bind_sW
(
ld
,
dnW
,
credW
,
method
);
exit:
exit:
strfreeW
(
dnW
);
strfreeW
(
dnW
);
strfreeW
(
credW
);
if
(
credW
!=
(
WCHAR
*
)
cred
)
strfreeW
(
credW
);
#endif
#endif
return
ret
;
return
ret
;
}
}
#ifdef HAVE_LDAP_H
static
int
sasl_interact
(
LDAP
*
ld
,
unsigned
flags
,
void
*
defaults
,
void
*
interact
)
{
#ifdef HAVE_SASL_SASL_H
SEC_WINNT_AUTH_IDENTITY_A
*
id
=
defaults
;
sasl_interact_t
*
sasl
=
interact
;
TRACE
(
"%p,%08x,%p,%p
\n
"
,
ld
,
flags
,
defaults
,
interact
);
while
(
sasl
->
id
!=
SASL_CB_LIST_END
)
{
TRACE
(
"sasl->id = %04lx
\n
"
,
sasl
->
id
);
if
(
sasl
->
id
==
SASL_CB_GETREALM
)
{
sasl
->
result
=
id
->
Domain
;
sasl
->
len
=
id
->
DomainLength
;
}
else
if
(
sasl
->
id
==
SASL_CB_USER
)
{
sasl
->
result
=
id
->
User
;
sasl
->
len
=
id
->
UserLength
;
}
else
if
(
sasl
->
id
==
SASL_CB_PASS
)
{
sasl
->
result
=
id
->
Password
;
sasl
->
len
=
id
->
PasswordLength
;
}
sasl
++
;
}
return
LDAP_SUCCESS
;
#else
FIXME
(
"%p,%08x,%p,%p: stub
\n
"
,
ld
,
flags
,
defaults
,
interact
);
return
LDAP_SUCCESS
;
#endif
/* HAVE_SASL_SASL_H */
}
#endif
/* HAVE_LDAP_H */
/***********************************************************************
/***********************************************************************
* ldap_bind_sW (WLDAP32.@)
* ldap_bind_sW (WLDAP32.@)
*
*
...
@@ -197,21 +248,71 @@ ULONG CDECL ldap_bind_sW( WLDAP32_LDAP *ld, PWCHAR dn, PWCHAR cred, ULONG method
...
@@ -197,21 +248,71 @@ ULONG CDECL ldap_bind_sW( WLDAP32_LDAP *ld, PWCHAR dn, PWCHAR cred, ULONG method
TRACE
(
"(%p, %s, %p, 0x%08x)
\n
"
,
ld
,
debugstr_w
(
dn
),
cred
,
method
);
TRACE
(
"(%p, %s, %p, 0x%08x)
\n
"
,
ld
,
debugstr_w
(
dn
),
cred
,
method
);
if
(
!
ld
)
return
WLDAP32_LDAP_PARAM_ERROR
;
if
(
!
ld
)
return
WLDAP32_LDAP_PARAM_ERROR
;
if
(
method
!=
LDAP_AUTH_SIMPLE
)
return
WLDAP32_LDAP_PARAM_ERROR
;
if
(
dn
)
{
if
(
method
==
LDAP_AUTH_SIMPLE
)
dnU
=
strWtoU
(
dn
);
{
if
(
!
dnU
)
goto
exit
;
if
(
dn
)
{
dnU
=
strWtoU
(
dn
);
if
(
!
dnU
)
goto
exit
;
}
if
(
cred
)
{
credU
=
strWtoU
(
cred
);
if
(
!
credU
)
goto
exit
;
pwd
.
bv_len
=
strlen
(
credU
);
pwd
.
bv_val
=
credU
;
}
ret
=
map_error
(
ldap_sasl_bind_s
(
ld
,
dnU
,
LDAP_SASL_SIMPLE
,
&
pwd
,
NULL
,
NULL
,
NULL
));
}
}
if
(
cred
)
{
else
if
(
method
==
WLDAP32_LDAP_AUTH_NEGOTIATE
)
credU
=
strWtoU
(
cred
);
{
if
(
!
credU
)
goto
exit
;
SEC_WINNT_AUTH_IDENTITY_A
idU
;
SEC_WINNT_AUTH_IDENTITY_W
idW
;
pwd
.
bv_len
=
strlen
(
credU
);
SEC_WINNT_AUTH_IDENTITY_W
*
id
=
(
SEC_WINNT_AUTH_IDENTITY_W
*
)
cred
;
pwd
.
bv_val
=
credU
;
memset
(
&
idU
,
0
,
sizeof
(
idU
)
);
if
(
id
)
{
if
(
id
->
Flags
&
SEC_WINNT_AUTH_IDENTITY_ANSI
)
{
idW
.
Flags
=
SEC_WINNT_AUTH_IDENTITY_UNICODE
;
idW
.
Domain
=
(
unsigned
short
*
)
strnAtoW
(
(
char
*
)
id
->
Domain
,
id
->
DomainLength
,
&
idW
.
DomainLength
);
idW
.
User
=
(
unsigned
short
*
)
strnAtoW
(
(
char
*
)
id
->
User
,
id
->
UserLength
,
&
idW
.
UserLength
);
idW
.
Password
=
(
unsigned
short
*
)
strnAtoW
(
(
char
*
)
id
->
Password
,
id
->
PasswordLength
,
&
idW
.
PasswordLength
);
id
=
&
idW
;
}
idU
.
Domain
=
(
unsigned
char
*
)
strnWtoU
(
id
->
Domain
,
id
->
DomainLength
,
&
idU
.
DomainLength
);
idU
.
User
=
(
unsigned
char
*
)
strnWtoU
(
id
->
User
,
id
->
UserLength
,
&
idU
.
UserLength
);
idU
.
Password
=
(
unsigned
char
*
)
strnWtoU
(
id
->
Password
,
id
->
PasswordLength
,
&
idU
.
PasswordLength
);
}
ret
=
map_error
(
ldap_sasl_interactive_bind_s
(
ld
,
NULL
/* server will ignore DN anyway */
,
NULL
/* query supportedSASLMechanisms */
,
NULL
,
NULL
,
LDAP_SASL_QUIET
,
sasl_interact
,
&
idU
));
if
(
id
&&
(
id
->
Flags
&
SEC_WINNT_AUTH_IDENTITY_ANSI
))
{
strfreeW
(
(
WCHAR
*
)
idW
.
Domain
);
strfreeW
(
(
WCHAR
*
)
idW
.
User
);
strfreeW
(
(
WCHAR
*
)
idW
.
Password
);
}
strfreeU
(
(
char
*
)
idU
.
Domain
);
strfreeU
(
(
char
*
)
idU
.
User
);
strfreeU
(
(
char
*
)
idU
.
Password
);
}
else
{
FIXME
(
"method %#x not supported
\n
"
,
method
);
return
WLDAP32_LDAP_PARAM_ERROR
;
}
}
ret
=
map_error
(
ldap_sasl_bind_s
(
ld
,
dnU
,
LDAP_SASL_SIMPLE
,
&
pwd
,
NULL
,
NULL
,
NULL
));
exit:
exit:
strfreeU
(
dnU
);
strfreeU
(
dnU
);
...
...
dlls/wldap32/winldap_private.h
View file @
364ac678
...
@@ -101,6 +101,8 @@ typedef struct berelement
...
@@ -101,6 +101,8 @@ typedef struct berelement
#define WLDAP32_LDAP_OPT_SECURITY_CONTEXT 0x99
#define WLDAP32_LDAP_OPT_SECURITY_CONTEXT 0x99
#define WLDAP32_LDAP_OPT_ROOTDSE_CACHE 0x9a
#define WLDAP32_LDAP_OPT_ROOTDSE_CACHE 0x9a
#define WLDAP32_LDAP_AUTH_NEGOTIATE 0x486
typedef
struct
ldap
typedef
struct
ldap
{
{
struct
struct
...
...
dlls/wldap32/wldap32.h
View file @
364ac678
...
@@ -93,6 +93,38 @@ static inline LPWSTR strUtoW( char *str )
...
@@ -93,6 +93,38 @@ static inline LPWSTR strUtoW( char *str )
return
ret
;
return
ret
;
}
}
static
inline
LPWSTR
strnAtoW
(
LPCSTR
str
,
DWORD
inlen
,
DWORD
*
outlen
)
{
LPWSTR
ret
=
NULL
;
*
outlen
=
0
;
if
(
str
)
{
DWORD
len
=
MultiByteToWideChar
(
CP_ACP
,
0
,
str
,
inlen
,
NULL
,
0
);
if
((
ret
=
heap_alloc
(
len
*
sizeof
(
WCHAR
)
)))
{
MultiByteToWideChar
(
CP_ACP
,
0
,
str
,
inlen
,
ret
,
len
);
*
outlen
=
len
;
}
}
return
ret
;
}
static
inline
char
*
strnWtoU
(
LPCWSTR
str
,
DWORD
inlen
,
DWORD
*
outlen
)
{
LPSTR
ret
=
NULL
;
*
outlen
=
0
;
if
(
str
)
{
DWORD
len
=
WideCharToMultiByte
(
CP_UTF8
,
0
,
str
,
inlen
,
NULL
,
0
,
NULL
,
NULL
);
if
((
ret
=
heap_alloc
(
len
)))
{
WideCharToMultiByte
(
CP_UTF8
,
0
,
str
,
inlen
,
ret
,
len
,
NULL
,
NULL
);
*
outlen
=
len
;
}
}
return
ret
;
}
static
inline
void
strfreeA
(
LPSTR
str
)
static
inline
void
strfreeA
(
LPSTR
str
)
{
{
heap_free
(
str
);
heap_free
(
str
);
...
...
include/config.h.in
View file @
364ac678
...
@@ -779,6 +779,9 @@
...
@@ -779,6 +779,9 @@
/* Define to 1 if you have the `roundf' function. */
/* Define to 1 if you have the `roundf' function. */
#undef HAVE_ROUNDF
#undef HAVE_ROUNDF
/* Define to 1 if you have the <sasl/sasl.h> header file. */
#undef HAVE_SASL_SASL_H
/* Define to 1 if you have the <sched.h> header file. */
/* Define to 1 if you have the <sched.h> header file. */
#undef HAVE_SCHED_H
#undef HAVE_SCHED_H
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment