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
6d4fb08e
Commit
6d4fb08e
authored
Jul 31, 2006
by
Robert Reif
Committed by
Alexandre Julliard
Jul 31, 2006
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
advapi32: Add computer sid support to LookupAccountSidW.
parent
9d435046
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
51 additions
and
3 deletions
+51
-3
security.c
dlls/advapi32/security.c
+51
-3
No files found.
dlls/advapi32/security.c
View file @
6d4fb08e
...
@@ -143,6 +143,7 @@ static const WCHAR DIALUP[] = { 'D','I','A','L','U','P',0 };
...
@@ -143,6 +143,7 @@ static const WCHAR DIALUP[] = { 'D','I','A','L','U','P',0 };
static
const
WCHAR
DOMAIN
[]
=
{
'D'
,
'O'
,
'M'
,
'A'
,
'I'
,
'N'
,
0
};
static
const
WCHAR
DOMAIN
[]
=
{
'D'
,
'O'
,
'M'
,
'A'
,
'I'
,
'N'
,
0
};
static
const
WCHAR
ENTERPRISE_DOMAIN_CONTROLLERS
[]
=
{
'E'
,
'N'
,
'T'
,
'E'
,
'R'
,
'P'
,
'R'
,
'I'
,
'S'
,
'E'
,
' '
,
'D'
,
'O'
,
'M'
,
'A'
,
'I'
,
'N'
,
' '
,
'C'
,
'O'
,
'N'
,
'T'
,
'R'
,
'O'
,
'L'
,
'L'
,
'E'
,
'R'
,
'S'
,
0
};
static
const
WCHAR
ENTERPRISE_DOMAIN_CONTROLLERS
[]
=
{
'E'
,
'N'
,
'T'
,
'E'
,
'R'
,
'P'
,
'R'
,
'I'
,
'S'
,
'E'
,
' '
,
'D'
,
'O'
,
'M'
,
'A'
,
'I'
,
'N'
,
' '
,
'C'
,
'O'
,
'N'
,
'T'
,
'R'
,
'O'
,
'L'
,
'L'
,
'E'
,
'R'
,
'S'
,
0
};
static
const
WCHAR
Everyone
[]
=
{
'E'
,
'v'
,
'e'
,
'r'
,
'y'
,
'o'
,
'n'
,
'e'
,
0
};
static
const
WCHAR
Everyone
[]
=
{
'E'
,
'v'
,
'e'
,
'r'
,
'y'
,
'o'
,
'n'
,
'e'
,
0
};
static
const
WCHAR
Guest
[]
=
{
'G'
,
'u'
,
'e'
,
's'
,
't'
,
0
};
static
const
WCHAR
Guests
[]
=
{
'G'
,
'u'
,
'e'
,
's'
,
't'
,
's'
,
0
};
static
const
WCHAR
Guests
[]
=
{
'G'
,
'u'
,
'e'
,
's'
,
't'
,
's'
,
0
};
static
const
WCHAR
INTERACTIVE
[]
=
{
'I'
,
'N'
,
'T'
,
'E'
,
'R'
,
'A'
,
'C'
,
'T'
,
'I'
,
'V'
,
'E'
,
0
};
static
const
WCHAR
INTERACTIVE
[]
=
{
'I'
,
'N'
,
'T'
,
'E'
,
'R'
,
'A'
,
'C'
,
'T'
,
'I'
,
'V'
,
'E'
,
0
};
static
const
WCHAR
LOCAL
[]
=
{
'L'
,
'O'
,
'C'
,
'A'
,
'L'
,
0
};
static
const
WCHAR
LOCAL
[]
=
{
'L'
,
'O'
,
'C'
,
'A'
,
'L'
,
0
};
...
@@ -1825,9 +1826,10 @@ LookupAccountSidW(
...
@@ -1825,9 +1826,10 @@ LookupAccountSidW(
OUT
PSID_NAME_USE
name_use
)
OUT
PSID_NAME_USE
name_use
)
{
{
int
i
,
j
;
int
i
,
j
;
const
WCHAR
*
ac
=
Administrator
;
/* FIXME */
const
WCHAR
*
ac
=
NULL
;
const
WCHAR
*
dm
=
DOMAIN
;
/* FIXME */
const
WCHAR
*
dm
=
NULL
;
SID_NAME_USE
use
=
SidTypeUser
;
/* FIXME */
SID_NAME_USE
use
=
0
;
LPWSTR
computer_name
=
NULL
;
TRACE
(
"(%s,sid=%s,%p,%p(%lu),%p,%p(%lu),%p)
\n
"
,
TRACE
(
"(%s,sid=%s,%p,%p(%lu),%p,%p(%lu),%p)
\n
"
,
debugstr_w
(
system
),
debugstr_sid
(
sid
),
debugstr_w
(
system
),
debugstr_sid
(
sid
),
...
@@ -1841,6 +1843,7 @@ LookupAccountSidW(
...
@@ -1841,6 +1843,7 @@ LookupAccountSidW(
return
FALSE
;
return
FALSE
;
}
}
/* check the well known SIDs first */
for
(
i
=
0
;
i
<=
60
;
i
++
)
{
for
(
i
=
0
;
i
<=
60
;
i
++
)
{
if
(
IsWellKnownSid
(
sid
,
i
))
{
if
(
IsWellKnownSid
(
sid
,
i
))
{
for
(
j
=
0
;
j
<
(
sizeof
(
ACCOUNT_SIDS
)
/
sizeof
(
ACCOUNT_SIDS
[
0
]));
j
++
)
{
for
(
j
=
0
;
j
<
(
sizeof
(
ACCOUNT_SIDS
)
/
sizeof
(
ACCOUNT_SIDS
[
0
]));
j
++
)
{
...
@@ -1854,6 +1857,45 @@ LookupAccountSidW(
...
@@ -1854,6 +1857,45 @@ LookupAccountSidW(
}
}
}
}
if
(
dm
==
NULL
)
{
MAX_SID
local
;
MAX_SID
admin
;
MAX_SID
guest
;
/* check for the local computer next */
if
(
ADVAPI_GetComputerSid
(
&
local
))
{
DWORD
size
=
MAX_COMPUTERNAME_LENGTH
+
1
;
BOOL
result
;
computer_name
=
HeapAlloc
(
GetProcessHeap
(),
0
,
size
*
sizeof
(
WCHAR
));
result
=
GetComputerNameW
(
computer_name
,
&
size
);
if
(
result
)
{
CopySid
(
GetSidLengthRequired
(
local
.
SubAuthorityCount
),
&
admin
,
&
local
);
admin
.
SubAuthorityCount
++
;
admin
.
SubAuthority
[
4
]
=
DOMAIN_USER_RID_ADMIN
;
CopySid
(
GetSidLengthRequired
(
local
.
SubAuthorityCount
),
&
guest
,
&
local
);
guest
.
SubAuthorityCount
++
;
guest
.
SubAuthority
[
4
]
=
DOMAIN_USER_RID_GUEST
;
if
(
EqualSid
(
sid
,
&
local
))
{
dm
=
computer_name
;
ac
=
Blank
;
use
=
3
;
}
else
if
(
EqualSid
(
sid
,
&
admin
))
{
dm
=
computer_name
;
ac
=
Administrator
;
use
=
1
;
}
else
if
(
EqualSid
(
sid
,
&
guest
))
{
dm
=
computer_name
;
ac
=
Guest
;
use
=
1
;
}
}
}
}
if
(
dm
)
{
*
accountSize
=
strlenW
(
ac
)
+
1
;
*
accountSize
=
strlenW
(
ac
)
+
1
;
if
(
account
&&
(
*
accountSize
>
strlenW
(
ac
)))
if
(
account
&&
(
*
accountSize
>
strlenW
(
ac
)))
strcpyW
(
account
,
ac
);
strcpyW
(
account
,
ac
);
...
@@ -1863,7 +1905,13 @@ LookupAccountSidW(
...
@@ -1863,7 +1905,13 @@ LookupAccountSidW(
strcpyW
(
domain
,
dm
);
strcpyW
(
domain
,
dm
);
*
name_use
=
use
;
*
name_use
=
use
;
HeapFree
(
GetProcessHeap
(),
0
,
computer_name
);
return
TRUE
;
return
TRUE
;
}
HeapFree
(
GetProcessHeap
(),
0
,
computer_name
);
SetLastError
(
ERROR_NONE_MAPPED
);
return
FALSE
;
}
}
/******************************************************************************
/******************************************************************************
...
...
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