Files
libopenapi/datamodel/high/v2/parameter.go
Dave Shanley 3d5ecf0efb Refactored version directory names
3.0 and 2.0 do not work, there are multiple versions and anything with a period in it sucks from my point of view, v2 and v3 feel much better from a DX perspective.
2022-09-16 08:33:39 -04:00

123 lines
3.1 KiB
Go

// Copyright 2022 Princess B33f Heavy Industries / Dave Shanley
// SPDX-License-Identifier: MIT
package v2
import (
"github.com/pb33f/libopenapi/datamodel/high"
"github.com/pb33f/libopenapi/datamodel/high/base"
low "github.com/pb33f/libopenapi/datamodel/low/v2"
)
type Parameter struct {
Name string
In string
Type string
Format string
Description string
Required bool
AllowEmptyValue bool
Schema *base.SchemaProxy
Items *Items
CollectionFormat string
Default any
Maximum int
ExclusiveMaximum bool
Minimum int
ExclusiveMinimum bool
MaxLength int
MinLength int
Pattern string
MaxItems int
MinItems int
UniqueItems bool
Enum []string
MultipleOf int
Extensions map[string]any
low *low.Parameter
}
func NewParameter(parameter *low.Parameter) *Parameter {
p := new(Parameter)
p.low = parameter
p.Extensions = high.ExtractExtensions(parameter.Extensions)
if !parameter.Name.IsEmpty() {
p.Name = parameter.Name.Value
}
if !parameter.In.IsEmpty() {
p.In = parameter.In.Value
}
if !parameter.Type.IsEmpty() {
p.Type = parameter.Type.Value
}
if !parameter.Format.IsEmpty() {
p.Format = parameter.Format.Value
}
if !parameter.Description.IsEmpty() {
p.Description = parameter.Description.Value
}
if !parameter.Required.IsEmpty() {
p.Required = parameter.Required.Value
}
if !parameter.AllowEmptyValue.IsEmpty() {
p.AllowEmptyValue = parameter.AllowEmptyValue.Value
}
if !parameter.Schema.IsEmpty() {
p.Schema = base.NewSchemaProxy(&parameter.Schema)
}
if !parameter.Items.IsEmpty() {
p.Items = NewItems(parameter.Items.Value)
}
if !parameter.CollectionFormat.IsEmpty() {
p.CollectionFormat = parameter.CollectionFormat.Value
}
if !parameter.Default.IsEmpty() {
p.Default = parameter.Default.Value
}
if !parameter.Maximum.IsEmpty() {
p.Maximum = parameter.Maximum.Value
}
if !parameter.ExclusiveMaximum.IsEmpty() {
p.ExclusiveMaximum = parameter.ExclusiveMaximum.Value
}
if !parameter.Minimum.IsEmpty() {
p.Minimum = parameter.Minimum.Value
}
if !parameter.ExclusiveMinimum.IsEmpty() {
p.ExclusiveMinimum = parameter.ExclusiveMinimum.Value
}
if !parameter.MaxLength.IsEmpty() {
p.MaxLength = parameter.MaxLength.Value
}
if !parameter.MinLength.IsEmpty() {
p.MinLength = parameter.MinLength.Value
}
if !parameter.Pattern.IsEmpty() {
p.Pattern = parameter.Pattern.Value
}
if !parameter.MinItems.IsEmpty() {
p.MinItems = parameter.MinItems.Value
}
if !parameter.MaxItems.IsEmpty() {
p.MaxItems = parameter.MaxItems.Value
}
if !parameter.UniqueItems.IsEmpty() {
p.UniqueItems = parameter.UniqueItems.Value
}
if !parameter.Enum.IsEmpty() {
var enums []string
for e := range parameter.Enum.Value {
enums = append(enums, parameter.Enum.Value[e].Value)
}
p.Enum = enums
}
if !parameter.MultipleOf.IsEmpty() {
p.MultipleOf = parameter.MultipleOf.Value
}
return p
}
func (p *Parameter) GoLow() *low.Parameter {
return p.low
}