Modules/SharePointDsc.WebAppPolicy/SPWebAppPolicy.psm1

function Assert-SPDscPolicyUser()
{
    Param (
        [Parameter(Mandatory=$false)]
        [Array]
        $CurrentDifferences,

        [Parameter(Mandatory=$true)]
        [String]
        $UsernameToCheck
    )

    foreach ($difference in $CurrentDifferences)
    {
        if ($difference.ContainsKey($UsernameToCheck))
        {
            return $true
        }
    }
    return $false
}

function Compare-SPDscWebAppPolicy()
{
    Param (
        [Parameter(Mandatory=$true)]
        [Array]
        $WAPolicies,

        [Parameter(Mandatory=$true)]
        [Array]
        $DSCSettings,

        [Parameter(Mandatory=$true)]
        [String]
        $DefaultIdentityType
    )
    Import-Module -Name (Join-Path -Path $PSScriptRoot `
                                   -ChildPath "..\SharePointDsc.Util\SharePointDsc.Util.psm1" `
                                   -Resolve)
    $diff = @()

    foreach ($policy in $WAPolicies)
    {
        $memberexists = $false
        foreach ($setting in $DSCSettings)
        {
            $identityType = $DefaultIdentityType
            if ((Test-SPDscObjectHasProperty -Object $setting `
                                             -PropertyName "IdentityType") -eq $true)
            {
                $identityType = $setting.IdentityType
            }
            if (($policy.Username -eq $setting.Username) -and `
                ($policy.IdentityType -eq $identityType))
            {

                $memberexists = $true

                $polbinddiff = Compare-Object -ReferenceObject $policy.PermissionLevel.ToLower() `
                                              -DifferenceObject $setting.PermissionLevel.ToLower()

                if ($null -ne $polbinddiff)
                {
                    Write-Verbose -Message ("Permission level different for " + `
                                            "$($policy.IdentityType) user '$($policy.Username)'")

                    if (-not (Assert-SPDscPolicyUser -CurrentDifferences $diff `
                                                     -UsernameToCheck $policy.Username.ToLower()))
                    {
                        $diff += @{
                            Username                  = $policy.Username.ToLower()
                            Status                    = "Different"
                            IdentityType              = $policy.IdentityType
                            DesiredPermissionLevel    = $setting.PermissionLevel
                            DesiredActAsSystemSetting = $setting.ActAsSystemAccount
                        }
                    }
                }

                if ($setting.ActAsSystemAccount)
                {
                    if ($policy.ActAsSystemAccount -ne $setting.ActAsSystemAccount)
                    {
                        Write-Verbose -Message ("System User different for " + `
                                               "$($policy.IdentityType) user '$($policy.Username)'")

                        if (-not (Assert-SPDscPolicyUser -CurrentDifferences $diff `
                                                         -UsernameToCheck $policy.Username.ToLower()))
                        {
                            $diff += @{
                                Username = $policy.Username.ToLower()
                                Status = "Different"
                                IdentityType = $policy.IdentityType
                                DesiredPermissionLevel = $setting.PermissionLevel
                                DesiredActAsSystemSetting = $setting.ActAsSystemAccount
                            }
                        }
                    }
                }
            }
        }

        if (-not $memberexists)
        {
            if (-not (Assert-SPDscPolicyUser -CurrentDifferences $diff `
                                             -UsernameToCheck $policy.Username.ToLower()))
            {
                $diff += @{
                    Username                  = $policy.Username.ToLower()
                    Status                    = "Additional"
                    IdentityType              = $policy.IdentityType
                    DesiredPermissionLevel    = $null
                    DesiredActAsSystemSetting = $null
                }
            }
        }
    }

    foreach ($setting in $DSCSettings)
    {
        $memberexists = $false
        $identityType = $DefaultIdentityType
        if ((Test-SPDscObjectHasProperty -Object $setting -PropertyName "IdentityType") -eq $true)
        {
            $identityType = $setting.IdentityType
        }
        foreach ($policy in $WAPolicies)
        {
            if (($policy.Username -eq $setting.Username) -and `
                ($policy.IdentityType -eq $identityType))
            {
                $memberexists = $true

                $polbinddiff = Compare-Object -ReferenceObject $policy.PermissionLevel.ToLower() `
                                              -DifferenceObject $setting.PermissionLevel.ToLower()
                if ($null -ne $polbinddiff)
                {
                    Write-Verbose -Message ("Permission level different for " + `
                                           "$($policy.IdentityType) user '$($policy.Username)'")

                    if (-not (Assert-SPDscPolicyUser -CurrentDifferences $diff `
                                                     -UsernameToCheck $policy.Username.ToLower()))
                    {
                        $diff += @{
                            Username                  = $setting.Username.ToLower()
                            Status                    = "Different"
                            IdentityType              = $identityType
                            DesiredPermissionLevel    = $setting.PermissionLevel
                            DesiredActAsSystemSetting = $setting.ActAsSystemAccount
                        }
                    }
                }

                if ($setting.ActAsSystemAccount)
                {
                    if ($policy.ActAsSystemAccount -ne $setting.ActAsSystemAccount)
                    {
                        Write-Verbose -Message ("System User different for " + `
                                               "$($policy.IdentityType) user '$($policy.Username)'")

                        if (-not (Assert-SPDscPolicyUser -CurrentDifferences $diff `
                                                         -UsernameToCheck $policy.Username.ToLower()))
                        {
                            $diff += @{
                                Username                  = $setting.Username.ToLower()
                                Status                    = "Different"
                                IdentityType              = $identityType
                                DesiredPermissionLevel    = $setting.PermissionLevel
                                DesiredActAsSystemSetting = $setting.ActAsSystemAccount
                            }
                        }
                    }
                }
            }
        }

        if (-not $memberexists)
        {
            if (-not (Assert-SPDscPolicyUser -CurrentDifferences $diff `
                                             -UsernameToCheck $setting.Username.ToLower()))
            {
                $diff += @{
                    Username                  = $setting.Username.ToLower()
                    Status                    = "Missing"
                    IdentityType              = $identityType
                    DesiredPermissionLevel    = $setting.PermissionLevel
                    DesiredActAsSystemSetting = $setting.ActAsSystemAccount
                }
            }
        }
    }
    return $diff
}