次の方法で共有


レジストリ キーの追加

説明

この例では、リソースを Registry 使用してレジストリ キーが存在することを確認する方法を示します。

Ensure を設定しPresentValueName を空の文字列に設定し、キーを設定するとHKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment\MyNewKey、リソースはレジストリ キーが存在しない場合にレジストリ キーを追加MyNewKeyします。

Invoke-DscResource

このスクリプトは、コマンドレットでInvoke-DscResourceリソースをRegistry使用してレジストリ キーが存在することを確認する方法をMyNewKey示しています。

[CmdletBinding()]
param()

begin {
    $SharedParameters = @{
        Name       = 'Registry'
        ModuleName = 'PSDscResource'
        Properties = @{
            Key       = 'HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment\MyNewKey'
            Ensure    = 'Present'
            ValueName = ''
        }
    }

    $NonGetProperties = @(
        'Ensure'
    )
}

process {
    $TestResult = Invoke-DscResource -Method Test @SharedParameters

    if ($TestResult.InDesiredState) {
        $QueryParameters = $SharedParameters.Clone()

        foreach ($Property in $NonGetProperties) {
            $QueryParameters.Properties.Remove($Property)
        }

        Invoke-DscResource -Method Get @QueryParameters
    } else {
        Invoke-DscResource -Method Set @SharedParameters
    }
}

構成を使用する

このスニペットは、レジストリ キーが存在することを確認するために、リソース ブロックで a を定義ConfigurationRegistryする方法をMyNewKey示しています。

Configuration AddKey {
    Import-DscResource -ModuleName 'PSDscResources'

    Node localhost {
        Registry ExampleRegistry {
            Key       = 'HKLM:\SYSTEM\CurrentControlSet\Control\Session Manager\Environment\MyNewKey'
            Ensure    = 'Present'
            ValueName = ''
        }
    }
}