Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
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-winehq
Commits
dbe5453f
Commit
dbe5453f
authored
Apr 15, 2009
by
Hans Leidekker
Committed by
Alexandre Julliard
Apr 15, 2009
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
advapi32: Fix buffer size query for CreateWellKnownSid.
parent
c23beb31
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
40 additions
and
6 deletions
+40
-6
security.c
dlls/advapi32/security.c
+18
-5
security.c
dlls/advapi32/tests/security.c
+22
-1
No files found.
dlls/advapi32/security.c
View file @
dbe5453f
...
@@ -859,7 +859,8 @@ CreateWellKnownSid( WELL_KNOWN_SID_TYPE WellKnownSidType,
...
@@ -859,7 +859,8 @@ CreateWellKnownSid( WELL_KNOWN_SID_TYPE WellKnownSidType,
unsigned
int
i
;
unsigned
int
i
;
TRACE
(
"(%d, %s, %p, %p)
\n
"
,
WellKnownSidType
,
debugstr_sid
(
DomainSid
),
pSid
,
cbSid
);
TRACE
(
"(%d, %s, %p, %p)
\n
"
,
WellKnownSidType
,
debugstr_sid
(
DomainSid
),
pSid
,
cbSid
);
if
(
cbSid
==
NULL
||
pSid
==
NULL
||
(
DomainSid
&&
!
IsValidSid
(
DomainSid
)))
{
if
(
cbSid
==
NULL
||
(
DomainSid
&&
!
IsValidSid
(
DomainSid
)))
{
SetLastError
(
ERROR_INVALID_PARAMETER
);
SetLastError
(
ERROR_INVALID_PARAMETER
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -868,11 +869,17 @@ CreateWellKnownSid( WELL_KNOWN_SID_TYPE WellKnownSidType,
...
@@ -868,11 +869,17 @@ CreateWellKnownSid( WELL_KNOWN_SID_TYPE WellKnownSidType,
if
(
WellKnownSids
[
i
].
Type
==
WellKnownSidType
)
{
if
(
WellKnownSids
[
i
].
Type
==
WellKnownSidType
)
{
DWORD
length
=
GetSidLengthRequired
(
WellKnownSids
[
i
].
Sid
.
SubAuthorityCount
);
DWORD
length
=
GetSidLengthRequired
(
WellKnownSids
[
i
].
Sid
.
SubAuthorityCount
);
if
(
*
cbSid
<
length
)
{
if
(
*
cbSid
<
length
)
{
*
cbSid
=
length
;
SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
return
FALSE
;
return
FALSE
;
}
}
if
(
!
pSid
)
{
SetLastError
(
ERROR_INVALID_PARAMETER
);
return
FALSE
;
}
CopyMemory
(
pSid
,
&
WellKnownSids
[
i
].
Sid
.
Revision
,
length
);
CopyMemory
(
pSid
,
&
WellKnownSids
[
i
].
Sid
.
Revision
,
length
);
*
cbSid
=
length
;
*
cbSid
=
length
;
return
TRUE
;
return
TRUE
;
...
@@ -891,11 +898,17 @@ CreateWellKnownSid( WELL_KNOWN_SID_TYPE WellKnownSidType,
...
@@ -891,11 +898,17 @@ CreateWellKnownSid( WELL_KNOWN_SID_TYPE WellKnownSidType,
DWORD
domain_sid_length
=
GetSidLengthRequired
(
domain_subauth
);
DWORD
domain_sid_length
=
GetSidLengthRequired
(
domain_subauth
);
DWORD
output_sid_length
=
GetSidLengthRequired
(
domain_subauth
+
1
);
DWORD
output_sid_length
=
GetSidLengthRequired
(
domain_subauth
+
1
);
if
(
*
cbSid
<
output_sid_length
)
{
if
(
*
cbSid
<
output_sid_length
)
{
*
cbSid
=
output_sid_length
;
SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
SetLastError
(
ERROR_INSUFFICIENT_BUFFER
);
return
FALSE
;
return
FALSE
;
}
}
if
(
!
pSid
)
{
SetLastError
(
ERROR_INVALID_PARAMETER
);
return
FALSE
;
}
CopyMemory
(
pSid
,
DomainSid
,
domain_sid_length
);
CopyMemory
(
pSid
,
DomainSid
,
domain_sid_length
);
(
*
GetSidSubAuthorityCount
(
pSid
))
++
;
(
*
GetSidSubAuthorityCount
(
pSid
))
++
;
(
*
GetSidSubAuthority
(
pSid
,
domain_subauth
))
=
WellKnownRids
[
i
].
Rid
;
(
*
GetSidSubAuthority
(
pSid
,
domain_subauth
))
=
WellKnownRids
[
i
].
Rid
;
...
...
dlls/advapi32/tests/security.c
View file @
dbe5453f
...
@@ -1354,7 +1354,9 @@ struct well_known_sid_value
...
@@ -1354,7 +1354,9 @@ struct well_known_sid_value
static
void
test_CreateWellKnownSid
(
void
)
static
void
test_CreateWellKnownSid
(
void
)
{
{
SID_IDENTIFIER_AUTHORITY
ident
=
{
SECURITY_NT_AUTHORITY
};
SID_IDENTIFIER_AUTHORITY
ident
=
{
SECURITY_NT_AUTHORITY
};
PSID
domainsid
;
PSID
domainsid
,
sid
;
DWORD
size
,
error
;
BOOL
ret
;
int
i
;
int
i
;
if
(
!
pCreateWellKnownSid
)
if
(
!
pCreateWellKnownSid
)
...
@@ -1363,6 +1365,25 @@ static void test_CreateWellKnownSid(void)
...
@@ -1363,6 +1365,25 @@ static void test_CreateWellKnownSid(void)
return
;
return
;
}
}
size
=
0
;
SetLastError
(
0xdeadbeef
);
ret
=
pCreateWellKnownSid
(
WinInteractiveSid
,
NULL
,
NULL
,
&
size
);
error
=
GetLastError
();
ok
(
!
ret
,
"CreateWellKnownSid succeeded
\n
"
);
ok
(
error
==
ERROR_INSUFFICIENT_BUFFER
,
"expected ERROR_INSUFFICIENT_BUFFER, got %u
\n
"
,
error
);
ok
(
size
,
"expected size > 0
\n
"
);
SetLastError
(
0xdeadbeef
);
ret
=
pCreateWellKnownSid
(
WinInteractiveSid
,
NULL
,
NULL
,
&
size
);
error
=
GetLastError
();
ok
(
!
ret
,
"CreateWellKnownSid succeeded
\n
"
);
ok
(
error
==
ERROR_INVALID_PARAMETER
,
"expected ERROR_INVALID_PARAMETER, got %u
\n
"
,
error
);
sid
=
HeapAlloc
(
GetProcessHeap
(),
0
,
size
);
ret
=
pCreateWellKnownSid
(
WinInteractiveSid
,
NULL
,
sid
,
&
size
);
ok
(
ret
,
"CreateWellKnownSid failed %u
\n
"
,
GetLastError
());
HeapFree
(
GetProcessHeap
(),
0
,
sid
);
/* a domain sid usually have three subauthorities but we test that CreateWellKnownSid doesn't check it */
/* a domain sid usually have three subauthorities but we test that CreateWellKnownSid doesn't check it */
AllocateAndInitializeSid
(
&
ident
,
6
,
SECURITY_NT_NON_UNIQUE
,
12
,
23
,
34
,
45
,
56
,
0
,
0
,
&
domainsid
);
AllocateAndInitializeSid
(
&
ident
,
6
,
SECURITY_NT_NON_UNIQUE
,
12
,
23
,
34
,
45
,
56
,
0
,
0
,
&
domainsid
);
...
...
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