ObjectHandling/Export-ObjectsToFolder.ps1
<#
.synopsis Export objects from a container to a folder .description Export objects from a container to a folder based on filter credentials stored in the settings.json .parameter ContainerName Container to be used. Can be provided in the settings.json .parameter Folder Folder the objects should be exported to .parameter Credential SQL Credentials to export objects .example Export-ObjectsToFolder -ContainerName test -Folder C:\temp -Credential (Get-Credential) #> function Export-ObjectsToFolder { Param( [Parameter(Mandatory=$false)] [string] $ContainerName, [Parameter(Mandatory=$true)] [string] $Folder, [Parameter(Mandatory=$false)] [pscredential] $Credential ) if ($null -eq $ContainerName -or $ContainerName -eq "") { $ContainerName = (Get-EnvironmentKeyValue -KeyName 'name') } if ($null -eq $Credential) { $NewCredential = Get-CredentialFromEnvironmentJson if ($NewCredential -eq $false) { $Password = ("01000000d08c9ddf0115d1118c7a00c04fc297eb01000000f2d5880bd296784999333fc74a891a790000000002000000000003660000c000000010000000aab554bf75952d24752731bd3580c3100000000004800000a0000000100000002d614183cc102d517a1830bf036a81c51800000023f5b6d355199ef36b42f88dea120bc2a0218c02be82d4a614000000b56ce44dddc0077c795ed1e30d92802a5a761a93" | ConvertTo-SecureString) $Credential = [PSCredential]::new('admin', $Password) } else { $Credential = $NewCredential } } if (!(Test-Path $Folder -PathType Container)) { New-Item $Folder -ItemType Directory -Force } $containerFolder = ((Get-NavContainerSharedFolders $ContainerName).GetEnumerator() | Where-Object { $_.Value -eq "C:\Run\my"}).Name $objectsFilter = (Get-EnvironmentKeyValue -KeyName 'objectsFilter') if (($null -eq $objectsFilter) -or ($objectsFilter -eq '')) { return } $objectsName = ("{0}_{1}_{2}_BaseObjects.fob" -f (Get-AppKeyValue -KeyName 'publisher'), (Get-AppKeyValue -KeyName 'name'), (Get-AppKeyValue -KeyName 'version')) Export-NavContainerObjects -containerName $ContainerName -objectsFolder "$containerFolder" -filter "$objectsFilter" -sqlCredential $Credential -exportTo 'fob file' if (Test-Path (Join-Path $containerFolder "objects.fob") -PathType Leaf) { Copy-Item -Path (Join-Path $containerFolder "objects.fob") -Destination (Join-Path $Folder $objectsName) -Force Remove-Item (Join-Path $containerFolder "objects.fob") -Force } } Export-ModuleMember Export-ObjectsToFolder |