Atlanta Custom Software Development 

 
   Search        Code/Page
 

User Login
Email

Password

 

Forgot the Password?
Services
» Web Development
» Maintenance
» Data Integration/BI
» Information Management
Programming
  Database
Automation
OS/Networking
Graphics
Links
Tools
» Regular Expr Tester
» Free Tools

Check whether the current user is an administrator
[ All Languages » VB »  Windows]

Total Hit ( 5106)

Rate this article:     Poor     Excellent 

 Submit Your Question/Comment about this article

Rating


 


This function will determine whether or not a thread is running in the user context of the local Administrator account. You need to examine the access token associated with that thread using the GetTokenInformation() API, since this access token represents the user under which the thread is running. By default the token associated with a thread is that of its containing process, but this user context will be superceded by any token attached directly to the thread. So to determine a thread's user context, first attempt to obtain any token attached directly to the thread with OpenThreadToken(). If this fails, and it reports an ERROR_NO_TOKEN, then obtain the token of the thread's containing process with OpenProcessToken().

Click here to copy the following block
Option Explicit
Option Base 0   ' Important assumption for this code

'Fixed at this size for comfort. Could be bigger or made dynamic.
Private Const ANYSIZE_ARRAY As Long = 100

' Security APIs
Private Const TokenUser = 1
Private Const TokenGroups = 2
Private Const TokenPrivileges = 3
Private Const TokenOwner = 4
Private Const TokenPrimaryGroup = 5
Private Const TokenDefaultDacl = 6
Private Const TokenSource = 7
Private Const TokenType = 8
Private Const TokenImpersonationLevel = 9
Private Const TokenStatistics = 10

' Token Specific Access Rights
Private Const TOKEN_ASSIGN_PRIMARY = &H1
Private Const TOKEN_DUPLICATE = &H2
Private Const TOKEN_IMPERSONATE = &H4
Private Const TOKEN_QUERY = &H8
Private Const TOKEN_QUERY_SOURCE = &H10
Private Const TOKEN_ADJUST_PRIVILEGES = &H20
Private Const TOKEN_ADJUST_GROUPS = &H40
Private Const TOKEN_ADJUST_DEFAULT = &H80

' NT well-known SIDs
Private Const SECURITY_DIALUP_RID = &H1
Private Const SECURITY_NETWORK_RID = &H2
Private Const SECURITY_BATCH_RID = &H3
Private Const SECURITY_INTERACTIVE_RID = &H4
Private Const SECURITY_SERVICE_RID = &H6
Private Const SECURITY_ANONYMOUS_LOGON_RID = &H7
Private Const SECURITY_LOGON_IDS_RID = &H5
Private Const SECURITY_LOCAL_SYSTEM_RID = &H12
Private Const SECURITY_NT_NON_UNIQUE = &H15
Private Const SECURITY_BUILTIN_DOMAIN_RID = &H20

' Well-known domain relative sub-authority values (RIDs)
Private Const DOMAIN_ALIAS_RID_ADMINS = &H220
Private Const DOMAIN_ALIAS_RID_USERS = &H221
Private Const DOMAIN_ALIAS_RID_GUESTS = &H222
Private Const DOMAIN_ALIAS_RID_POWER_USERS = &H223
Private Const DOMAIN_ALIAS_RID_ACCOUNT_OPS = &H224
Private Const DOMAIN_ALIAS_RID_SYSTEM_OPS = &H225
Private Const DOMAIN_ALIAS_RID_PRINT_OPS = &H226
Private Const DOMAIN_ALIAS_RID_BACKUP_OPS = &H227
Private Const DOMAIN_ALIAS_RID_REPLICATOR = &H228

Private Const SECURITY_NT_AUTHORITY = &H5

Private Type SID_AND_ATTRIBUTES
  Sid As Long
  Attributes As Long
End Type

Private Type TOKEN_GROUPS
  GroupCount As Long
  Groups(ANYSIZE_ARRAY) As SID_AND_ATTRIBUTES
End Type

Private Type SID_IDENTIFIER_AUTHORITY
  Value(0 To 5) As Byte
End Type

Private Declare Function GetCurrentProcess Lib "Kernel32" () As Long

Private Declare Function GetCurrentThread Lib "Kernel32" () As Long

Private Declare Function OpenProcessToken Lib "Advapi32" (ByVal ProcessHandle _
  As Long, ByVal DesiredAccess As Long, TokenHandle As Long) As Long

Private Declare Function OpenThreadToken Lib "Advapi32" (ByVal ThreadHandle As _
  Long, ByVal DesiredAccess As Long, ByVal OpenAsSelf As Long, _
  TokenHandle As Long) As Long

