我有一个函数GrantGenericRead
,当我在同一个运行中创建一个对象$ouUnixGroups
时,它会起作用。我正在试图弄清楚如何从AD中获取一个可以运行GrantGenericRead
的对象,但是当我尝试这种方式时,我知道如何(adsi,使用.Path查找),我可以' t访问对象的一些属性来设置它。我很想有人告诉我我做错了什么。
当代码全部同时运行时,此代码有效:
function CreateADGroup([string] $server, [string] $name, [string] $container, [string] $gtype)
{
$objClass = "group";
$strCn = GetCn -name $name -objClass $objClass;
$objDsGroup = CreateDsObject -server $server -container $container -name $name -objClass $objClass
[Void] $objDsGroup.Put("sAMAccountName", $name)
if ($gtype -eq "global")
{
# Global Distribution Group
[Void] $objDsGroup.Put("groupType", 0x80000002)
}
elseif ($gtype -eq "dlg")
{
# Domain Local Distribution Group
[Void] $objDsGroup.Put("groupType", 0x80000004)
}
elseif ($gtype -eq "uni")
{
# Universal Security Group
[Void] $objDsGroup.Put("groupType", 0x80000008)
}
else
{
Write-Host("Invalid group type {0}" -f $gtype)
}
[Void]$objDsGroup.SetInfo()
return $objDsGroup
}
function CreateDsObject([string] $server, [string] $container, [string] $name, [string] $objClass)
{
$strConatinerPath = GetLdapPath -server $server -dn $container
$objContainer = [adsi] $strConatinerPath
$strChildCn = GetCn -name $name -objClass $objClass
$strChildDn = "{0},{1}" -f $strChildCn, $container
$strChildPath = GetLdapPath -server $server -dn $strChildDn
$objChildEntry = $objContainer.Create($objClass, $strChildCn)
[Void]$objChildEntry.SetInfo()
return $objChildEntry
}
function GrantGenericRead($dsTrustee, $dsResources)
{
$strSid = GetSid -dsObj $dsTrustee
$objSid = New-Object Security.Principal.SecurityIdentifier($strSid)
$ace = New-Object DirectoryServices.ActiveDirectoryAccessRule($objSid, $AD_RIGHT::GenericRead, $AC_TYPE::Allow)
[Void] $dsResources.psbase.ObjectSecurity.AddAccessRule($ace)
[Void] $dsResources.psbase.CommitChanges()
}
function GetSid($dsObj)
{
$dn = $dsObj.distinguishedName.Value
$binary = $dsObj.psbase.Properties["objectSid"].Value
$sid = New-Object Security.Principal.SecurityIdentifier($binary, 0)
return $sid.ToString()
}
$adminContainerDn = "OU=Zone Administration,{0}" -f $adminContainer.Get("distinguishedName") #returns OU=Zone Administration,OU=asdfasdf,DC=baldur,DC=vm
$ouUnixGroups = CreateDsObject -server $server -container $ouDN -name $strOuUnixGroups -objClass "OrganizationalUnit"
$joinOps = CreateADGroup -server $server -name "Join Operators" -container $adminContainerDn -gtype "global"
GrantGenericRead -dsTrustee $joinOps -dsResources $ouUnixGroups
我想要完成的是能够从不创建它们的脚本中修改$joinOps
和$ouUnixGroups
。我如何访问它们?我可以得到sid,但这似乎没有帮助我,除非我错过了一些非常关键的东西。
GrantGenericRead -dsTrustee $joinOps -dsResources [adsi]$ouUnixGroups.Path
如果有人想看一下,我会在http://pastebin.com/uF3nrDuw上发布的安装程序脚本中删除其中的一些内容。 û
答案 0 :(得分:1)
你可以尝试:
GrantGenericRead -dsTrustee [adsi]"cn=Agroup,ou=AnOU,dc=dompn,dc=domp0" -dsResources [adsi]"ou=theUnixOU,ou=AnOtherOU,dc=dompn,dc=domp0"