Public/Graph/Update-KriticalUtcmMgBetaDeviceManagementRoleDefinition.ps1

<#
.SYNOPSIS
    Kritical.UTCM wrapper over Microsoft365DSC helper Update-MgBetaDeviceManagementRoleDefinition
    (category: Graph, module: M365DSCGraphShim).

.DESCRIPTION
    Thin delegating passthrough — logic stays in Microsoft365DSC upstream;
    Kritical.UTCM provides the friendly namespace + citation registration.

    Install-Module Microsoft365DSC -Scope CurrentUser BEFORE calling.

.NOTES
    Category: Graph
    Module: M365DSCGraphShim
    Params: 21
#>

function Update-KriticalUtcmMgBetaDeviceManagementRoleDefinition {
    [CmdletBinding()]
    param(
        [String] $RoleDefinitionId,
        [Object] $InputObject,
        [Object] $BodyParameter,
        [String] $ResponseHeadersVariable,
        [Hashtable] $AdditionalProperties,
        [String] $Description,
        [String] $DisplayName,
        [String] $Id,
        [SwitchParameter] $IsBuiltIn,
        [SwitchParameter] $IsBuiltInRoleDefinition,
        [Object] $Permissions,
        [Object] $RoleAssignments,
        [Object] $RolePermissions,
        [String[]] $RoleScopeTagIds,
        [SwitchParameter] $Break,
        [IDictionary] $Headers,
        [Object[]] $HttpPipelineAppend,
        [Object[]] $HttpPipelinePrepend,
        [Uri] $Proxy,
        [PSCredential] $ProxyCredential,
        [SwitchParameter] $ProxyUseDefaultCredentials
    )

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