Results 1 to 2 of 2

Thread: Execute under a different user

  1. #1
    Flare
    Guest

    Execute under a different user

    Is there any API that will allow my program to execute certain functions it does w/ Administrator level access? (IE it bumps up privelages for the certain things it does to root level)

    thx

  2. #2
    I'm about to be a PowerPoster! Hack's Avatar
    Join Date
    Aug 2001
    Location
    Searching for mendhak
    Posts
    58,333
    You can play with AdjustTokenPrivileges. The following applies to this:
    The AdjustTokenPrivileges function enables or disables privileges in the specified access token.
    Enabling or disabling privileges in an access token requires TOKEN_ADJUST_PRIVILEGES access.
    VB Code:
    1. 'Example:
    2. Private Const EWX_LOGOFF = 0
    3. Private Const EWX_SHUTDOWN = 1
    4. Private Const EWX_REBOOT = 2
    5. Private Const EWX_FORCE = 4
    6. Private Const TOKEN_ADJUST_PRIVILEGES = &H20
    7. Private Const TOKEN_QUERY = &H8
    8. Private Const SE_PRIVILEGE_ENABLED = &H2
    9. Private Const ANYSIZE_ARRAY = 1
    10. Private Const VER_PLATFORM_WIN32_NT = 2
    11. Private Type OSVERSIONINFO
    12.     dwOSVersionInfoSize As Long
    13.     dwMajorVersion As Long
    14.     dwMinorVersion As Long
    15.     dwBuildNumber As Long
    16.     dwPlatformId As Long
    17.     szCSDVersion As String * 128
    18. End Type
    19. Private Type LUID
    20.     LowPart As Long
    21.     HighPart As Long
    22. End Type
    23. Private Type LUID_AND_ATTRIBUTES
    24.     pLuid As LUID
    25.     Attributes As Long
    26. End Type
    27. Private Type TOKEN_PRIVILEGES
    28.     PrivilegeCount As Long
    29.     Privileges(ANYSIZE_ARRAY) As LUID_AND_ATTRIBUTES
    30. End Type
    31. Private Declare Function GetCurrentProcess Lib "kernel32" () As Long
    32. Private Declare Function OpenProcessToken Lib "advapi32" (ByVal ProcessHandle As Long, ByVal DesiredAccess As Long, TokenHandle As Long) As Long
    33. Private Declare Function LookupPrivilegeValue Lib "advapi32" Alias "LookupPrivilegeValueA" (ByVal lpSystemName As String, ByVal lpName As String, lpLuid As LUID) As Long
    34. Private Declare Function AdjustTokenPrivileges Lib "advapi32" (ByVal TokenHandle As Long, ByVal DisableAllPrivileges As Long, NewState As TOKEN_PRIVILEGES, ByVal BufferLength As Long, PreviousState As TOKEN_PRIVILEGES, ReturnLength As Long) As Long
    35. Private Declare Function ExitWindowsEx Lib "user32" (ByVal uFlags As Long, ByVal dwReserved As Long) As Long
    36. Private Declare Function GetVersionEx Lib "kernel32" Alias "GetVersionExA" (ByRef lpVersionInformation As OSVERSIONINFO) As Long
    37. 'Detect if the program is running under Windows NT
    38. Public Function IsWinNT() As Boolean
    39.     Dim myOS As OSVERSIONINFO
    40.     myOS.dwOSVersionInfoSize = Len(myOS)
    41.     GetVersionEx myOS
    42.     IsWinNT = (myOS.dwPlatformId = VER_PLATFORM_WIN32_NT)
    43. End Function
    44. 'set the shut down privilege for the current application
    45. Private Sub EnableShutDown()
    46.     Dim hProc As Long
    47.     Dim hToken As Long
    48.     Dim mLUID As LUID
    49.     Dim mPriv As TOKEN_PRIVILEGES
    50.     Dim mNewPriv As TOKEN_PRIVILEGES
    51.     hProc = GetCurrentProcess()
    52.     OpenProcessToken hProc, TOKEN_ADJUST_PRIVILEGES + TOKEN_QUERY, hToken
    53.     LookupPrivilegeValue "", "SeShutdownPrivilege", mLUID
    54.     mPriv.PrivilegeCount = 1
    55.     mPriv.Privileges(0).Attributes = SE_PRIVILEGE_ENABLED
    56.     mPriv.Privileges(0).pLuid = mLUID
    57.     ' enable shutdown privilege for the current application
    58.     AdjustTokenPrivileges hToken, False, mPriv, 4 + (12 * mPriv.PrivilegeCount), mNewPriv, 4 + (12 * mNewPriv.PrivilegeCount)
    59. End Sub
    60. ' Shut Down NT
    61. Public Sub ShutDownNT(Force As Boolean)
    62.     Dim ret As Long
    63.     Dim Flags As Long
    64.     Flags = EWX_SHUTDOWN
    65.     If Force Then Flags = Flags + EWX_FORCE
    66.     If IsWinNT Then EnableShutDown
    67.     ExitWindowsEx Flags, 0
    68. End Sub
    69. 'Restart NT
    70. Public Sub RebootNT(Force As Boolean)
    71.     Dim ret As Long
    72.     Dim Flags As Long
    73.     Flags = EWX_REBOOT
    74.     If Force Then Flags = Flags + EWX_FORCE
    75.     If IsWinNT Then EnableShutDown
    76.     ExitWindowsEx Flags, 0
    77. End Sub
    78. 'Log off the current user
    79. Public Sub LogOffNT(Force As Boolean)
    80.     Dim ret As Long
    81.     Dim Flags As Long
    82.     Flags = EWX_LOGOFF
    83.     If Force Then Flags = Flags + EWX_FORCE
    84.     ExitWindowsEx Flags, 0
    85. End Sub
    86.  
    87. 'In a form
    88. 'This project needs a form with three command buttons
    89. Private Sub Command1_Click()
    90.     LogOffNT True
    91. End Sub
    92. Private Sub Command2_Click()
    93.     RebootNT True
    94. End Sub
    95. Private Sub Command3_Click()
    96.     ShutDownNT True
    97. End Sub
    98. Private Sub Form_Load()
    99.     'KPD-Team 2000
    100.     'URL: [url]http://www.allapi.net/[/url]
    101.     'E-Mail: [email][email protected][/email]
    102.     Command1.Caption = "Log Off NT"
    103.     Command2.Caption = "Reboot NT"
    104.     Command3.Caption = "Shutdown NT"
    105. End Sub

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •  



Click Here to Expand Forum to Full Width