How to check windows administrative privilege?
Moderators: FourthWorld, heatherlaine, Klaus, kevinmiller, robinmiller
- 
				alemrantareq
- Posts: 203
- Joined: Wed Jul 23, 2008 8:46 am
How to check windows administrative privilege?
I've made a tweak software which needs administrator rights before running. Does anyone tell me what will be the script for checking administrative privilege of windows with if function? I've searched it in the sample script websites but there are no such scripts that might help me. pls pls help me ...[/quote]
			
			
									
									
						The only way I know how you could do this would be with getting Rev to run some vbscript which you can call by running a file from the shell. I don't believe it would be possible to use the "do... as vbscript" method directly from Rev, as 
The best way I've found (rather than interrogating the user groups, which may be nested very deeply) is as suggested near the end of this thread http://www.myitforum.com/forums/m_14241 ... htm#142413 which checks to see if the logged on user has access to the administrative share on the local drive.
So you could store this vbscript code file in the appropriate place, or write it out temporarily and delete it after running:
Then in your Rev app, call it via
			
			
									
									
						whereas the Rev shell command will receive the wscript.echo as a return value. In any event I'm unaware of how to get a "do..." statement list to parse "if..then" constructs.Rev docs wrote:Any scripts on Windows which contain references to WScript will fail to run as WScript objects do not exist in the Revolution Environment
