From 62393f8760cd541435fdb18c2bf247eced2598dc Mon Sep 17 00:00:00 2001 From: Richard van der Hoff Date: Wed, 13 Mar 2024 17:33:30 +0000 Subject: [PATCH 1/2] Clean up URI resolution --- .../partials/openapi/resolve-ref-object.html | 25 +++++++++---------- 1 file changed, 12 insertions(+), 13 deletions(-) diff --git a/layouts/partials/openapi/resolve-ref-object.html b/layouts/partials/openapi/resolve-ref-object.html index 0041d688d..c65984715 100644 --- a/layouts/partials/openapi/resolve-ref-object.html +++ b/layouts/partials/openapi/resolve-ref-object.html @@ -28,19 +28,18 @@ {{ $ref_value := index $schema "$ref"}} {{ if $ref_value }} - {{ $ref_url := urls.Parse $ref_value }} - - {{ if ne $ref_url.Path "" }} - {{/* Reference to a different file: load it */}} - {{ $full_path := path.Join $path $ref_url.Path }} - {{ $without_ext := replaceRE "\\.[^\\.]*$" "" $full_path }} - {{ $pieces := split $without_ext "/" }} - {{ $ret = index site.Data $pieces }} - {{ else }} - {{ $ret = $root_schema }} - {{ end }} + {{/* Resolve the ref URI relative to the path of the schema file */}} + {{ $base_uri := urls.Parse $path }} + {{ $ref_uri := urls.Parse $ref_value }} + {{ $full_uri := $base_uri.ResolveReference $ref_uri }} + + {{/* strip the extension, and the leading `/`, from the path */}} + {{ $full_path := strings.TrimPrefix "/" (replaceRE "\\.[^\\.]*$" "" $full_uri.Path) }} + + {{ $pieces := split $full_path "/" }} + {{ $ret = index site.Data $pieces }} - {{ if ne $ref_url.Fragment "" }} + {{ if $ref_uri.Fragment }} {{/* Per https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#relative-references-in-uris: @@ -55,7 +54,7 @@ subsequent keys as indexes. */}} - {{ $keys := split (strings.TrimPrefix "/" $ref_url.Fragment ) "/" }} + {{ $keys := split (strings.TrimPrefix "/" $ref_uri.Fragment ) "/" }} {{ $ret = index $ret $keys }} {{ end }} From 63638fbbc58d6e5ab51c8b27d6e139f54aa4de44 Mon Sep 17 00:00:00 2001 From: Richard van der Hoff Date: Wed, 13 Mar 2024 17:36:50 +0000 Subject: [PATCH 2/2] Remove redundant $root_schema --- layouts/partials/openapi/render-api.html | 2 +- layouts/partials/openapi/render-operation.html | 4 +--- layouts/partials/openapi/render-parameters.html | 8 +------- layouts/partials/openapi/render-request.html | 6 ------ layouts/partials/openapi/resolve-ref-object.html | 4 ---- 5 files changed, 3 insertions(+), 21 deletions(-) diff --git a/layouts/partials/openapi/render-api.html b/layouts/partials/openapi/render-api.html index 541fe10d8..8af18e970 100644 --- a/layouts/partials/openapi/render-api.html +++ b/layouts/partials/openapi/render-api.html @@ -21,7 +21,7 @@ {{/* note that a `paths` entry can be a $ref */}} - {{ $params := dict "endpoint" $endpoint "path" $path "root_schema" $api_data }} + {{ $params := dict "endpoint" $endpoint "path" $path }} {{ with $path_data.get }} diff --git a/layouts/partials/openapi/render-operation.html b/layouts/partials/openapi/render-operation.html index 3d5a472d9..253e2efe8 100644 --- a/layouts/partials/openapi/render-operation.html +++ b/layouts/partials/openapi/render-operation.html @@ -6,7 +6,6 @@ * `endpoint`: the endpoint * `operation_data`: the OpenAPI data for the operation * `path`: the path where this definition was found, to enable us to resolve "$ref" - * `root_schema`: the root schema object where this definition was found, to enable us to resolve local "$ref" references This template renders the operation as a `
` containing: @@ -23,7 +22,6 @@ {{ $endpoint := .endpoint }} {{ $operation_data := .operation_data }} {{ $path := .path }} -{{ $root_schema := .root_schema }} {{ $anchor := anchorize $endpoint }}
@@ -82,7 +80,7 @@


