Merge pull request #2783 from trondhindenes/win_feature_source
win_feature: source option
This commit is contained in:
commit
6dca72bc06
2 changed files with 43 additions and 7 deletions
|
@ -28,6 +28,7 @@ $result = New-Object PSObject -Property @{
|
|||
}
|
||||
|
||||
$name = Get-Attr $params "name" -failifempty $true
|
||||
|
||||
$name = $name -split ',' | % { $_.Trim() }
|
||||
|
||||
$state = Get-Attr $params "state" "present"
|
||||
|
@ -39,14 +40,46 @@ If (($state -ne 'present') -and ($state -ne 'absent')) {
|
|||
$restart = Get-Attr $params "restart" $false | ConvertTo-Bool
|
||||
$includesubfeatures = Get-Attr $params "include_sub_features" $false | ConvertTo-Bool
|
||||
$includemanagementtools = Get-Attr $params "include_management_tools" $false | ConvertTo-Bool
|
||||
$source = Get-Attr $params "source" $false
|
||||
|
||||
If ($state -eq "present") {
|
||||
if ($source)
|
||||
{
|
||||
if (!(test-path $source))
|
||||
{
|
||||
Fail-Json $result "Failed to find source path $source"
|
||||
}
|
||||
}
|
||||
|
||||
$InstallParams = @{
|
||||
"Name"=$name;
|
||||
"Restart"=$Restart;
|
||||
"IncludeAllSubFeature"=$includesubfeatures;
|
||||
"ErrorAction"="SilentlyContinue"
|
||||
}
|
||||
|
||||
if ($IncludeManagementTools -eq $true)
|
||||
{
|
||||
$InstallParams.add("IncludeManagementTools",$includemanagementtools)
|
||||
}
|
||||
|
||||
if ($source -ne $null)
|
||||
{
|
||||
$InstallParams.add("Source",$source)
|
||||
}
|
||||
|
||||
|
||||
|
||||
try {
|
||||
If (Get-Command "Install-WindowsFeature" -ErrorAction SilentlyContinue) {
|
||||
$featureresult = Install-WindowsFeature -Name $name -Restart:$restart -IncludeAllSubFeature:$includesubfeatures -IncludeManagementTools:$includemanagementtools -ErrorAction SilentlyContinue
|
||||
$featureresult = Install-WindowsFeature @InstallParams
|
||||
}
|
||||
ElseIf (Get-Command "Add-WindowsFeature" -ErrorAction SilentlyContinue) {
|
||||
$featureresult = Add-WindowsFeature -Name $name -Restart:$restart -IncludeAllSubFeature:$includesubfeatures -ErrorAction SilentlyContinue
|
||||
if ($IncludeManagementTools)
|
||||
{
|
||||
$Params.Remove("IncludeManagementTools")
|
||||
}
|
||||
$featureresult = Add-WindowsFeature @InstallParams
|
||||
}
|
||||
Else {
|
||||
Fail-Json $result "Not supported on this version of Windows"
|
||||
|
|
|
@ -34,7 +34,6 @@ options:
|
|||
- Names of roles or features to install as a single feature or a comma-separated list of features
|
||||
required: true
|
||||
default: null
|
||||
aliases: []
|
||||
state:
|
||||
description:
|
||||
- State of the features or roles on the system
|
||||
|
@ -43,7 +42,6 @@ options:
|
|||
- present
|
||||
- absent
|
||||
default: present
|
||||
aliases: []
|
||||
restart:
|
||||
description:
|
||||
- Restarts the computer automatically when installation is complete, if restarting is required by the roles or features installed.
|
||||
|
@ -51,7 +49,6 @@ options:
|
|||
- yes
|
||||
- no
|
||||
default: null
|
||||
aliases: []
|
||||
include_sub_features:
|
||||
description:
|
||||
- Adds all subfeatures of the specified feature
|
||||
|
@ -59,7 +56,6 @@ options:
|
|||
- yes
|
||||
- no
|
||||
default: null
|
||||
aliases: []
|
||||
include_management_tools:
|
||||
description:
|
||||
- Adds the corresponding management tools to the specified feature
|
||||
|
@ -67,7 +63,13 @@ options:
|
|||
- yes
|
||||
- no
|
||||
default: null
|
||||
aliases: []
|
||||
source:
|
||||
description:
|
||||
- Specify a source to install the feature from
|
||||
required: false
|
||||
choices:
|
||||
- {driveletter}:\sources\sxs
|
||||
- \\{IP}\Share\sources\sxs
|
||||
author:
|
||||
- "Paul Durivage (@angstwad)"
|
||||
- "Trond Hindenes (@trondhindenes)"
|
||||
|
@ -79,6 +81,7 @@ EXAMPLES = '''
|
|||
# PS C:\Users\Administrator> Import-Module ServerManager; Get-WindowsFeature
|
||||
$ ansible -i hosts -m win_feature -a "name=Web-Server" all
|
||||
$ ansible -i hosts -m win_feature -a "name=Web-Server,Web-Common-Http" all
|
||||
ansible -m "win_feature" -a "name=NET-Framework-Core source=C:/Temp/iso/sources/sxs" windows
|
||||
|
||||
|
||||
# Playbook example
|
||||
|
|
Loading…
Reference in a new issue