Public/Utility/Assert-KritTcmBlueprint.ps1

<#
.SYNOPSIS
    Krit.TCM wrapper over Microsoft365DSC helper Assert-M365DSCBlueprint
    (category: Utility, module: M365DSCUtil).

.DESCRIPTION
    Auto-scaffolded wave .1514 by New-KritTcmFromM365DscHelpers.ps1.
    Thin delegating passthrough — logic stays in Microsoft365DSC upstream;
    Krit.TCM provides the friendly namespace + citation registration
    for HARD RULE 20 discipline.

    Install-Module Microsoft365DSC -Scope CurrentUser BEFORE calling.

.NOTES
    Wave .1514. Underlying cmdlet: Assert-M365DSCBlueprint
    Category: Utility
    Module: M365DSCUtil
    Params: 18
#>

function Assert-KritTcmBlueprint {
    [CmdletBinding()]
    param(
        [Parameter(Mandatory)] [String] $BluePrintUrl,
        [Parameter(Mandatory)] [String] $OutputReportPath,
        [PSCredential] $Credentials,
        [String] $ApplicationId,
        [String] $TenantId,
        [String] $CertificatePath,
        [PSCredential] $CertificatePassword,
        [String] $CertificateThumbprint,
        [String] $HeaderFilePath,
        [String] $Type,
        [String[]] $ExcludedProperties,
        [String[]] $ExcludedResources,
        [Boolean] $DriftOnly,
        [Boolean] $KeepExport,
        [SwitchParameter] $UseVariableSubstitution,
        [String] $SourceConfigurationDataPath,
        [String] $DestinationConfigurationDataPath,
        [String[]] $ExcludedSubstitutionProperties
    )

    if (-not (Get-Command -Name 'Assert-M365DSCBlueprint' -ErrorAction SilentlyContinue)) {
        throw '[KritTcm] Assert-M365DSCBlueprint not available — Install-Module Microsoft365DSC -Scope CurrentUser then re-run'
    }
    try {
        & 'Assert-M365DSCBlueprint' @PSBoundParameters
    } catch {
        Write-Error ('[KritTcm/Assert-KritTcmBlueprint] ' + 'Assert-M365DSCBlueprint' + ' failed: ' + $_.Exception.Message)
        throw
    }
}