program UserRights;
{$APPTYPE CONSOLE}
uses
Windows;
const
APPNAME = 'UserRights';
VER = '1.0';
INFO_TEXT = APPNAME + ' ' + VER +
' - asciigen.blogspot.com';
type
TUserPrivileges = record
InternalName: string[255];
Displayname: string[255];
end;
TUserPrivilegesArray = array of TUserPrivileges;
function Ansi2OEM(AnsiString: string): string;
begin
ANSIString := ANSIString + #0;
CharToOEM(PChar(ANSIString), @ANSIString[1]);
Delete(ANSIString, Length(ANSIString), 1);
Result := ANSIString;
end;
function UserName: string;
var
Size: DWORD;
begin
Size := MAX_COMPUTERNAME_LENGTH + 1;
SetLength(Result, Size);
if GetUserName(PChar(Result), Size) then
SetLength(Result, Size)
else
Result := '';
end;
function GetCurrentUserPrivileges: TUserPrivilegesArray;
const
TokenSize = 800; // (SizeOf(Pointer)=4 *200)
var
hToken: THandle;
pTokenInfo: PTOKENPRIVILEGES;
ReturnLen: Cardinal;
i: Integer;
PrivName: PChar;
DisplayName: PChar;
NameSize: Cardinal;
DisplSize: Cardinal;
LangId: Cardinal;
begin
if OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES or
TOKEN_QUERY, hToken) then
begin
GetMem(pTokenInfo, TokenSize);
try
if GetTokenInformation(hToken, TokenPrivileges, pTokenInfo, TokenSize,
ReturnLen) then
begin
GetMem(PrivName, 255);
GetMem(DisplayName, 255);
try
setlength(result, pTokenInfo.PrivilegeCount);
for i := 0 to pTokenInfo.PrivilegeCount - 1 do
begin
DisplSize := 255;
NameSize := 255;
LookupPrivilegeName(nil, pTokenInfo.Privileges[i].Luid, PrivName,
Namesize);
LookupPrivilegeDisplayName(nil, PrivName, DisplayName, DisplSize,
LangId);
SetString(result[i].InternalName, PrivName, NameSize);
SetString(result[i].Displayname, DisplayName, DisplSize);
end;
finally
FreeMem(PrivName, 255);
FreeMem(DisplayName, 255);
end;
end;
finally
FreeMem(PTokenInfo, sizeof(PTokenPrivileges));
end;
end;
end;
var
Loop: Cardinal;
UP: TUserPrivilegesArray;
s: string;
begin
writeln(Ansi2OEM('Benutzerrechte für: ') + UserName());
writeln('');
UP := GetCurrentUserPrivileges;
for Loop := 0 to length(UP) - 1 do
begin
s := UP[Loop].InternalName + ': ' + Ansi2OEM(UP[Loop].Displayname);
writeln(s);
end;
writeln('');
writeln(INFO_TEXT);
readln;
end.

Get User Rights
Abonnieren
Posts (Atom)
Beliebte Posts
-
Windows Key Sniffer 0.82 - Update 08/2024 Der Windows Key Sniffer hat mir im Laufe der Zeit viel Arbeit erspart und unterstützt, viele Wi...
-
Network Source Code Update Source Code Network Update : https://asciigen.blogspot.com/p/network.html Send Message 1.0 Source Server Client ...
-
Windows Defender Bypass Version 0.75 - Update 11/2024 Den Windows 10-eigenen Virenschutz Defender kann man auf mehreren Wegen abschalt...
-
ASCii GIF Animator Update Version 0.68 (32 bit) - 11/2024 Bei dieser überarbeiteten Version ist die Kompatibilität zu den verschiedenen...
-
MD5 Hacker v.0.26 - Update 08.2024 MD5 Hashs sollten eigentlich nicht entschlüsselt werden können. Jedoch gibt es Tools, mit welchen auch ...
-
Dir Sniffer Version 0.11 - Update 02/2025 Dir Sniffer ist ein kleines aber nützliches Tool um herauszufinden, was ihr Programm auf ihrem...
-
Host Editor Version 0.65 - Update 01/2025 Hosts File Editor allows for the easy editing of host files and backup creation. Create your ...
-
Oldskool Font Generator v.0.29 - Update 11/2023 Das Tool stell 508 Bitmap Fonts zu Verfügung. Eigene Fonts können integriert werden, sie...
-
Hard Crypter 0.19 - Update 12/2023 Mit diesem Tool können Sie jede beliebige Datei auf dem Windows-System verschlüsseln. Die Byte-Erse...
Keine Kommentare:
Kommentar veröffentlichen