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
9cb94b27
Commit
9cb94b27
authored
Jun 20, 2005
by
Robert Shearman
Committed by
Alexandre Julliard
Jun 20, 2005
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Implement RtlImpersonateSelf, RevertToSelf and MapGenericMask.
parent
433f72f8
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
81 additions
and
13 deletions
+81
-13
security.c
dlls/advapi32/security.c
+34
-9
sec.c
dlls/ntdll/sec.c
+46
-3
winternl.h
include/winternl.h
+1
-1
No files found.
dlls/advapi32/security.c
View file @
9cb94b27
...
...
@@ -1770,23 +1770,40 @@ NotifyBootConfigStatus( DWORD x1 )
/******************************************************************************
* RevertToSelf [ADVAPI32.@]
*
* Ends the impersonation of a user.
*
* PARAMS
* void []
*
* RETURNS
* Success: TRUE.
* Failure: FALSE.
*/
BOOL
WINAPI
RevertToSelf
(
void
)
{
FIXME
(
"(), stub
\n
"
);
return
TRUE
;
HANDLE
Token
=
NULL
;
return
set_ntstatus
(
NtSetInformationThread
(
GetCurrentThread
(),
ThreadImpersonationToken
,
&
Token
,
sizeof
(
Token
)
)
);
}
/******************************************************************************
* ImpersonateSelf [ADVAPI32.@]
*
* Makes an impersonation token that represents the process user and assigns
* to the current thread.
*
* PARAMS
* ImpersonationLevel [I] Level at which to impersonate.
*
* RETURNS
* Success: TRUE.
* Failure: FALSE.
*/
BOOL
WINAPI
ImpersonateSelf
(
SECURITY_IMPERSONATION_LEVEL
ImpersonationLevel
)
{
return
RtlImpersonateSelf
(
ImpersonationLevel
);
return
set_ntstatus
(
RtlImpersonateSelf
(
ImpersonationLevel
)
);
}
/******************************************************************************
...
...
@@ -1844,14 +1861,22 @@ BOOL WINAPI AccessCheckByType(
return
!*
AccessStatus
;
}
/******************************************************************************
* MapGenericMask [ADVAPI32.@]
*
* Maps generic access rights into specific access rights according to the
* supplied mapping.
*
* PARAMS
* AccessMask [I/O] Access rights.
* GenericMapping [I] The mapping between generic and specific rights.
*
* RETURNS
* Nothing.
*/
VOID
WINAPI
MapGenericMask
(
PDWORD
AccessMask
,
PGENERIC_MAPPING
GenericMapping
)
{
FIXME
(
"%p %p - stub
\n
"
,
AccessMask
,
GenericMapping
);
*
AccessMask
|=
GenericMapping
->
GenericRead
;
*
AccessMask
|=
GenericMapping
->
GenericWrite
;
*
AccessMask
|=
GenericMapping
->
GenericExecute
;
*
AccessMask
|=
GenericMapping
->
GenericAll
;
RtlMapGenericMask
(
AccessMask
,
GenericMapping
);
}
/*************************************************************************
...
...
dlls/ntdll/sec.c
View file @
9cb94b27
...
...
@@ -1365,12 +1365,55 @@ RtlAdjustPrivilege(ULONG Privilege,
/******************************************************************************
* RtlImpersonateSelf [NTDLL.@]
*
* Makes an impersonation token that represents the process user and assigns
* to the current thread.
*
* PARAMS
* ImpersonationLevel [I] Level at which to impersonate.
*
* RETURNS
* Success: STATUS_SUCCESS.
* Failure: NTSTATUS code.
*/
BOOL
WINAPI
NTSTATUS
WINAPI
RtlImpersonateSelf
(
SECURITY_IMPERSONATION_LEVEL
ImpersonationLevel
)
{
FIXME
(
"(%08x), stub
\n
"
,
ImpersonationLevel
);
return
TRUE
;
NTSTATUS
Status
;
OBJECT_ATTRIBUTES
ObjectAttributes
;
HANDLE
ProcessToken
;
HANDLE
ImpersonationToken
;
TRACE
(
"(%08x)
\n
"
,
ImpersonationLevel
);
Status
=
NtOpenProcessToken
(
NtCurrentProcess
(),
TOKEN_DUPLICATE
,
&
ProcessToken
);
if
(
Status
!=
STATUS_SUCCESS
)
return
Status
;
InitializeObjectAttributes
(
&
ObjectAttributes
,
NULL
,
0
,
NULL
,
NULL
);
Status
=
NtDuplicateToken
(
ProcessToken
,
TOKEN_IMPERSONATE
,
&
ObjectAttributes
,
ImpersonationLevel
,
TokenImpersonation
,
&
ImpersonationToken
);
if
(
Status
!=
STATUS_SUCCESS
)
{
NtClose
(
ProcessToken
);
return
Status
;
}
Status
=
NtSetInformationThread
(
GetCurrentThread
(),
ThreadImpersonationToken
,
&
ImpersonationToken
,
sizeof
(
ImpersonationToken
)
);
NtClose
(
ImpersonationToken
);
NtClose
(
ProcessToken
);
return
Status
;
}
/******************************************************************************
...
...
include/winternl.h
View file @
9cb94b27
...
...
@@ -1890,7 +1890,7 @@ PVOID WINAPI RtlImageDirectoryEntryToData(HMODULE,BOOL,WORD,ULONG *);
PIMAGE_NT_HEADERS
WINAPI
RtlImageNtHeader
(
HMODULE
);
PIMAGE_SECTION_HEADER
WINAPI
RtlImageRvaToSection
(
const
IMAGE_NT_HEADERS
*
,
HMODULE
,
DWORD
);
PVOID
WINAPI
RtlImageRvaToVa
(
const
IMAGE_NT_HEADERS
*
,
HMODULE
,
DWORD
,
IMAGE_SECTION_HEADER
**
);
BOOL
WINAPI
RtlImpersonateSelf
(
SECURITY_IMPERSONATION_LEVEL
);
NTSTATUS
WINAPI
RtlImpersonateSelf
(
SECURITY_IMPERSONATION_LEVEL
);
void
WINAPI
RtlInitString
(
PSTRING
,
PCSZ
);
void
WINAPI
RtlInitAnsiString
(
PANSI_STRING
,
PCSZ
);
void
WINAPI
RtlInitUnicodeString
(
PUNICODE_STRING
,
PCWSTR
);
...
...
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