Пример кода для установки элемента статического контекстного меню
В следующем примере кода используются два скрипта. Первый скрипт (Frommenu.vbs) — это команда, которая выполняется при выборе элемента меню. Второй скрипт (Addmenu.vbs) устанавливает элемент контекстного меню описателя отображения для выполнения скрипта Frommenu.vbs. В этом примере предполагается языковой стандарт 409 (английский язык США) и расширение контекстного меню объекта пользователя в оснастках администрирования Active Directory.
Выполнение примера кода
- Скопируйте код для frommenu.vbs ниже, откройте Блокнот, вставьте код в Блокнот, сохраните файл как C:\frommenu.vbs и закройте Блокнот.
- Скопируйте приведенный ниже код для Addmenu.vbs, откройте Блокнот, вставьте код в Блокнот, сохраните файл как C:\addmenu.vbs и закройте Блокнот.
- Запустите Addmenu.vbs.
- Запустите оснастку Пользователи и компьютеры Active Directory.
FROMMENU. VBS
'Frommenu.vbs is the script run when the menu item is chosen.
''''''''''''''''''''
' Parse the arguments
' First arg is ADsPath of the selected object. Second is Class.
''''''''''''''''''''
On Error Resume Next
Set oArgs = WScript.Arguments
sText = "This script was run from a display specifier context menu." & vbCrLf & "Selected Item:"
If oArgs.Count > 1 Then
sText = sText & vbCrLf & " ADsPath: " & oArgs.item(0)
sText = sText & vbCrLf & " Class: " & oArgs.item(1)
Else
sText = sText & vbCrLf & "Arg Count: " & oArgs.Count
End If
show_items sText
Err.Number = 0
sBind = oArgs.item(0)
Set dsobj= GetObject(sBind)
If (Err.Number <> 0) Then
BailOnFailure Err.Number, "on GetObject method"
End If
objname = dsobj.Get("name")
If (Err.Number <> 0) Then
BailOnFailure Err.Number, "on Get method"
End If
sText = "Use ADsPath from first argument to bind and get RDN (name) property."
sText = sText & vbCrLf & "Name: " & objname
show_items sText
''''''''''''''''''''
' Display subroutines
''''''''''''''''''''
Sub show_items(strText)
MsgBox strText, vbInformation, "Script from Context Menu"
End Sub
Sub BailOnFailure(ErrNum, ErrText) strText = "Error 0x" & Hex(ErrNum) & " " & ErrText
MsgBox strText, vbInformation, "ADSI Error"
WScript.Quit
End Sub
ADDMENU. VBS
' Addmenu.vbs adds the menu item to run Frommenu.vbs
' from user object's context menu in the admin snap-ins.
On Error Resume Next
Set root= GetObject("LDAP://rootDSE")
If (Err.Number <> 0) Then
BailOnFailure Err.Number, "on GetObject method"
End If
sConfig = root.Get("configurationNamingContext")
'hardcoded for user class.
sClass = "user"
'hardcoded for US English
sLocale = "409"
sPath = "LDAP://cn=" & sClass & "-Display,cn=" & sLocale & ",cn=DisplaySpecifiers," & sConfig
show_items "Display Specifier: " & sPath
Set obj= GetObject(sPath)
If (Err.Number <> 0) Then
BailOnFailure Err.Number, "on GetObject method"
End If
'TODO--check if this is already there.
'Add the value for the context menu
sValue = "5,Run My Test Script,c:\frommenu.vbs"
vValue = Array(sValue)
obj.PutEx 3, "adminContextMenu", vValue
If (Err.Number <> 0) Then
BailOnFailure Err.Number, "on IADs::PutEx method"
End If
' Commit the change.
obj.SetInfo
If (Err.Number <> 0) Then
BailOnFailure Err.Number, "on IADs::SetInfo method"
End If
show_items "Success! Added value to adminContextMenu property of user-Display: " & sValue
''''''''''''''''''''
' Display subroutines
''''''''''''''''''''
Sub show_items(strText)
MsgBox strText, vbInformation, "Add admin context menu"
End Sub
Sub BailOnFailure(ErrNum, ErrText) strText = "Error 0x" & Hex(ErrNum) & " " & ErrText
MsgBox strText, vbInformation, "ADSI Error"
WScript.Quit
End Sub