Public/Export-Vaporshell.ps1
function Export-Vaporshell { <# .SYNOPSIS Exports the template object to JSON file. .DESCRIPTION Exports the template object to JSON file. Requires the Vaporshell input object to be type 'Vaporshell.Template' .PARAMETER VaporshellTemplate The input template object .PARAMETER Path Path to save the resulting JSON file. .PARAMETER Force Forces an overwrite if the Path already exists .EXAMPLE $Template = Initialize-Vaporshell -Description "This is a sample template that builds an S3 bucket" # Add items to the $Template object here $Template | Export-Vaporshell -Path "C:\CloudFormation\Templates\S3Bucket.json" -Force .EXAMPLE $Template = Initialize-Vaporshell -Description "This is a sample template that builds an S3 bucket" # Add items to the $Template object here Export-Vaporshell -VaporshellTemplate $Template -Path "C:\CloudFormation\Templates\S3Bucket.json" -Force .FUNCTIONALITY Vaporshell #> [cmdletbinding()] Param ( [parameter(Mandatory = $true,Position = 0,ValueFromPipeline = $true)] [ValidateScript({ if($_.Resources) { $true } else { throw "Unable to find any resources on this Vaporshell template. Resources are required in CloudFormation templates at the minimum." } })] [PSTypeName('Vaporshell.Template')] $VaporshellTemplate, [parameter(Mandatory = $false,Position = 1)] [System.String] $Path, [Switch] $Force ) Begin { $ForcePref = @{} if ($Force) { $ForcePref.add("Force",$True) } } Process { if ($Path) { ConvertTo-Json -Depth 50 -InputObject $VaporshellTemplate -Verbose:$false | Set-Content -Path $Path @ForcePref -Verbose:$false } else { ConvertTo-Json -Depth 50 -InputObject $VaporshellTemplate -Verbose:$false } } } |