Powershell 解析 Swagger Json

Powershell Parse Swagger Json

下面的工作是将 Swagger json 解析为资源、方法、httptype 但可能... $path.Definition 部分很奇怪,我怎样才能得到 $path.Definition是一个数组而不是我需要解析数组符号的字符串。

$json = Get-Content -Path "$PSScriptRoot/Test/example_swagger.json" | ConvertFrom-Json
$paths = Get-Member -InputObject $json.paths -MemberType NoteProperty
$result = ""
foreach($path in $paths) {
    $elements = $path.Name.Substring(5).split("/") -join ","
    $httpmethods = $path.Definition.Substring($path.Definition.IndexOf("@{"))
    if ($httpmethods.Contains("get")) {
        $result += $elements + ", GET" + "`n"
    }
    if ($httpmethods.Contains("post")) {
        $result += $elements + ", POST" + "`n" #same methodnames different http methods
    }
}
$result

正如我对 的回答所详述,ConvertFrom-Json 的输出很难迭代。这使得 "for each key in object""keys of object not ahead of time" 种情况更难处理,但不是不可能。

你需要一个辅助函数:

# helper to turn PSCustomObject into a list of key/value pairs
function Get-ObjectMember {
    [CmdletBinding()]
    Param(
        [Parameter(Mandatory=$True, ValueFromPipeline=$True)]
        [PSCustomObject]$obj
    )
    $obj | Get-Member -MemberType NoteProperty | ForEach-Object {
        $key = $_.Name
        [PSCustomObject]@{Key = $key; Value = $obj."$key"}
    }
}

有了这个,方法就变得简单多了:

$swagger = Get-Content -Path "example_swagger.json" -Encoding UTF8 -Raw | ConvertFrom-Json

$swagger.paths | Get-ObjectMember | ForEach-Object {
    [pscustomobject]@{
        path = $_.Key
        methods = $_.Value | Get-ObjectMember | ForEach-Object Key
    }
}

作为示例应用到 https://editor.swagger.io/ 中的默认 Swagger 文件,这是打印出来的

path                     methods            
----                     -------            
/pet                     {post, put}        
/pet/findByStatus        get                
/pet/findByTags          get                
/pet/{petId}             {delete, get, post}
/pet/{petId}/uploadImage post               
/store/inventory         get                
/store/order             post               
/store/order/{orderId}   {delete, get}      
/user                    post               
/user/createWithArray    post               
/user/createWithList     post               
/user/login              get                
/user/logout             get                
/user/{username}         {delete, get, put}