From 040ae98da73040ed41726de11a5ec5792afeb93a Mon Sep 17 00:00:00 2001 From: empty03 <57891206+empty03@users.noreply.github.com> Date: Mon, 18 Nov 2019 13:09:01 +0100 Subject: [PATCH] SwitchParameter -AsPlainText Added switch parameter '-AsPlainText' to replace chars which confluence would try to convert to macros. --- .../Public/ConvertTo-StorageFormat.ps1 | 24 ++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/ConfluencePS/Public/ConvertTo-StorageFormat.ps1 b/ConfluencePS/Public/ConvertTo-StorageFormat.ps1 index 7931ef3..21a1963 100644 --- a/ConfluencePS/Public/ConvertTo-StorageFormat.ps1 +++ b/ConfluencePS/Public/ConvertTo-StorageFormat.ps1 @@ -18,7 +18,8 @@ function ConvertTo-StorageFormat { Mandatory = $true, ValueFromPipeline = $true )] - [string[]]$Content + [string[]]$Content, + [System.Management.Automation.SwitchParameter]$AsPlainText ) BEGIN { @@ -29,6 +30,27 @@ function ConvertTo-StorageFormat { Write-Debug "[$($MyInvocation.MyCommand.Name)] ParameterSetName: $($PsCmdlet.ParameterSetName)" Write-Debug "[$($MyInvocation.MyCommand.Name)] PSBoundParameters: $($PSBoundParameters | Out-String)" + if ($AsPlainText) + { + Write-Verbose "[$($MyInvocation.MyCommand.Name)] Replace special chars with ascii code" + [System.Collections.Hashtable]$SpecialChars = @{ + '#' = '#' + '@' = '@' + '[' = '[' + ']' = ']' + '{' = '{' + '}' = 'Ӊ' + } + + foreach ($Key in $SpecialChars.Keys) + { + for ($i = 0; $i -lt $Content.Count; $i ++) + { + $Content[$i] = $Content[$i].Replace($Key, $SpecialChars.$Key) + } + } + } + $iwParameters = Copy-CommonParameter -InputObject $PSBoundParameters $iwParameters['Uri'] = "$ApiUri/contentbody/convert/storage" $iwParameters['Method'] = 'Post'