Skip to content

Commit

Permalink
fix approvers and reviewers + M365DSCDRGUtil:convertComplextoHashtable
Browse files Browse the repository at this point in the history
  • Loading branch information
William-Francillette committed Oct 25, 2023
1 parent a58b818 commit 017fefc
Show file tree
Hide file tree
Showing 2 changed files with 89 additions and 10 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ function Get-TargetResource
Write-Verbose -Message "Found access package assignment policy with id {$($getValue.Id)} and DisplayName {$DisplayName}"

#region Format AccessReviewSettings
$formattedAccessReviewSettings = Get-M365DSCDRGComplexTypeToHashtable -ComplexObject $getValue.AccessReviewSettings
$formattedAccessReviewSettings = Get-M365DSCDRGComplexTypeToHashtable -ComplexObject $getValue.AccessReviewSettings -Verbose
if($null -ne $formattedAccessReviewSettings)
{
$formattedAccessReviewSettings.remove('additionalProperties') | Out-Null
Expand All @@ -139,6 +139,7 @@ function Get-TargetResource
if (-not [String]::isNullOrEmpty($setting.AdditionalProperties.id))
{
$user = Get-MgUser -UserId $setting.AdditionalProperties.id -ErrorAction SilentlyContinue

if ($null -ne $user)
{
$setting.add('Id', $user.UserPrincipalName)
Expand All @@ -148,7 +149,7 @@ function Get-TargetResource
{
$setting.add('ManagerLevel', $setting.AdditionalProperties.managerLevel)
}
$setting.remove('additionalProperties') | Out-Null
$setting.remove('AdditionalProperties') | Out-Null
}
}
#endregion
Expand All @@ -170,7 +171,11 @@ function Get-TargetResource
$setting.add('odataType', $setting.AdditionalProperties.'@odata.type')
if (-not [String]::isNullOrEmpty($setting.AdditionalProperties.id))
{
$setting.add('Id', $setting.AdditionalProperties.id)
$user = Get-MgUser -UserId $setting.AdditionalProperties.id -ErrorAction SilentlyContinue
if ($null -ne $user)
{
$setting.add('Id', $user.UserPrincipalName)
}
}
if (-not [String]::isNullOrEmpty($setting.AdditionalProperties.managerLevel))
{
Expand All @@ -187,7 +192,11 @@ function Get-TargetResource
$setting.add('odataType', $setting.AdditionalProperties.'@odata.type')
if (-not [String]::isNullOrEmpty($setting.AdditionalProperties.id))
{
$setting.add('Id', $setting.AdditionalProperties.id)
$user = Get-MgUser -UserId $setting.AdditionalProperties.id -ErrorAction SilentlyContinue
if ($null -ne $user)
{
$setting.add('Id', $user.UserPrincipalName)
}
}
if (-not [String]::isNullOrEmpty($setting.AdditionalProperties.managerLevel))
{
Expand Down Expand Up @@ -462,6 +471,36 @@ function Set-TargetResource
}
}
}
if ( $null -ne $CreateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers)
{
for ($i = 0; $i -lt $CreateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers.Length; $i++)
{
$primaryApprover = $CreateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers[$i]
if ($null -ne $primaryApprover.id)
{
$user = Get-MgUser -Filter "startswith(UserPrincipalName, '$($primaryApprover.Id.Split('@')[0])')" -ErrorAction SilentlyContinue
if ($null -ne $user)
{
$CreateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers[$i].Id = $user.Id
}
}
}
}
if ( $null -ne $CreateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers)
{
for ($i = 0; $i -lt $CreateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers.Length; $i++)
{
$escalationApprover = $CreateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers[$i]
if ($null -ne $escalationApprover.id)
{
$user = Get-MgUser -Filter "startswith(UserPrincipalName, '$($escalationApprover.Id.Split('@')[0])')" -ErrorAction SilentlyContinue
if ($null -ne $user)
{
$CreateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers[$i].Id = $user.Id
}
}
}
}
if ($null -ne $CreateParameters.RequestorSettings -and $null -ne $CreateParameters.RequestorSettings.AllowedRequestors)
{
for ($i = 0; $i -lt $CreateParameters.RequestorSettings.AllowedRequestors.Length; $i++)
Expand Down Expand Up @@ -527,6 +566,36 @@ function Set-TargetResource
}
}
}
if ($null -ne $UpdateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers)
{
for ($i = 0; $i -lt $UpdateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers.Length; $i++)
{
$primaryApprover = $UpdateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers[$i]
if ($null -ne $primaryApprover.id)
{
$user = Get-MgUser -Filter "startswith(UserPrincipalName, '$($primaryApprover.Id.Split('@')[0])')" -ErrorAction SilentlyContinue
if ($null -ne $user)
{
$UpdateParameters.RequestApprovalSettings.ApprovalStages.PrimaryApprovers[$i].Id = $user.Id
}
}
}
}
if ($null -ne $UpdateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers)
{
for ($i = 0; $i -lt $UpdateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers.Length; $i++)
{
$escalationApprover = $UpdateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers[$i]
if ($null -ne $escalationApprover.id)
{
$user = Get-MgUser -Filter "startswith(UserPrincipalName, '$($escalationApprover.Id.Split('@')[0])')" -ErrorAction SilentlyContinue
if ($null -ne $user)
{
$UpdateParameters.RequestApprovalSettings.ApprovalStages.EscalationApprovers[$i].Id = $user.Id
}
}
}
}
if ($null -ne $UpdateParameters.RequestorSettings -and $null -ne $UpdateParameters.RequestorSettings.AllowedRequestors)
{
#Write-Verbose -Message "Updating Requestors' Id"
Expand Down Expand Up @@ -810,7 +879,17 @@ function Export-TargetResource

if ($null -ne $Results.AccessReviewSettings)
{
$complexTypeStringResult = Get-M365DSCDRGComplexTypeToString -ComplexObject $Results.AccessReviewSettings -CIMInstanceName MicrosoftGraphassignmentreviewsettings
$complexMapping = @(
@{
Name = 'Reviewers'
CimInstanceName = 'MicrosoftGraphuserset'
IsRequired = $false
}
)
$complexTypeStringResult = Get-M365DSCDRGComplexTypeToString `
-ComplexObject $Results.AccessReviewSettings `
-CIMInstanceName MicrosoftGraphassignmentreviewsettings `
-ComplexTypeMapping $complexMapping
if ($complexTypeStringResult)
{
$Results.AccessReviewSettings = $complexTypeStringResult
Expand Down Expand Up @@ -939,7 +1018,7 @@ function Export-TargetResource
if ($null -ne $Results.AccessReviewSettings)
{
$currentDSCBlock = Convert-DSCStringParamToVariable -DSCBlock $currentDSCBlock -ParameterName 'AccessReviewSettings'
$currentDSCBlock = Convert-DSCStringParamToVariable -DSCBlock $currentDSCBlock -ParameterName 'Reviewers'
#$currentDSCBlock = Convert-DSCStringParamToVariable -DSCBlock $currentDSCBlock -ParameterName 'Reviewers'
}
if ($null -ne $Results.Questions )
{
Expand Down
8 changes: 4 additions & 4 deletions Modules/Microsoft365DSC/Modules/M365DSCDRGUtil.psm1
Original file line number Diff line number Diff line change
Expand Up @@ -134,21 +134,21 @@ function Get-M365DSCDRGComplexTypeToHashtable
return , [hashtable[]]$results
}


if ($ComplexObject.getType().fullname -like '*Dictionary*')
{
$results = @{}

$ComplexObject = [hashtable]::new($ComplexObject)
$keys = $ComplexObject.Keys

foreach ($key in $keys)
{
if ($null -ne $ComplexObject.$key)
{
$keyName = $key

$keyType = $ComplexObject.$key.gettype().fullname

if ($keyType -like '*CimInstance*' -or $keyType -like '*Dictionary*' -or $keyType -like 'Microsoft.Graph.PowerShell.Models.*' -or $keyType -like '*[[\]]')
if ($keyType -like '*CimInstance*' -or $keyType -like '*Dictionary*' -or $keyType -like 'Microsoft.Graph.PowerShell.Models.*' -or $keyType -like 'Microsoft.Graph.Beta.PowerShell.Models.*' -or $keyType -like '*[[\]]')
{
$hash = Get-M365DSCDRGComplexTypeToHashtable -ComplexObject $ComplexObject.$key

Expand Down Expand Up @@ -185,7 +185,7 @@ function Get-M365DSCDRGComplexTypeToHashtable
if ($null -ne $ComplexObject.$keyName)
{
$keyType = $ComplexObject.$keyName.gettype().fullname
if ($keyType -like '*CimInstance*' -or $keyType -like '*Dictionary*' -or $keyType -like 'Microsoft.Graph.PowerShell.Models.*')
if ($keyType -like '*CimInstance*' -or $keyType -like '*Dictionary*' -or $keyType -like 'Microsoft.Graph.*PowerShell.Models.*')
{
$hash = Get-M365DSCDRGComplexTypeToHashtable -ComplexObject $ComplexObject.$keyName

Expand Down

0 comments on commit 017fefc

Please sign in to comment.