Private Declare Function GetTokenInformation Lib "Advapi32" (ByVal TokenHandle _
  As Long, TokenInformationClass As Integer, TokenInformation As Any, _
  ByVal TokenInformationLength As Long, ReturnLength As Long) As Long

Private Declare Function AllocateAndInitializeSid Lib "Advapi32" _
  (pIdentifierAuthority As SID_IDENTIFIER_AUTHORITY, ByVal nSubAuthorityCount _
  As Byte, ByVal nSubAuthority0 As Long, ByVal nSubAuthority1 As Long, _
  ByVal nSubAuthority2 As Long, ByVal nSubAuthority3 As Long, _
  ByVal nSubAuthority4 As Long, ByVal nSubAuthority5 As Long, _
  ByVal nSubAuthority6 As Long, ByVal nSubAuthority7 As Long, _
  lpPSid As Long) As Long

Private Declare Function RtlMoveMemory Lib "Kernel32" (Dest As Any, _
  Source As Any, ByVal lSize As Long) As Long

Private Declare Function IsValidSid Lib "Advapi32" (ByVal pSid As Long) As Long

Private Declare Function EqualSid Lib "Advapi32" (pSid1 As Any, _
  pSid2 As Any) As Long

Private Declare Sub FreeSid Lib "Advapi32" (pSid As Any)

Private Declare Function CloseHandle Lib "Kernel32" (ByVal hObject As Long) As _
  Long


' Returns True if the thread is running in the
' user context of the local Administrator account
' Example:
'  MsgBox "Current user is the Administrator: " & IsAdmin
Public Function IsAdmin() As Boolean
  Dim hProcessToken    As Long
  Dim BufferSize     As Long
  Dim psidAdmin      As Long
  Dim lResult       As Long
  Dim X          As Integer
  Dim tpTokens      As TOKEN_GROUPS
  Dim tpSidAuth      As SID_IDENTIFIER_AUTHORITY
  Dim llRetVal      As Long
  Dim InfoBuffer()    As Long
  Dim sids()       As SID_AND_ATTRIBUTES
  Dim llCount       As Long
  Dim llIdx        As Long
  Dim llMax        As Long
  IsAdmin = False
  tpSidAuth.Value(5) = SECURITY_NT_AUTHORITY

   ' Obtain current process token
  If Not OpenThreadToken(GetCurrentThread(), TOKEN_QUERY, True, _
    hProcessToken) Then
    Call OpenProcessToken(GetCurrentProcess(), TOKEN_QUERY, hProcessToken)
  End If
  If hProcessToken Then

     ' Deternine the buffer size required
    llRetVal = GetTokenInformation(hProcessToken, ByVal TokenGroups, 0, 0, _
      BufferSize) ' Determine required buffer size
    If BufferSize Then

      ReDim InfoBuffer((BufferSize \ 4) - 1) As Long
      ReDim sids(0 To tpTokens.GroupCount) As SID_AND_ATTRIBUTES
       ' Retrieve your token information
      lResult = GetTokenInformation(hProcessToken, ByVal TokenGroups, _
        InfoBuffer(0), BufferSize, BufferSize)

      If lResult <> 1 Then Exit Function

       ' Move it from memory into the token structure
      Call RtlMoveMemory(tpTokens, InfoBuffer(0), LenB(tpTokens))

       ' Retreive the admins sid pointer
      lResult = AllocateAndInitializeSid(tpSidAuth, 2, _
        SECURITY_BUILTIN_DOMAIN_RID, DOMAIN_ALIAS_RID_ADMINS, 0, 0, 0, _
        0, 0, 0, psidAdmin)
      If lResult <> 1 Then Exit Function
      If IsValidSid(psidAdmin) Then
        For X = 0 To tpTokens.GroupCount

           ' Run through your token sid pointers
          If IsValidSid(tpTokens.Groups(X).Sid) Then

             ' Test for a match between the admin sid equalling
             ' your Sid 's
            If EqualSid(ByVal tpTokens.Groups(X).Sid, _
              ByVal psidAdmin) Then
              IsAdmin = True
              Exit For
            End If
          End If
        Next
      End If
      If psidAdmin Then Call FreeSid(psidAdmin)
    End If
    Call CloseHandle(hProcessToken)
  End If
End Function


Submitted By : Nayan Patel  (Member Since : 5/26/2004 12:23:06 PM)

Job Description : He is the moderator of this site and currently working as an independent consultant. He works with VB.net/ASP.net, SQL Server and other MS technologies. He is MCSD.net, MCDBA and MCSE. In his free time he likes to watch funny movies and doing oil painting.
View all (893) submissions by this author  (Birth Date : 7/14/1981 )


Home   |  Comment   |  Contact Us   |  Privacy Policy   |  Terms & Conditions   |  BlogsZappySys

© 2008 BinaryWorld LLC. All rights reserved.