Files
libopenapi/datamodel/high/v3/link.go
Dave Shanley c17cc4a7e6 Adding more docs to high level models.
Cleaning things that are not used.
2022-09-16 14:03:05 -04:00

48 lines
1.3 KiB
Go

// Copyright 2022 Princess B33f Heavy Industries / Dave Shanley
// SPDX-License-Identifier: MIT
package v3
import (
"github.com/pb33f/libopenapi/datamodel/high"
low "github.com/pb33f/libopenapi/datamodel/low/v3"
)
// Link represents an OpenAPI 3+ Link object that is backed by a low-level one.
// - https://spec.openapis.org/oas/v3.1.0#link-object
type Link struct {
OperationRef string
OperationId string
Parameters map[string]string
RequestBody string
Description string
Server *Server
Extensions map[string]any
low *low.Link
}
// NewLink will create a new high-level Link instance from a low-level one.
func NewLink(link *low.Link) *Link {
l := new(Link)
l.low = link
l.OperationRef = link.OperationRef.Value
l.OperationId = link.OperationId.Value
params := make(map[string]string)
for k, v := range link.Parameters.Value {
params[k.Value] = v.Value
}
l.Parameters = params
l.RequestBody = link.RequestBody.Value
l.Description = link.Description.Value
if link.Server.Value != nil {
l.Server = NewServer(link.Server.Value)
}
l.Extensions = high.ExtractExtensions(link.Extensions)
return l
}
// GoLow will return the low-level Link instance used to create the high-level one.
func (l *Link) GoLow() *low.Link {
return l.low
}