internal/New-AppInsightsTelemetry.ps1
<# .SYNOPSIS Get new telemetry entry. .EXAMPLE PS C:\>New-AppInsightsTelemetry 'AppEvents' Get new entry for AppEvent. .INPUTS System.String #> function New-AppInsightsTelemetry { [CmdletBinding()] [Alias('New-AITelemetry')] [OutputType([hashtable])] param ( # Telemetry Type Name [Parameter(Mandatory = $true)] [ValidateSet('AppDependencies', 'AppEvents', 'AppExceptions', 'AppRequests', 'AppTraces')] [string] $Name, # Instrumentation Key [Parameter(Mandatory = $false)] [string] $InstrumentationKey = $script:ModuleConfig.'ai.instrumentationKey' ) [hashtable] $mapNameToBaseType = @{ 'AppDependencies' = 'RemoteDependencyData' 'AppEvents' = 'EventData' 'AppExceptions' = 'ExceptionData' 'AppRequests' = 'RequestData' 'AppTraces' = 'MessageData' } ## Return Immediately when Telemetry is Disabled if ($script:ModuleConfig.'ai.disabled') { return } if ($script:AppInsightsRuntimeState.OperationStack.Count -gt 0) { $Operation = $script:AppInsightsRuntimeState.OperationStack.Peek() } else { $Operation = @{ Id = New-Guid Name = $MyInvocation.MyCommand.Name ParentId = $null } } $AppInsightsTelemetry = [ordered]@{ name = $Name time = $null iKey = $InstrumentationKey tags = [ordered]@{ "ai.application.ver" = [string]$MyInvocation.MyCommand.Module.Version "ai.operation.id" = [string]$Operation.Id "ai.operation.name" = [string]$Operation.Name "ai.operation.parentId" = [string]$Operation.ParentId "ai.session.id" = [string]$script:AppInsightsRuntimeState.SessionId "ai.user.id" = [string]$script:AppInsightsState.UserId } data = [ordered]@{ baseType = $mapNameToBaseType[$Name] baseData = [ordered]@{ ver = 2 properties = $null } } } ## Update Time if ($PSVersionTable.PSVersion -ge [version]'7.1') { $AppInsightsTelemetry['time'] = Get-Date -AsUTC -Format 'o' } else { $AppInsightsTelemetry['time'] = [datetime]::UtcNow.ToString('o') } ## Update OS if ($PSVersionTable.PSEdition -eq 'Core') { $AppInsightsTelemetry.tags['ai.device.osVersion'] = $PSVersionTable.OS } else { $AppInsightsTelemetry.tags['ai.device.osVersion'] = ('Microsoft Windows {0}' -f $PSVersionTable.BuildVersion) } ## Add Authenticated MSFT User if ((Get-ObjectPropertyValue $script:ConnectState.MsGraphToken 'Account' 'HomeAccountId' 'TenantId') -in ('72f988bf-86f1-41af-91ab-2d7cd011db47', 'cc7d0b33-84c6-4368-a879-2e47139b7b1f')) { $AppInsightsTelemetry.tags['ai.user.authUserId'] = $script:ConnectState.MsGraphToken.Account.HomeAccountId.Identifier } ## Add Default Custom Properties $AppInsightsTelemetry.data.baseData['properties'] = [ordered]@{ Culture = [System.Threading.Thread]::CurrentThread.CurrentCulture.Name PsEdition = $PSVersionTable.PSEdition.ToString() PsVersion = $PSVersionTable.PSVersion.ToString() DebugPreference = $DebugPreference } if ($script:ConnectState.MsGraphToken) { if ($script:ConnectState.MsGraphToken.TenantId) { $AppInsightsTelemetry.data.baseData['properties']['TenantId'] = $script:ConnectState.MsGraphToken.TenantId } else { $AppInsightsTelemetry.data.baseData['properties']['TenantId'] = Expand-JsonWebTokenPayload $script:ConnectState.MsGraphToken.AccessToken | Select-Object -ExpandProperty tid } $AppInsightsTelemetry.data.baseData['properties']['CloudEnvironment'] = $script:ConnectState.CloudEnvironment } return $AppInsightsTelemetry } |