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
7c786cfd
Commit
7c786cfd
authored
Apr 30, 2021
by
Hans Leidekker
Committed by
Alexandre Julliard
Apr 30, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
msv1_0: Implement SpSealMessage and SpUnsealMessage.
Signed-off-by:
Hans Leidekker
<
hans@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
9894c4fb
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
73 additions
and
2 deletions
+73
-2
main.c
dlls/msv1_0/main.c
+73
-2
No files found.
dlls/msv1_0/main.c
View file @
7c786cfd
...
...
@@ -1430,14 +1430,85 @@ static NTSTATUS NTAPI ntlm_SpVerifySignature( LSA_SEC_HANDLE handle, SecBufferDe
return
verify_signature
(
ctx
,
ctx
->
flags
,
msg
,
idx
);
}
static
NTSTATUS
NTAPI
ntlm_SpSealMessage
(
LSA_SEC_HANDLE
handle
,
ULONG
qop
,
SecBufferDesc
*
msg
,
ULONG
msg_seq_no
)
{
int
token_idx
,
data_idx
;
struct
ntlm_ctx
*
ctx
;
TRACE
(
"%lx, %08x, %p %u
\n
"
,
handle
,
qop
,
msg
,
msg_seq_no
);
if
(
qop
)
FIXME
(
"ignoring quality of protection %08x
\n
"
,
qop
);
if
(
msg_seq_no
)
FIXME
(
"ignoring message sequence number %u
\n
"
,
msg_seq_no
);
if
(
!
handle
)
return
SEC_E_INVALID_HANDLE
;
if
(
!
msg
||
!
msg
->
pBuffers
||
msg
->
cBuffers
<
2
||
(
token_idx
=
get_buffer_index
(
msg
,
SECBUFFER_TOKEN
))
==
-
1
||
(
data_idx
=
get_buffer_index
(
msg
,
SECBUFFER_DATA
))
==
-
1
)
return
SEC_E_INVALID_TOKEN
;
if
(
msg
->
pBuffers
[
token_idx
].
cbBuffer
<
16
)
return
SEC_E_BUFFER_TOO_SMALL
;
ctx
=
(
struct
ntlm_ctx
*
)
handle
;
if
(
ctx
->
flags
&
FLAG_NEGOTIATE_NTLM2
&&
ctx
->
flags
&
FLAG_NEGOTIATE_SEAL
)
{
create_signature
(
ctx
,
ctx
->
flags
,
msg
,
token_idx
,
SIGN_SEND
,
FALSE
);
arc4_process
(
&
ctx
->
crypt
.
ntlm2
.
send_arc4info
,
msg
->
pBuffers
[
data_idx
].
pvBuffer
,
msg
->
pBuffers
[
data_idx
].
cbBuffer
);
if
(
ctx
->
flags
&
FLAG_NEGOTIATE_KEY_EXCHANGE
)
arc4_process
(
&
ctx
->
crypt
.
ntlm2
.
send_arc4info
,
(
char
*
)
msg
->
pBuffers
[
token_idx
].
pvBuffer
+
4
,
8
);
}
else
{
char
*
sig
=
msg
->
pBuffers
[
token_idx
].
pvBuffer
;
create_signature
(
ctx
,
ctx
->
flags
|
FLAG_NEGOTIATE_SIGN
,
msg
,
token_idx
,
SIGN_SEND
,
FALSE
);
arc4_process
(
&
ctx
->
crypt
.
ntlm
.
arc4info
,
msg
->
pBuffers
[
data_idx
].
pvBuffer
,
msg
->
pBuffers
[
data_idx
].
cbBuffer
);
arc4_process
(
&
ctx
->
crypt
.
ntlm
.
arc4info
,
sig
+
4
,
12
);
if
(
ctx
->
flags
&
FLAG_NEGOTIATE_ALWAYS_SIGN
||
!
ctx
->
flags
)
memset
(
sig
+
4
,
0
,
4
);
}
return
SEC_E_OK
;
}
static
NTSTATUS
NTAPI
ntlm_SpUnsealMessage
(
LSA_SEC_HANDLE
handle
,
SecBufferDesc
*
msg
,
ULONG
msg_seq_no
,
ULONG
*
qop
)
{
int
token_idx
,
data_idx
;
struct
ntlm_ctx
*
ctx
;
TRACE
(
"%lx, %p, %u, %p
\n
"
,
handle
,
msg
,
msg_seq_no
,
qop
);
if
(
msg_seq_no
)
FIXME
(
"ignoring message sequence number %u
\n
"
,
msg_seq_no
);
if
(
!
handle
)
return
SEC_E_INVALID_HANDLE
;
if
(
!
msg
||
!
msg
->
pBuffers
||
msg
->
cBuffers
<
2
||
(
token_idx
=
get_buffer_index
(
msg
,
SECBUFFER_TOKEN
))
==
-
1
||
(
data_idx
=
get_buffer_index
(
msg
,
SECBUFFER_DATA
))
==
-
1
)
return
SEC_E_INVALID_TOKEN
;
if
(
msg
->
pBuffers
[
token_idx
].
cbBuffer
<
16
)
return
SEC_E_BUFFER_TOO_SMALL
;
ctx
=
(
struct
ntlm_ctx
*
)
handle
;
if
(
ctx
->
flags
&
FLAG_NEGOTIATE_NTLM2
&&
ctx
->
flags
&
FLAG_NEGOTIATE_SEAL
)
arc4_process
(
&
ctx
->
crypt
.
ntlm2
.
recv_arc4info
,
msg
->
pBuffers
[
data_idx
].
pvBuffer
,
msg
->
pBuffers
[
data_idx
].
cbBuffer
);
else
arc4_process
(
&
ctx
->
crypt
.
ntlm
.
arc4info
,
msg
->
pBuffers
[
data_idx
].
pvBuffer
,
msg
->
pBuffers
[
data_idx
].
cbBuffer
);
/* make sure we use a session key for the signature check, SealMessage always does that,
even in the dummy case */
return
verify_signature
(
ctx
,
ctx
->
flags
|
FLAG_NEGOTIATE_SIGN
,
msg
,
token_idx
);
}
static
SECPKG_USER_FUNCTION_TABLE
ntlm_user_table
=
{
ntlm_SpInstanceInit
,
NULL
,
/* SpInitUserModeContext */
ntlm_SpMakeSignature
,
ntlm_SpVerifySignature
,
NULL
,
/* SpSealMessage */
NULL
,
/* SpUnsealMessage */
ntlm_SpSealMessage
,
ntlm_SpUnsealMessage
,
NULL
,
/* SpGetContextToken */
NULL
,
/* SpQueryContextAttributes */
NULL
,
/* SpCompleteAuthToken */
...
...
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