I need to check programmatically (in .NET) whether a given user (domain account) is a member of the built-in Administrators group on a current computer (the one where the application gets executed).
Is it possible?
I need to check programmatically (in .NET) whether a given user (domain account) is a member of the built-in Administrators group on a current computer (the one where the application gets executed).
Is it possible?
If you are talking about the currently running user then
If not then I expect its possible to set identity to a particular user but not looked into how.
I don't know about .Net, but in win32, the easy way is to call IsUserAnAdmin(). If you need more control, you can open the process token and check with CheckTokenMembership for each group you need to check
Edit: See pinvoke.net for .NET sample code (Thanks chopeen)
There is a Win32 API for this you could P/Invoke: IsUserAnAdmin
The question is more complex on Vista ... see this blog post.
You could loop the groups like i did in this answer:
Determining members of local groups via C#
After reading some more, the easiest thing would be to use the
System.DirectoryServices.AccountManagement
namespace. Here is how it can be used:http://www.leastprivilege.com/SystemDirectoryServicesAccountManagement.aspx
Sample: