Module/Common/Function.Xccdf.ps1
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# Copyright (c) Microsoft Corporation. All rights reserved. # Licensed under the MIT License. <# .SYNOPSIS Returns the benchmark element from the xccdf xml document. .PARAMETER Path The literal path to the the zip file that contain the xccdf or the specifc xccdf file. #> function Get-StigXccdfBenchmarkContent { [CmdletBinding()] [OutputType([xml])] param ( [Parameter(Mandatory = $true)] [string] $Path ) if (-not (Test-Path -Path $path)) { Throw "The file $path was not found" } if ($path -like "*.zip") { [xml] $xccdfXmlContent = Get-StigContentFromZip -Path $path } else { [xml] $xccdfXmlContent = Get-Content -Path $path -Encoding UTF8 } $xccdfXmlContent.Benchmark } <# .SYNOPSIS Extracts the xccdf file from the zip file provided from the DISA website. .PARAMETER Path The literal path to the zip file. #> function Get-StigContentFromZip { [CmdletBinding()] [OutputType([xml])] param ( [Parameter(Mandatory = $true)] [string] $Path ) # Create a unique path in the users temp directory to expand the files to. $zipDestinationPath = "$((Split-Path -Path $path -Leaf) -replace '.zip','').$((Get-Date).Ticks)" Expand-Archive -LiteralPath $path -DestinationPath $zipDestinationPath # Get the full path to the extracted xccdf file. $getChildItem = @{ Path = $zipDestinationPath Filter = "*Manual-xccdf.xml" Recurse = $true } $xccdfPath = (Get-ChildItem @getChildItem).fullName # Get the xccdf content before removing the content from disk. $xccdfContent = Get-Content -Path $xccdfPath # Cleanup to temp folder Remove-Item $zipDestinationPath -Recurse -Force $xccdfContent } |