Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Win32/Win64 API (native code) (https://www.delphipraxis.net/17-win32-win64-api-native-code/)
-   -   Delphi Benutzergruppen des angemeldeten Benutzers ermitteln (https://www.delphipraxis.net/155994-benutzergruppen-des-angemeldeten-benutzers-ermitteln.html)

MaBuSE 16. Nov 2010 09:12


Benutzergruppen des angemeldeten Benutzers ermitteln
 
Hallo,
wie kann ich die Benutergruppen des angemeldeten Benutzers ermitteln?

Analog dem Befehl:
Code:
net use <Benutzername> /domain
In Luckies ntuser sind leider nur Funktionen zum Anzeigen der Gruppen enthalten.
Die globalen Gruppen liegen aber nicht auf dem lokalem Rechner.
Es kann aber nicht sein, dass die Server abklappern muss um sich alle Gruppen anzuzeigen um dann zu prüfen ob der Benutzer in der Gruppe ist.
Bei uns sind das im Moment ca. 3000 Gruppen -> das dauert ja dann ewig.

Es muss doch einen Weg geben die zugeordneten Gruppen eines Benutzers anzuzeigen.

Vielen Dank im Vorraus
MaBuSE

Luckie 16. Nov 2010 09:41

AW: Benutzergruppen des angemeldeten Benutzers ermitteln
 
Nun ja, zumindest die lokalen Gruppen eines Benutzers bekommst du mit EnumUserGroups aus MpuNTUser.pas. Die solltest du eigentlich auch entsprechend für Server umschreiben können.

MaBuSE 16. Nov 2010 12:12

AW: Benutzergruppen des angemeldeten Benutzers ermitteln
 
Zitat:

Zitat von Luckie (Beitrag 1061839)
Nun ja, zumindest die lokalen Gruppen eines Benutzers bekommst du mit EnumUserGroups aus MpuNTUser.pas. Die solltest du eigentlich auch entsprechend für Server umschreiben können.

Ja, konnte ich ;-)

Danke. :thumb:

Die Funktion GetDomainUserGroups gibt einfach alle Gruppen als String zurück.

Beisp:
Delphi-Quellcode:
...
uses
  u_GetDomainUserGroups;
...
procedure TForm1.Button1Click(Sender: TObject);
begin
  Memo1.Lines.Text := GetDomainUserGroups('MyDomain', 'MyUserName');
end;
...
Viel Spaß
MaBuSE

PS: Hier der Quelltext der Unit:
Delphi-Quellcode:
////////////////////////////////////////////////////////////////////////////////
// u_GetDomainUserGroups
////////////////////////////////////////////////////////////////////////////////
// (c) 2010 MaBuSE member of delphipraxis.net
// based on MpuNTUser.pas (c) 2005, 2006 Michael Puff (MPu)
////////////////////////////////////////////////////////////////////////////////
// there is no warranty of any kind, use at your own risk
////////////////////////////////////////////////////////////////////////////////
unit u_GetDomainUserGroups;

interface

uses
  Windows, SysUtils, Classes;

// http://msdn.microsoft.com/en-us/library/aa370655%28VS.85%29.aspx
function NetUserGetGroups(servername: LPCWSTR; username: LPCWSTR; level: DWORD; var bufptr: Pointer;
  prefmaxlen: DWORD; var entriesread: DWORD; var totalentries: DWORD): DWORD; stdcall;

// http://msdn.microsoft.com/en-us/library/aa370304(VS.85).aspx
function NetApiBufferFree(Buffer: Pointer): DWORD; stdcall;

// Gibt Gruppen des Benutzers User in der Domäne Domain zurück
function GetDomainUserGroups(const Domain, User: WideString): string;

implementation

function NetUserGetGroups; external 'netapi32.dll' name 'NetUserGetGroups';
function NetApiBufferFree; external 'netapi32.dll' name 'NetApiBufferFree';

const
  MAX_PREFERRED_LENGTH = DWORD(-1);

type
  TGroupInfo0 = record
    grpi0_name: LPWSTR;
  end;
  PGroupInfo0 = ^TGroupInfo0;

function GetDomainUserGroups(const Domain, User: WideString): string;
var
  gui0: Pointer;
  i: Integer;
  Error, EntriesRead, EntriesTotal: DWORD;
begin
  gui0 := nil;
  try
    Error := NetUserGetGroups(PWideChar(Domain), PWideChar(User),
      0, gui0, MAX_PREFERRED_LENGTH, EntriesRead, EntriesTotal);
    if Error <> 0 then RaiseLastOSError(Error)
    else
      with TStringList.Create do
      try
        for i := 0 to EntriesRead - 1 do
          Add(PGroupInfo0(Integer(gui0)+(i*SizeOf(Pointer)))^.grpi0_name);
        Sort;
        Result := Text;
      finally
        Free;
      end;
  finally
    NetApiBufferFree(gui0);
  end;
end;

end.

Dezipaitor 16. Nov 2010 22:05

AW: Benutzergruppen des angemeldeten Benutzers ermitteln
 
Sollte man für angemeldete nicht besser das Token vom User benutzen?! Denn sollte der Benutzer von der Domaine getrennt worden sein, könnte die Aufzählung fehlschlagen.


Alle Zeitangaben in WEZ +1. Es ist jetzt 15:38 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz