functions/ConvertFrom-MCASTimestamp.ps1
<#
.Synopsis Converts an MCAS timestamp (13-digit integer or 10-digit integer) to a native date/time value of type [datetime]. .DESCRIPTION ConvertFrom-MCASTimestamp returns a System.DateTime value representing the time (localized to the Powershell session's timezone) for a timestamp value from MCAS. .EXAMPLE PS C:\> ConvertFrom-MCASTimestamp 1520272590839 Monday, March 5, 2018 12:56:30 PM .EXAMPLE PS C:\> Get-MCASActivity -ResultSetSize 5 | ForEach-Object {ConvertFrom-MCASTimestamp $_.timestamp} Monday, March 5, 2018 12:56:30 PM Monday, March 5, 2018 12:50:28 PM Monday, March 5, 2018 12:49:34 PM Monday, March 5, 2018 12:45:36 PM Monday, March 5, 2018 12:45:23 PM .FUNCTIONALITY ConvertFrom-MCASTimestamp is intended to return the Powershell datetime of a timestamp value from MCAS. #> function ConvertFrom-MCASTimestamp { [CmdletBinding()] [OutputType([datetime])] param ( [Parameter(Mandatory=$true,ValueFromPipeline=$true,Position=0)] $Timestamp ) process { Write-Verbose $Timestamp.ToString().length if ($Timestamp.ToString().length -eq 13) { (([datetime]'1/1/1970').AddSeconds($Timestamp/1000)).ToLocalTime() } elseif ($Timestamp.ToString().length -eq 10) { (([datetime]'1/1/1970').AddSeconds($Timestamp)).ToLocalTime() } else { throw 'Unexpected value provided for -Timestamp parameter. A 13-digit or 10-digit timestamp was expected.' } } } |