1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
use std::collections::BTreeMap; use crate::{FromRef, Header, Link, MediaType, Spec, ObjectOrReference, RefPath}; /// Describes a single response from an API Operation, including design-time, static `links` /// to operations based on the response. /// /// See <https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.1.md#responseObject>. #[derive(Clone, Debug, Deserialize, Serialize, PartialEq, Default)] pub struct Response { /// A short description of the response. /// [CommonMark syntax](http://spec.commonmark.org/) MAY be used for rich text representation. pub description: Option<String>, /// Maps a header name to its definition. /// [RFC7230](https://tools.ietf.org/html/rfc7230#page-22) states header names are case /// insensitive. If a response header is defined with the name `"Content-Type"`, it SHALL /// be ignored. #[serde(default)] #[serde(skip_serializing_if = "BTreeMap::is_empty")] pub headers: BTreeMap<String, ObjectOrReference<Header>>, /// A map containing descriptions of potential response payloads. The key is a media type /// or [media type range](https://tools.ietf.org/html/rfc7231#appendix-D) and the value /// describes it. For responses that match multiple keys, only the most specific key is /// applicable. e.g. text/plain overrides text/* #[serde(default)] #[serde(skip_serializing_if = "BTreeMap::is_empty")] pub content: BTreeMap<String, MediaType>, /// A map of operations links that can be followed from the response. The key of the map /// is a short name for the link, following the naming constraints of the names for /// [Component Objects](https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.1.md#componentsObject). #[serde(default)] #[serde(skip_serializing_if = "BTreeMap::is_empty")] pub links: BTreeMap<String, ObjectOrReference<Link>>, // TODO: Add "Specification Extensions" https://github.com/OAI/OpenAPI-Specification/blob/master/versions/3.0.1.md#specificationExtensions} } impl FromRef for Response { fn from_ref(spec: &Spec, path: &str) -> Option<Self> where Self: Sized, { let path = RefPath::from_str(path); match path.kind.as_ref() { "responses" => spec .components .as_ref() .and_then(|cs| cs.responses.get(&path.name)) .and_then(|oor| oor.resolve(&spec)), _ => None, } } }