【问题标题】:Can I use the data from my Resource.Schema.Mof file in a powershell script?我可以在 powershell 脚本中使用 Resource.Schema.Mof 文件中的数据吗?
【发布时间】: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-MofFile function.
  • 好吧,那会增加一个构建步骤,我宁愿避免。 .Net 中似乎必须有一些函数来解析 .Mof 文件。我只是不知道它是否是公开的。

标签: powershell dry dsc


【解决方案1】:

您可以尝试使用 PowerShell v5 中引入的类来编写资源。它应该在很大程度上消除您正在谈论的问题 - 因为没有 schema.mof 可以使用

【讨论】:

    猜你喜欢
    • 2020-02-14
    • 2012-08-27
    • 1970-01-01
    • 1970-01-01
    • 2021-12-29
    • 2021-10-09
    • 2015-11-10
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多