The best way I've found (rather than interrogating the user groups, which may be nested very deeply) is as suggested near the end of this thread http://www.myitforum.com/forums/m_14241 ... htm#142413 which checks to see if the logged on user has access to the administrative share on the local drive.
So you could store this vbscript code file in the appropriate place, or write it out temporarily and delete it after running:
Code: Select all
Set Shell = CreateObject("WScript.Shell") 
Set filesys = CreateObject("Scripting.FileSystemObject") 
computername = Shell.ExpandEnvironmentStrings("%computername%") 
if filesys.FolderExists("\" & computername & "\Admin$\System32") then 
wScript.echo ("Admin") 
else 
wScript.echo ("Not Admin") 
end if
set filesys = nothing
set Shell = nothing
Code: Select all
local tResult
set the hideConsoleWindows to true
--stops a command prompt window/task bar icon appearing
put shell("cscript.exe //nologo" && quote & <<path/filename.vbs>> & quote) into tResult
--enclose the path/filename in quotes to be on the safe side
--use cscript.exe rather than wscript.exe to return values to the command
--console from where it will be picked up by the Rev shell, rather than
--the Windows interface where it will pop up on screen and not be
--available to Rev.
--if you leave out the nologo option, then the result will be returned with
--a text "logo" of several lines of "Microsoft Windows Scripting Host" blah
--before the returned value. Using the nologo option just gives you the
--returned value on its own. (With the proviso indicated below).
if the last char of tResult is cr then delete the last char of tResult
--windows normally returns a trailing cr via the wscript.echo so this just tidies it up. 
if tResult is "Admin" then
  answer "Admin"
  --do stuff based on admin status
else
  answer "Sorry, you need administrative rights to proceed"
end if
As a slight variation, you could also potentially get the computer name from Rev and pass that as an argument, so that the vbscript doesn't have to make another wScript shell for interrogating the machine name, as in
			
			
									
									
						Code: Select all
computername = wScript.Arguments.Named.Item("comp")
Set filesys = CreateObject("Scripting.FileSystemObject") 
if filesys.FolderExists("\\" & computername & "\Admin$\System32") then 
wScript.echo ("Admin") 
else 
wScript.echo ("Not Admin") 
end if
set filesys = nothingCode: Select all
set the hideConsoleWindows to true
   put shell ("cscript.exe //nologo" && quote & <<path/filename.vbs>> & quote && quote & "/comp:" & $COMPUTERNAME & quote) into tResult
   if the last char of tResult is cr then delete the last char of tResult
  etc etc...
- 
				trevordevore
- VIP Livecode Opensource Backer 
- Posts: 1005
- Joined: Sat Apr 08, 2006 3:06 pm
- Contact:
Thanks for posting that code SparkOut. I modified it a bit so it would work with 'do as vbscript' and I added some error checking. I did a quick test on XP admin/non-admin accounts and it worked but the code returned a false positive on a Vista standard (non-admin) account. In any case here is the example of how to run it using 'do ... as'.
Here is the VBScript:
And here is some code for a button to test. I put the VBScript in a custom property of the button:
If all goes well you will get "admin" or "not admin" back. If an error occurred then the string will start with "error,".
			
			
									
									Here is the VBScript:
Code: Select all
On Error Resume Next
if Err.Number = 0 then
	Set Shell = CreateObject("WScript.Shell") 
	if Err.Number <> 0 then
		result = "error,unable to create shell object"
	end if
end if
if Err.Number = 0 then
	Set filesys = CreateObject("Scripting.FileSystemObject") 
	if Err.Number <> 0 then
		result = "error,unable to create file system object"
	end if
end if
if Err.Number = 0 then
	computername = Shell.ExpandEnvironmentStrings("%computername%") 
	if filesys.FolderExists("\\" & computername & "\Admin$\System32") then 
		result = "admin"
	else 
		result = "not admin"
	end if
	
	if Err.Number <> 0 then
		result = "error,unable to check administrative rights"
	end if
end if
set filesys = nothing 
set Shell = nothing
Code: Select all
    put the uVBScript of me into theScript
    do theScript as "vbscript"
    answer the result
Trevor DeVore
ScreenSteps - https://www.screensteps.com
LiveCode Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode
LiveCode Builder Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode-builder
						ScreenSteps - https://www.screensteps.com
LiveCode Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode
LiveCode Builder Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode-builder
- 
				trevordevore
- VIP Livecode Opensource Backer 
- Posts: 1005
- Joined: Sat Apr 08, 2006 3:06 pm
- Contact:
Yes, it is 
The 10 line limit is for executing Revolution code. It doesn't apply when using "as" (i.e. AppleScript or VBScript).
			
			
									
									
The 10 line limit is for executing Revolution code. It doesn't apply when using "as" (i.e. AppleScript or VBScript).
Trevor DeVore
ScreenSteps - https://www.screensteps.com
LiveCode Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode
LiveCode Builder Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode-builder
						ScreenSteps - https://www.screensteps.com
LiveCode Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode
LiveCode Builder Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode-builder
I noted the repeated 
Is there a reason why the VBscript on RunRev does not support a "on error Goto ErrorLabel" at the beginning of the script ?
Is it something the eventually will get implemented ?
			
			
									
									
						Code: Select all
if err.number=0 then
  ....  
end ifIs it something the eventually will get implemented ?
- 
				trevordevore
- VIP Livecode Opensource Backer 
- Posts: 1005
- Joined: Sat Apr 08, 2006 3:06 pm
- Contact:
While Visual Basic does support "on error Goto ErrorLabel", VBScript does not so Revolution cannot implement it. There are no limitations in Revolution that are not inherent to other environments that interpret VBScript.
			
			
									
									Trevor DeVore
ScreenSteps - https://www.screensteps.com
LiveCode Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode
LiveCode Builder Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode-builder
						ScreenSteps - https://www.screensteps.com
LiveCode Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode
LiveCode Builder Repos - https://github.com/search?q=user%3Atrevordevore+topic:livecode-builder
Thanks for the prompt answer.
I suspected that it could have been something on the MS part...
To implement error cheking, using Vbscript and SQL, I have to put a "if err <>0 then" practically everywhere: after opening the jet connection, checking the password, after the sql statement, after the answer and so on, making the code rather confusing.
Thanks anyway
			
			
									
									
						I suspected that it could have been something on the MS part...
To implement error cheking, using Vbscript and SQL, I have to put a "if err <>0 then" practically everywhere: after opening the jet connection, checking the password, after the sql statement, after the answer and so on, making the code rather confusing.
Thanks anyway
Hello,
Does the solution described above actually work for anyone? I tried it with an admin account and a standard (guest) account and I always get true returned. It seems to me that you need to check whether you can actually write to the system32 directory, rather than whether it exists. Also, it seems to me that you can do the trick above simply with
which yields exactly the same result as the VBScript solution presented above. 
Any better solutions?
Best,
Mark
			
			
									
									Does the solution described above actually work for anyone? I tried it with an admin account and a standard (guest) account and I always get true returned. It seems to me that you need to check whether you can actually write to the system32 directory, rather than whether it exists. Also, it seems to me that you can do the trick above simply with
Code: Select all
if there is a folder specialFolderPath("system") then
  return "admin" -- bogus result!
else return "non amin" -- never happensAny better solutions?
Best,
Mark
The biggest LiveCode group on Facebook: https://www.facebook.com/groups/livecode.developers
The book "Programming LiveCode for the Real Beginner"! Get it here! http://tinyurl.com/book-livecode
						The book "Programming LiveCode for the Real Beginner"! Get it here! http://tinyurl.com/book-livecode
This original codehas always worked for me. I just tested with a Vista profile on my daughter's computer and got "Not Admin" returned (correctly). My profile returns "Admin" as expected. By the way, it's not testing for the existence of the System32 directory, but the Admin share of that directory. The admin share is hidden from a limited user by default.
			
			
									
									
						Code: Select all
Set Shell = CreateObject("WScript.Shell") 
Set filesys = CreateObject("Scripting.FileSystemObject") 
computername = Shell.ExpandEnvironmentStrings("%computername%") 
if filesys.FolderExists("\\" & computername & "\Admin$\System32") then 
wScript.echo ("Admin") 
else 
wScript.echo ("Not Admin") 
end if 
set filesys = nothing 
set Shell = nothing 
If it still doesn't work, then that same thread offers some alternative methods to try. This one, http://www.myitforum.com/forums/fb.asp?m=142596 testing for the right to delete a specific registry key (Current Control Set, so unlikely to have had the ACL adjusted) I've tested, and have had no issues. Of course, if the machine has had the registry ACLs opened up to allow something as stupid as a default user having rights to delete the Current Control Set key, then you will get false positives, but you'd probably have more pressing issues to worry about on behalf of your client, if so.
			
			
									
									
						Code: Select all
' Create constants for access rights and registry hive 
const KEY_QUERY_VALUE = &H0001 
const KEY_SET_VALUE = &H0002 
const KEY_CREATE = &H0032 
const KEY_CREATE_SUB_KEY = &H0004 
const KEY_DELETE = &H00010000 
const HKEY_LOCAL_MACHINE = &H80000002 
strComputer = "." 
Set objReg=GetObject("winmgmts:"_ 
   & "{impersonationLevel=impersonate}!\\" &_ 
   strComputer & "\root\default:StdRegProv") 
strKeyPath = "SYSTEM\CurrentControlSet" 
bHasAccessRight = False 
' Does the account under which the script runs have the 
'    right to query the SYSTEM\CurrentControlSet key 
objReg.CheckAccess HKEY_LOCAL_MACHINE, strKeyPath, _ 
   DELETE, bHasAccessRight 
If bHasAccessRight = True Then 
   Wscript.Echo "User is an Admin" 
Else 
   Wscript.Echo "User is not an Admin" 
End If - 
				alemrantareq
- Posts: 203
- Joined: Wed Jul 23, 2008 8:46 am
Hi everybody,
After creating this topic, I could not work with the first 7 replies. May be those can work with someone's pcs but I use Windows XP and those scripts failed to give me the accurate results. Then i did a simple trick to check administrative privilege of windows xp and that is, as far i know admin privilege can be simply checked by setting a registry value in HKEY_LOCAL_MACHINE and then giving a query on it; because without admin account, none can create registry value in HKEY_LOCAL_MACHINE using other accounts. So, i made a script which will set a value, then query it. If the account is not admin, then it shows a failure dialog message and quit; else if admin, it deletes that value after opening the application.
			
			
									
									
						After creating this topic, I could not work with the first 7 replies. May be those can work with someone's pcs but I use Windows XP and those scripts failed to give me the accurate results. Then i did a simple trick to check administrative privilege of windows xp and that is, as far i know admin privilege can be simply checked by setting a registry value in HKEY_LOCAL_MACHINE and then giving a query on it; because without admin account, none can create registry value in HKEY_LOCAL_MACHINE using other accounts. So, i made a script which will set a value, then query it. If the account is not admin, then it shows a failure dialog message and quit; else if admin, it deletes that value after opening the application.
