Public/Groups/UserGroups/Set-JCUserGroupLDAP.ps1
Function Set-JCUserGroupLDAP { [CmdletBinding(DefaultParameterSetName = 'GroupName')] param ( [Parameter(Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'GroupName', Position = 0, HelpMessage = 'The name of the JumpCloud user group to modify')] [Alias('name')] [String]$GroupName, [Parameter(Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'GroupID', Position = 0, HelpMessage = 'The ID of the JumpCloud user group to modify')] [Alias('id', '_id')] [String]$GroupID, [Parameter(Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'GroupName')] [Parameter(Mandatory, ValueFromPipelineByPropertyName, ParameterSetName = 'GroupID', HelpMessage = 'A boolean $true/$false value to enable or disable LDAP for a group')] [Boolean]$LDAPEnabled ) begin { Write-Debug 'Verifying JCAPI Key' if ($JCAPIKEY.length -ne 40) { Connect-JConline } Write-Debug 'Populating API headers' $hdrs = @{ 'Content-Type' = 'application/json' 'Accept' = 'application/json' 'X-API-KEY' = $JCAPIKEY } if ($JCOrgID) { $hdrs.Add('x-org-id', "$($JCOrgID)") } Write-Debug 'Initilizing rawResults and results resultsArray' $resultsArray = @() if ($PSCmdlet.ParameterSetName -eq 'GroupName') { Write-Debug 'Populating GroupNameHash' $GroupNameHash = Get-DynamicHash -Object Group -GroupType User -returnProperties name } $LDAPServer = Get-JCObject -Type:('ldap_server') if ($LDAPServer.Count -gt 1) { Write-Error "More than 1 LDAP Server. Action aborted" Return } $LDAPServerID = $LDAPServer.id } process { if ($PSCmdlet.ParameterSetName -eq 'GroupName') { $GroupID = $GroupNameHash.GetEnumerator().Where({ $_.Value.name -contains ($GroupName) }).Name $POSTUrl = "$JCUrlBasePath/api/v2/usergroups/$GroupID/associations" switch ($LDAPEnabled) { $true { $PostBody = @{ op = 'add' id = "$LDAPServerID" type = 'ldap_server' attributes = $null } } $false { $PostBody = @{ op = 'remove' id = "$LDAPServerID" type = 'ldap_server' attributes = $null } } } $JsonPostBody = $PostBody | ConvertTo-Json try { $LDAPUpdate = Invoke-RestMethod -Method Post -Uri $POSTUrl -Body $JsonPostBody -Headers $hdrs -UserAgent:(Get-JCUserAgent) $Results = [PSCustomObject]@{ GroupName = $GroupName LDAPEnabled = $LDAPEnabled } } catch { $Results = [PSCustomObject]@{ GroupName = $GroupName LDAPEnabled = $_.ErrorDetails } } $resultsArray += $Results } #End if elseif ($PSCmdlet.ParameterSetName -eq 'GroupID') { $POSTUrl = "$JCUrlBasePath/api/v2/usergroups/$GroupID/associations" switch ($LDAPEnabled) { $true { $PostBody = @{ op = 'add' id = "$LDAPServerID" type = 'ldap_server' attributes = $null } } $false { $PostBody = @{ op = 'remove' id = "$LDAPServerID" type = 'ldap_server' attributes = $null } } } $JsonPostBody = $PostBody | ConvertTo-Json try { $LDAPUpdate = Invoke-RestMethod -Method Post -Uri $POSTUrl -Body $JsonPostBody -Headers $hdrs -UserAgent:(Get-JCUserAgent) $Results = [PSCustomObject]@{ GroupID = $GroupID LDAPEnabled = $LDAPEnabled } } catch { $Results = [PSCustomObject]@{ GroupID = $GroupID LDAPEnabled = $_.ErrorDetails } } $resultsArray += $Results }#End elseif } #Ened process end { Return $resultsArray } } |