summaryrefslogtreecommitdiff
path: root/windows
diff options
context:
space:
mode:
authorAndrea Scarpino <me@andreascarpino.it>2016-06-15 20:26:03 +0200
committerMatt Davis <nitzmahone@users.noreply.github.com>2016-06-15 11:26:03 -0700
commitac32a1b8081b7b30bca169a43936fb41e240f32e (patch)
treed9c99143ed6ed4d6bf61d6dc29bb673d451efd6b /windows
parent65fe9eb2b018993841620e506482dc699a892263 (diff)
downloadansible-modules-extras-ac32a1b8081b7b30bca169a43936fb41e240f32e.tar.gz
Fix win_environment: strict-mode fix for 'value' (#2404)
Diffstat (limited to 'windows')
-rw-r--r--windows/win_environment.ps135
1 files changed, 9 insertions, 26 deletions
diff --git a/windows/win_environment.ps1 b/windows/win_environment.ps1
index bece0812..f1acfe19 100644
--- a/windows/win_environment.ps1
+++ b/windows/win_environment.ps1
@@ -20,37 +20,18 @@
# POWERSHELL_COMMON
$params = Parse-Args $args;
-$state = Get-Attr $params "state" $null;
-$result = New-Object PSObject;
-Set-Attr $result "changed" $false;
+$state = Get-AnsibleParam -obj $params -name "state" -default "present" -validateSet "present","absent"
+$name = Get-AnsibleParam -obj $params -name "name" -failifempty $true
+$level = Get-AnsibleParam -obj $params -name "level" -validateSet "machine","process","user" -failifempty $true
+$value = Get-AnsibleParam -obj $params -name "value"
-If ($state) {
- $state = $state.ToString().ToLower()
- If (($state -ne 'present') -and ($state -ne 'absent') ) {
- Fail-Json $result "state is '$state'; must be 'present', or 'absent'"
- }
-} else {
- $state = 'present'
-}
-
-If ($params.name)
-{
- $name = $params.name
-} else {
- Fail-Json $result "missing required argument: name"
-}
-
-$value = $params.value
-
-If ($params.level) {
- $level = $params.level.ToString().ToLower()
- If (( $level -ne 'machine') -and ( $level -ne 'user' ) -and ( $level -ne 'process')) {
- Fail-Json $result "level is '$level'; must be 'machine', 'user', or 'process'"
- }
+If ($level) {
+ $level = $level.ToString().ToLower()
}
$before_value = [Environment]::GetEnvironmentVariable($name, $level)
+$state = $state.ToString().ToLower()
if ($state -eq "present" ) {
[Environment]::SetEnvironmentVariable($name, $value, $level)
} Elseif ($state -eq "absent") {
@@ -59,6 +40,8 @@ if ($state -eq "present" ) {
$after_value = [Environment]::GetEnvironmentVariable($name, $level)
+$result = New-Object PSObject;
+Set-Attr $result "changed" $false;
Set-Attr $result "name" $name;
Set-Attr $result "before_value" $before_value;
Set-Attr $result "value" $after_value;