【发布时间】:2015-07-07 14:09:20
【问题描述】:
我正在编写用于管理 Windows DNS 配置项(BootMethod、EventLogLevel 等)的 DSC 资源。我的Get-TargetResource 函数需要遍历资源能够管理的所有配置项。目前,我在 Resource.psm1 文件中有一个哈希表来描述所有这些,但我希望能够使用 Resource.Schema.Mof 文件中已经存在的描述,这是在第一名。这是否可能,或者出于某种我不知道的原因可能是不明智的?
Schema.mof:
[ClassVersion("1.0.0"), FriendlyName("GO_DnsServerConfig")]
class GO_DnsServerConfig : OMI_BaseResource
{
[Key] string Name;
[Write,ValueMap{"Present","Absent"},Values{"Present","Absent"}]
string Ensure;
[Write] UInt32 AddressAnswerLimit;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 BindSecondaries;
[Write,ValueMap{"0","1","2","3"},Values{"0","1","2","3"}]
UInt32 BootMethod;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 DefaultAgingState;
[Write] UInt32 DefaultNoRefreshInterval;
[Write] UInt32 DefaultRefreshInterval;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 DisableAutoReverseZones;
[Write,ValueMap{"0","1"},Values{"0","1"}]
UInt32 DisableNsRecordsAutoCreation;
[Write] UInt32 DsPollingInterval;
[Write] UInt32 DsTombstoneInterval;
[Write] UInt32 EDnsCacheTimeout;
/* Does not appear to be fully implemented in dnscmd
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 EnableDnsProbes;
*/
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 EnableDnsSec;
[Write,ValueMap{"0","1"},Values{"0","1"}]
UInt32 EnableGlobalNamesSupport;
[Write,ValueMap{"0","1"},Values{"0","1"}]
UInt32 EnableGlobalQueryBlocklist;
[Write,ValueMap{"0","1","2","4"},Values{"0","1","2","4"}]
UInt32 EventLogLevel;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 ForwardDelegations;
[Write] UInt32 ForwardingTimeout;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 GlobalNamesQueryOrder;
/*
[Read,ValueMap{"isatap","wpad"},Values{"isatap","wpad"}]
String GlobalQueryBlocklist;
*/
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 IsSlave;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 LocalNetPriority;
[Write] UInt32 LogFileMaxSize;
[Write] string LogFilePath;
[Write] string LogIpFilterList;
[Write] uint32 LogLevel;
[Write] uint64 MaxCacheSize;
[Write]
uint32 MaxCacheTtl;
[Write,ValueMap{"0","1","2","3"},Values{"0","1","2","3"}]
uint16 NameCheckFlag;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 NoRecursion;
[Write] uint32 RecursionRetry;
[Write] uint32 RecursionTimeout;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 RoundRobin;
[Write] uint32 RpcProtocol;
[Write] uint32 ScavengingInterval;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 SecureResponses;
[Write] uint32 SendPort;
[Write] string ServerLevelPluginDll;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 StrictFileParsing;
[Write] UInt32 UpdateOptions;
[Write,ValueMap{"0","1"},Values{"0","1"}] UInt32 WriteAuthorityNs;
[Write] uint32 XfrConnectTimeout;
};
Get-TargetResource 函数:
function Get-TargetResource
{
[CmdletBinding()]
[OutputType([Hashtable])]
param
(
[Parameter(Mandatory = $true)]
[string]$Name
)
Set-StrictMode -Version 2.0
$ErrorActionPreference = 'Stop'
$ConfigItems =
@{
Name = $Name;
Ensure = $null;
AddressAnswerLimit = $null;
BindSecondaries = $null;
BootMethod = $null;
DefaultAgingState = $null;
DefaultNoRefreshInterval = $null;
DefaultRefreshInterval = $null;
DisableAutoReverseZones = $null;
DisableNsRecordsAutoCreation = $null;
DsPollingInterval = $null;
DsTombstoneInterval = $null;
EDnsCacheTimeout = $null;
#EnableDnsProbes = $null; #Disabled; see schema.
EnableDnsSec = $null;
EnableGlobalNamesSupport = $null;
EnableGlobalQueryBlocklist = $null;
EventLogLevel = $null;
ForwardDelegations = $null;
ForwardingTimeout = $null;
GlobalNamesQueryOrder = $null;
GlobalQueryBlocklist = $null;
IsSlave = $null;
LocalNetPriority = $null;
LogFileMaxSize = $null;
LogFilePath = $null;
LogIpFilterList = $null;
LogLevel = $null;
MaxCacheSize = $null;
MaxCacheTtl = $null;
NameCheckFlag = $null;
NoRecursion = $null;
RecursionRetry = $null;
RecursionTimeout = $null;
RoundRobin = $null;
RpcProtocol = $null;
ScavengingInterval = $null;
SecureResponses = $null;
SendPort = $null;
ServerLevelPluginDll = $null;
StrictFileParsing = $null;
UpdateOptions = $null;
WriteAuthorityNs = $null;
XfrConnectTimeout = $null;
}
Write-Verbose "Check to see if there is a DNS server present on the box."
$ConfigItems.Ensure = Get-EnsureValue
If ($ConfigItems.Ensure -eq 'Present')
{
Write-Verbose "A DNS Server was found on this machine."
$ConfigItems.Ensure = 'Present'
Write-Verbose "Create a new hashtable to store the result."
$result = @{}
Write-Verbose "Add manually enumerated values to the resultset."
$result.Add('Name', $ConfigItems.Name)
$result.Add('Ensure', $ConfigItems.Ensure)
Write-Verbose "Get the current value for any item that is null."
$ConfigItems.GetEnumerator() `
| Where-Object {$_.Value -eq $null} `
| ForEach-Object `
{
$itemName = $_.Name
Write-Verbose "Getting: '$itemName'"
$itemValue =
Get-DnsConfigurationItem -Item $itemName
Write-Debug "Value: '$itemValue'"
if ($itemValue -ne $null)
{
Write-Verbose "Adding item to resultset."
$result.Add($itemName, $itemValue)
}
}
}
Else
{
Write-Verbose "No DNS server was found on this machine."
Write-Verbose "Returning with Ensure = '$($ConfigItems.Ensure)'."
$result = @{ Name = $ConfigItems.Name; Ensure = $ConfigItems.Ensure }
}
return $result
}
【问题讨论】:
-
你能发布你的模块代码,或者它的sn-p,以及MOF的相关部分吗?
-
谢谢,但我在查找 Resource.Schema.Mof 中已经存在的描述时遇到了麻烦,而且我没有看到您希望在代码中的哪个位置重用该值。您能否指出您将在哪里重复描述,以及您希望在哪里定义一次?
-
Schema.mof 文件中的所有内容都在 $ConfigItems 哈希表中进行了第二次定义,以便我可以对其进行迭代并获取实际值。我希望能够读取 Schema.mof 数据来代替该哈希表。
-
哦,我想我明白你现在在说什么了。你有没有考虑做相反的事情?根据脚本生成 MOF 文件? Have a look at this
New-MofFilefunction. -
好吧,那会增加一个构建步骤,我宁愿避免。 .Net 中似乎必须有一些函数来解析 .Mof 文件。我只是不知道它是否是公开的。
标签: powershell dry dsc