Src/Private/Export-Diagrammer.ps1
| function Export-Diagrammer { <# .SYNOPSIS Exports a diagram to a specified format. .DESCRIPTION The Export-Diagrammer function exports a diagram in PDF, PNG, SVG, or base64 formats using PSgraph. It supports adding watermarks to the output image (except for SVG and PDF formats) and allows for rotating the diagram output image. .PARAMETER GraphObj The Graphviz dot object to be exported. This parameter is mandatory. .PARAMETER ErrorDebug Enables error debugging. This parameter is optional. .PARAMETER Format The output format of the generated Graphviz diagram. Supported formats are PDF, PNG, SVG, and base64. This parameter is mandatory. .PARAMETER Filename The output filename of the generated Graphviz diagram. If not specified, the default filename is "Output" with the appropriate extension based on the format. .PARAMETER OutputFolderPath The path to the folder where the diagram output file will be saved. This parameter is optional but must be a valid path if provided. .PARAMETER IconPath The path to the icons directory, used for the SVG format. This parameter is optional but must be a valid path if provided. .PARAMETER WaterMarkText The text to be used as a watermark on the output image. This parameter is optional and not supported for SVG and PDF formats. .PARAMETER WaterMarkColor The color of the watermark text. The default color is 'Red'. This parameter is optional. .PARAMETER WaterMarkFontOpacity The font opacity of the watermark text. The default opacity is 30. This parameter is optional. .PARAMETER Rotate The degree to rotate the diagram output image. Valid rotation degrees are 0 and 90. This parameter is optional. .NOTES Version: 0.2.31 Author: Jonathan Colon Bluesky: @jcolonfpr.bsky.social GitHub: rebelinux .LINK https://github.com/rebelinux/Diagrammer.Core #> [CmdletBinding()] [OutputType([String])] param ( [Parameter( Position = 0, Mandatory = $true, HelpMessage = 'Please provide the graphviz dot object' )] [ValidateNotNullOrEmpty()] $GraphObj, [Parameter( Position = 1, Mandatory = $false, HelpMessage = 'Allow to enable error debugging' )] [bool]$ErrorDebug, [Parameter( Position = 2, Mandatory = $true, HelpMessage = 'Set the output format of the generated Graphviz diagram (Valid formats: pdf, png, svg, jpg, base64, dot)' )] [Array]$Format, [Parameter( Position = 3, Mandatory = $false, HelpMessage = 'Set the output filename of the generated Graphviz diagram (If not specified, the default filename is Output with the appropriate extension based on the format)' )] [string]$Filename, [Parameter( Position = 4, Mandatory = $false, HelpMessage = 'Please provide the path to the diagram output file' )] [ValidateScript({ if (-not ($_ | Test-Path) ) { throw "Folder does not exist" } return $true })] [System.IO.FileInfo] $OutputFolderPath = [system.io.path]::GetTempPath(), [Parameter( Position = 5, Mandatory = $false, HelpMessage = 'Please provide the path to the icons directory (Used for SVG format)' )] [ValidateScript({ if (-not ($_ | Test-Path) ) { throw "Folder does not exist" } return $true })] [System.IO.FileInfo] $IconPath, [Parameter( Position = 7, Mandatory = $false, HelpMessage = 'Allow to add a watermark to the output image (Not supported in svg format)' )] [string] $WaterMarkText, [Parameter( Position = 8, Mandatory = $false, HelpMessage = 'Allow to specified the color used for the watermark text' )] [string] $WaterMarkColor = 'Red', [Parameter( Position = 9, Mandatory = $false, HelpMessage = 'Allow to specified the color used for the watermark text' )] [int] $WaterMarkFontOpacity = 30, [Parameter( Position = 10, Mandatory = $false, HelpMessage = 'Allow to rotate the diagram output image. valid rotation degree (90, 180, 270)' )] [ValidateSet(0, 90, 180, 270)] [int] $Rotate = 0 ) process { # Setup all paths required for script to run $script:RootPath = Split-Path (Split-Path $PSScriptRoot -Parent) -Parent $GraphvizPath = switch ($PSVersionTable.Platform) { 'Unix' { & { if (Test-Path -Path '/usr/bin/dot') { '/usr/bin/dot' } elseif (Test-Path -Path '/bin/dot') { '/bin/dot' } elseif (Test-Path -Path '/usr/local/bin/dot') { '/usr/local/bin/dot' } elseif (Test-Path -Path '/opt/homebrew/bin/dot') { '/opt/homebrew/bin/dot' } else { throw "Graphviz 'dot' executable not found in standard Unix paths. Please install Graphviz." } } } default { Join-Path -Path $RootPath -ChildPath 'Tools\Graphviz\bin\dot.exe' } } # Set the path to the ImageMagick executable $script:ImageMagickPath = switch ($PSVersionTable.Platform) { 'Unix' { & { if (Test-Path -Path '/usr/bin/magick') { '/usr/bin/magick' } elseif (Test-Path -Path '/bin/magick') { '/bin/magick' } elseif (Test-Path -Path '/usr/local/bin/magick') { '/usr/local/bin/magick' } elseif (Test-Path -Path '/opt/homebrew/bin/magick') { '/opt/homebrew/bin/magick' } else { throw "ImageMagick 'magick' executable not found in standard Unix paths. Please install ImageMagick." } } } default { Join-Path $RootPath 'Tools\ImageMagick\magick.exe' } } # If Filename parameter is not specified, set filename to the Output.$OutputFormat if (-not $Filename) { if ($Format -ne "base64") { $Filename = "Output.$Format" } else { $Filename = "Output.png" } } try { $DestinationPath = Join-Path -Path $OutputFolderPath -ChildPath $FileName if ($Format -eq "svg") { if ($WaterMarkText) { Write-Verbose -Message "WaterMark option is not supported with the svg format." } ConvertTo-Svg -GraphObj $GraphObj -DestinationPath $DestinationPath -Angle $Rotate } elseif ($Format -eq "dot") { if ($WaterMarkText) { Write-Verbose -Message "WaterMark option is not supported with the dot format." } ConvertTo-Dot -GraphObj $GraphObj -DestinationPath $DestinationPath } elseif ($Format -eq "pdf" -and (-not $WaterMarkText)) { ConvertTo-Pdf -GraphObj $GraphObj -DestinationPath $DestinationPath } else { try { if ($Format -in @('base64', 'pdf')) { $tempFormat = "png" } else { $tempFormat = $Format } # Always convert to @(PNG or JPG) format before edit output image. $TempOutPut = Join-Path -Path ([system.io.path]::GetTempPath()) -ChildPath "$(Get-Random).$tempFormat" if ($tempFormat -in @('png', 'pdf')) { $Document = ConvertTo-Png -GraphObj $GraphObj -DestinationPath $TempOutPut } else { $Document = ConvertTo-Jpg -GraphObj $GraphObj -DestinationPath $TempOutPut } } catch { Write-Verbose -Message "Unable to convert Graphviz object to $tempFormat format. Path: $TempOutPut" Write-Debug -Message $($_.Exception.Message) } if ($WaterMarkText) { if ($Format -eq "pdf") { $Document = Add-WatermarkToImage -ImageInput $Document.FullName -WaterMarkText $WaterMarkText -FontColor $WaterMarkColor -FontOpacity $WaterMarkFontOpacity } else { Add-WatermarkToImage -ImageInput $TempOutPut -DestinationPath $DestinationPath -WaterMarkText $WaterMarkText -FontColor $WaterMarkColor -FontOpacity $WaterMarkFontOpacity } } # After adding watermark, convert it to PDF if required. GraphObj is not required for this step. # Needed because .NET does not support adding watermark to PDF files. Used ImageMagick to convert WaterMakerd PNG to PDF. if ($Format -eq "pdf") { $Null = ConvertTo-Pdf-WaterMark -ImageInput $Document.FullName -DestinationPath $DestinationPath } } if ($Format -eq "base64") { if (-not $WaterMarkText) { ConvertTo-Base64 -ImageInput $Document } else { ConvertTo-Base64 -ImageInput $DestinationPath } } elseif ($Format -in @('jpg', 'png', 'pdf')) { if ($WaterMarkText) { if ($Document) { Write-Verbose -Message "Deleting Temporary $Format file: $($Document.FullName)" try { Remove-Item -Path $Document } catch { Write-Verbose -Message "Unable to delete temporary file: $($Document.FullName)." Write-Debug -Message $($_.Exception.Message) } } Get-ChildItem -Path $DestinationPath } else { if ($Format -ne "pdf") { Copy-Item -Path $Document.FullName -Destination $DestinationPath if ($Document) { Write-Verbose -Message "Deleting Temporary $Format file: $($Document.FullName)" try { Remove-Item -Path $Document } catch { Write-Verbose -Message "Unable to delete temporary file: $($Document.FullName)." Write-Debug -Message $($_.Exception.Message) } } Get-ChildItem -Path $DestinationPath } } } } catch { if ($Document) { Remove-Item -Path $Document } $Err = $_ Write-Error -Message $Err } } end {} } |