Skip to content

Fix serialization of PSCustomObject wrapped object#158

Merged
gabriel-samfira merged 2 commits intocloudbase:masterfrom
gabriel-samfira:fix-wrapped-objects
Dec 15, 2024
Merged

Fix serialization of PSCustomObject wrapped object#158
gabriel-samfira merged 2 commits intocloudbase:masterfrom
gabriel-samfira:fix-wrapped-objects

Conversation

@gabriel-samfira
Copy link
Copy Markdown
Member

With the switch away from converting PSCustomObjects to dictionaries we broke the way values that are wrapped in a PSCustomObject are serialized.

This is evident when values of hashtables are generated using Write-Output which generates a PSCustomObject (Which is not evident in powershell, as there is a lot of magic in powershell), but is clearly evident when we try to use an object generated in PowerShell, in C#.

This change looks at the nested type of a PSCustomObject, and unwraps it if it's not just another PSCustomObject.

Fixes: #157

With the switch away from converting PSCustomObjects to dictionaries
we broke the way values that are wrapped in a PSCustomObject are serialized.

This is evident when values of hashtables are generated using Write-Output
which generates a PSCustomObject (Which is not evident in powershell, as
there is a lot of magic in powershell), but is clearly evident when we try
to use an object generated in PowerShell, in C#.

This change looks at the nested type of a PSCustomObject, and unwraps it
if it's not just another PSCustomObject.

Fixes: cloudbase#157

Signed-off-by: Gabriel Adrian Samfira <gsamfira@cloudbasesolutions.com>
Add a new type converter for IDictionary types which unwraps PScustomObjects
before serializing.

Signed-off-by: Gabriel Adrian Samfira <gsamfira@cloudbasesolutions.com>
@gabriel-samfira gabriel-samfira merged commit 7467c5b into cloudbase:master Dec 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Atom values obtained from Write-Output are incorrectly encoded

1 participant