utoipa/openapi/
external_docs.rs1use serde::{Deserialize, Serialize};
5
6use super::extensions::Extensions;
7use super::{builder, set_value};
8
9builder! {
10 ExternalDocsBuilder;
11
12 #[non_exhaustive]
14 #[derive(Serialize, Deserialize, Default, Clone, PartialEq, Eq)]
15 #[cfg_attr(feature = "debug", derive(Debug))]
16 #[serde(rename_all = "camelCase")]
17 pub struct ExternalDocs {
18 pub url: String,
20 pub description: Option<String>,
22
23 #[serde(skip_serializing_if = "Option::is_none", flatten)]
25 pub extensions: Option<Extensions>,
26 }
27}
28
29impl ExternalDocs {
30 pub fn new<S: AsRef<str>>(url: S) -> Self {
41 Self {
42 url: url.as_ref().to_string(),
43 ..Default::default()
44 }
45 }
46}
47
48impl ExternalDocsBuilder {
49 pub fn url<I: Into<String>>(mut self, url: I) -> Self {
51 set_value!(self url url.into())
52 }
53
54 pub fn description<S: Into<String>>(mut self, description: Option<S>) -> Self {
56 set_value!(self description description.map(|description| description.into()))
57 }
58
59 pub fn extensions(mut self, extensions: Option<Extensions>) -> Self {
61 set_value!(self extensions extensions)
62 }
63}