io.apicurio.datamodels.openapi.v3.models.Oas30Header Maven / Gradle / Ivy
/*
* Copyright 2019 Red Hat
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.apicurio.datamodels.openapi.v3.models;
import java.util.ArrayList;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import io.apicurio.datamodels.core.models.IReferenceNode;
import io.apicurio.datamodels.openapi.models.OasHeader;
/**
* Models an OpenAPI 3.0.x header.
* @author [email protected]
*/
public class Oas30Header extends OasHeader implements IReferenceNode {
public String $ref;
public Boolean required;
public Boolean deprecated;
public Boolean allowEmptyValue;
public String style;
public Boolean explode;
public Boolean allowReserved;
public Oas30Schema schema;
public Object example;
public Map examples = new LinkedHashMap<>();
public Map content = new LinkedHashMap<>();
/**
* Constructor.
*/
public Oas30Header(String name) {
super(name);
}
@Override
public String getReference() {
return $ref;
}
@Override
public void setReference(String reference) {
$ref = reference;
}
/**
* Creates a child items model.
*/
public Oas30Schema createSchema() {
Oas30Schema rval = new Oas30Schema();
rval._ownerDocument = this.ownerDocument();
rval._parent = this;
return rval;
}
/**
* Creates a child Example model.
*/
public Oas30Example createExample(String name) {
Oas30Example rval = new Oas30Example(name);
rval._ownerDocument = this.ownerDocument();
rval._parent = this;
return rval;
}
/**
* Adds the Example to the map of examples.
* @param example
*/
public void addExample(Oas30Example example) {
this.examples.put(example.getName(), example);
}
/**
* Removes an Example and returns it.
* @param name
*/
public Oas30Example removeExample(String name) {
return this.examples.remove(name);
}
/**
* Gets a single example by name.
* @param name
*/
public Oas30Example getExample(String name) {
return this.examples.get(name);
}
/**
* Gets all examples.
*/
public List getExamples() {
List rval = new ArrayList<>();
rval.addAll(this.examples.values());
return rval;
}
/**
* Creates a media type.
* @param name
*/
public Oas30MediaType createMediaType(String name) {
Oas30MediaType rval = new Oas30MediaType(name);
rval._ownerDocument = this.ownerDocument();
rval._parent = this;
return rval;
}
/**
* Adds a media type.
* @param name
* @param mediaType
*/
public void addMediaType(String name, Oas30MediaType mediaType) {
this.content.put(name, mediaType);
}
/**
* Gets a single media type by name.
* @param name
*/
public Oas30MediaType getMediaType(String name) {
return this.content.get(name);
}
/**
* Removes a single media type and returns it. This may return null or undefined if none found.
* @param name
*/
public Oas30MediaType removeMediaType(String name) {
return this.content.remove(name);
}
/**
* Gets a list of all media types.
*/
public List getMediaTypes() {
List rval = new ArrayList<>();
rval.addAll(this.content.values());
return rval;
}
}