#!powershell # Copyright: (c) 2014, Chris Hoffman # GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt) #Requires -Module Ansible.ModuleUtils.Legacy $params = Parse-Args $args -supports_check_mode $true $check_mode = Get-AnsibleParam -obj $params -name "_ansible_check_mode" -type "bool" -default $false $name = Get-AnsibleParam -obj $params -name "name" -type "str" -failifempty $true $state = Get-AnsibleParam -obj $params -name "state" -type "str" -default "present" -validateset "present","absent" $description = Get-AnsibleParam -obj $params -name "description" -type "str" $result = @{ changed = $false } $adsi = [ADSI]"WinNT://$env:COMPUTERNAME" $group = $adsi.Children | Where-Object {$_.SchemaClassName -eq 'group' -and $_.Name -eq $name } try { If ($state -eq "present") { If (-not $group) { If (-not $check_mode) { $group = $adsi.Create("Group", $name) $group.SetInfo() } $result.changed = $true } If ($null -ne $description) { IF (-not $group.description -or $group.description -ne $description) { $group.description = $description If (-not $check_mode) { $group.SetInfo() } $result.changed = $true } } } ElseIf ($state -eq "absent" -and $group) { If (-not $check_mode) { $adsi.delete("Group", $group.Name.Value) } $result.changed = $true } } catch { Fail-Json $result $_.Exception.Message } Exit-Json $result