-{{ partial "openapi/render-request" (dict "parameters" $operation_data.parameters "request_body" $operation_data.requestBody "path" $path "anchor_base" $anchor "root_schema" $root_schema ) }} +{{ partial "openapi/render-request" (dict "parameters" $operation_data.parameters "request_body" $operation_data.requestBody "path" $path "anchor_base" $anchor ) }}
{{ partial "openapi/render-responses" (dict "responses" $operation_data.responses "path" $path "anchor_base" $anchor ) }} diff --git a/layouts/partials/openapi/render-parameters.html b/layouts/partials/openapi/render-parameters.html index e874d86bd..c15479061 100644 --- a/layouts/partials/openapi/render-parameters.html +++ b/layouts/partials/openapi/render-parameters.html @@ -6,7 +6,6 @@ * `type`: the type of parameters to render: "header", "path", "query" * `caption`: caption to use for the table * `path`: the path where this definition was found, to enable us to resolve "$ref" - * `root_schema`: the root schema object where this definition was found, to enable us to resolve local "$ref" references This template renders a single table containing parameters of the given type. @@ -15,7 +14,6 @@ {{ $parameters := .parameters }} {{ $type := .type }} {{ $caption := .caption }} -{{ $root_schema := .root_schema }} {{ $path := .path }} {{/* build a dict mapping from name->parameter, which render-object-table expects */}} @@ -26,11 +24,7 @@ Per https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#operation-object: the parameters can be reference objects; resolve them now. */}} - {{ $parameter = partial "openapi/resolve-ref-object" (dict - "schema" $parameter - "root_schema" $root_schema - "path" $path - ) }} + {{ $parameter = partial "openapi/resolve-ref-object" (dict "schema" $parameter "path" $path) }} {{ if (eq $parameter.in $type) }} {{/* merge the schema at the same level as the rest of the other fields because that is diff --git a/layouts/partials/openapi/render-request.html b/layouts/partials/openapi/render-request.html index 24b09d5e4..96e19f693 100644 --- a/layouts/partials/openapi/render-request.html +++ b/layouts/partials/openapi/render-request.html @@ -5,7 +5,6 @@ * `parameters`: OpenAPI data specifying the parameters * `request_body`: OpenAPI data specifying the request body * `path`: the path where this definition was found, to enable us to resolve "$ref" - * `root_schema`: the root schema object where this definition was found, to enable us to resolve local "$ref" references * `anchor_base`: a prefix to add to the HTML anchors generated for each object This template renders: @@ -18,7 +17,6 @@ {{ $parameters := .parameters }} {{ $request_body := .request_body }} {{ $path := .path }} -{{ $root_schema := .root_schema }} {{ $anchor_base := .anchor_base }}

Request

@@ -33,22 +31,18 @@

Request parameters

"type" "header" "caption" "header parameters" "path" $path - "root_schema" $root_schema ) }} {{ partial "openapi/render-parameters" (dict "parameters" $parameters "type" "path" "caption" "path parameters" "path" $path - "root_schema" $root_schema ) }} {{ partial "openapi/render-parameters" (dict "parameters" $parameters "type" "query" "caption" "query parameters" - "root_schema" $root_schema "path" $path - "root_schema" $root_schema ) }} {{ end }} diff --git a/layouts/partials/openapi/resolve-ref-object.html b/layouts/partials/openapi/resolve-ref-object.html index c65984715..cd3e71d4f 100644 --- a/layouts/partials/openapi/resolve-ref-object.html +++ b/layouts/partials/openapi/resolve-ref-object.html @@ -13,16 +13,12 @@ * `path`: The path of the schema file containing the (potential) ref; used for resolving relative references. -* `root_schema`: The top-level schema which contains the potential ref; use for resolving `#/` - references. - Ref: https://github.com/OAI/OpenAPI-Specification/blob/main/versions/3.1.0.md#reference-object. */}} {{ $schema := .schema }} {{ $path := .path }} -{{ $root_schema := .root_schema }} {{ $ret := $schema }}