#[non_exhaustive]pub struct OpenApi {
pub openapi: OpenApiVersion,
pub info: Info,
pub servers: Option<Vec<Server>>,
pub paths: Paths,
pub components: Option<Components>,
pub security: Option<Vec<SecurityRequirement>>,
pub tags: Option<Vec<Tag>>,
pub external_docs: Option<ExternalDocs>,
pub schema: String,
pub extensions: Option<Extensions>,
}
Expand description
Root object of the OpenAPI document.
You can use OpenApi::new
function to construct a new OpenApi
instance and then
use the fields with mutable access to modify them. This is quite tedious if you are not simply
just changing one thing thus you can also use the OpenApiBuilder::new
to use builder to
construct a new OpenApi
object.
See more details at https://spec.openapis.org/oas/latest.html#openapi-object.
Fields (Non-exhaustive)§
This struct is marked as non-exhaustive
Struct { .. }
syntax; cannot be matched against without a wildcard ..
; and struct update syntax will not work.openapi: OpenApiVersion
OpenAPI document version.
info: Info
Provides metadata about the API.
See more details at https://spec.openapis.org/oas/latest.html#info-object.
servers: Option<Vec<Server>>
Optional list of servers that provides the connectivity information to target servers.
This is implicitly one server with url
set to /
.
See more details at https://spec.openapis.org/oas/latest.html#server-object.
paths: Paths
Available paths and operations for the API.
See more details at https://spec.openapis.org/oas/latest.html#paths-object.
components: Option<Components>
Holds various reusable schemas for the OpenAPI document.
Few of these elements are security schemas and object schemas.
See more details at https://spec.openapis.org/oas/latest.html#components-object.
security: Option<Vec<SecurityRequirement>>
Declaration of global security mechanisms that can be used across the API. The individual operations
can override the declarations. You can use SecurityRequirement::default()
if you wish to make security
optional by adding it to the list of securities.
See more details at https://spec.openapis.org/oas/latest.html#security-requirement-object.
Optional list of tags can be used to add additional documentation to matching tags of operations.
See more details at https://spec.openapis.org/oas/latest.html#tag-object.
external_docs: Option<ExternalDocs>
Optional global additional documentation reference.
See more details at https://spec.openapis.org/oas/latest.html#external-documentation-object.
schema: String
Schema keyword can be used to override default $schema
dialect which is by default
“https://spec.openapis.org/oas/3.1/dialect/base”.
All the references and individual files could use their own schema dialect.
extensions: Option<Extensions>
Optional extensions “x-something”.
Implementations§
Source§impl OpenApi
impl OpenApi
Sourcepub fn builder() -> OpenApiBuilder
pub fn builder() -> OpenApiBuilder
Construct a new OpenApiBuilder.
This is effectively same as calling OpenApiBuilder::new
Source§impl OpenApi
impl OpenApi
Sourcepub fn to_json(&self) -> Result<String, Error>
pub fn to_json(&self) -> Result<String, Error>
Converts this OpenApi
to JSON String. This method essentially calls serde_json::to_string
method.
Sourcepub fn to_pretty_json(&self) -> Result<String, Error>
pub fn to_pretty_json(&self) -> Result<String, Error>
Converts this OpenApi
to pretty JSON String. This method essentially calls serde_json::to_string_pretty
method.
Sourcepub fn to_yaml(&self) -> Result<String, Error>
Available on crate feature yaml
only.
pub fn to_yaml(&self) -> Result<String, Error>
yaml
only.Converts this OpenApi
to YAML String. This method essentially calls serde_yaml::to_string
method.
Sourcepub fn merge_from(self, other: OpenApi) -> OpenApi
pub fn merge_from(self, other: OpenApi) -> OpenApi
Merge other
OpenApi
moving self
and returning combined OpenApi
.
In functionality wise this is exactly same as calling OpenApi::merge
but but provides
leaner API for chaining method calls.
Sourcepub fn merge(&mut self, other: OpenApi)
pub fn merge(&mut self, other: OpenApi)
Merge other
OpenApi
consuming it and resuming it’s content.
Merge function will take all self
nonexistent servers
, paths
, schemas
, responses
,
security_schemes
, security_requirements
and tags
from other
OpenApi
.
This function performs a shallow comparison for paths
, schemas
, responses
and
security schemes
which means that only name
and path
is used for comparison. When
match occurs the whole item will be ignored from merged results. Only items not
found will be appended to self
.
For servers
, tags
and security_requirements
the whole item will be used for
comparison. Items not found from self
will be appended to self
.
Note! info
, openapi
, external_docs
and schema
will not be merged.
Sourcepub fn nest<P: Into<String>, O: Into<OpenApi>>(self, path: P, other: O) -> Self
pub fn nest<P: Into<String>, O: Into<OpenApi>>(self, path: P, other: O) -> Self
Nest other
OpenApi
to this OpenApi
.
Nesting performs custom OpenApi::merge
where other
OpenApi
paths are prepended with given
path
and then appended to paths
of this OpenApi
instance. Rest of the other
OpenApi
instance is merged to this OpenApi
with OpenApi::merge_from
method.
If multiple APIs are being nested with same path
only the last one will be retained.
Method accepts two arguments, first is the path to prepend .e.g. /user
. Second argument
is the OpenApi
to prepend paths for.
§Examples
Merge user_api
to api
nesting user_api
paths under /api/v1/user
let api = OpenApiBuilder::new()
.paths(
PathsBuilder::new().path(
"/api/v1/status",
PathItem::new(
HttpMethod::Get,
OperationBuilder::new()
.description(Some("Get status"))
.build(),
),
),
)
.build();
let user_api = OpenApiBuilder::new()
.paths(
PathsBuilder::new().path(
"/",
PathItem::new(HttpMethod::Post, OperationBuilder::new().build()),
)
)
.build();
let nested = api.nest("/api/v1/user", user_api);
Trait Implementations§
Source§impl<'de> Deserialize<'de> for OpenApi
impl<'de> Deserialize<'de> for OpenApi
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Source§impl From<OpenApi> for OpenApiBuilder
impl From<OpenApi> for OpenApiBuilder
Source§impl From<OpenApiBuilder> for OpenApi
impl From<OpenApiBuilder> for OpenApi
Source§fn from(value: OpenApiBuilder) -> Self
fn from(value: OpenApiBuilder) -> Self
impl StructuralPartialEq for OpenApi
Auto Trait Implementations§
impl Freeze for OpenApi
impl RefUnwindSafe for OpenApi
impl Send for OpenApi
impl Sync for OpenApi
impl Unpin for OpenApi
impl UnwindSafe for OpenApi
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)