Struct salvo_oapi::OpenApi
source · #[non_exhaustive]pub struct OpenApi {
pub openapi: OpenApiVersion,
pub info: Info,
pub servers: BTreeSet<Server>,
pub paths: Paths,
pub components: Components,
pub security: BTreeSet<SecurityRequirement>,
pub tags: BTreeSet<Tag>,
pub external_docs: Option<ExternalDocs>,
}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 OpenApi::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: OpenApiVersionOpenAPI document version.
info: InfoProvides metadata about the API.
See more details at https://spec.openapis.org/oas/latest.html#info-object.
servers: BTreeSet<Server>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: PathsAvailable paths and operations for the API.
See more details at https://spec.openapis.org/oas/latest.html#paths-object.
components: ComponentsHolds 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: BTreeSet<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.
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>Global additional documentation reference.
See more details at https://spec.openapis.org/oas/latest.html#external-documentation-object.
Implementations§
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>
pub fn to_yaml(&self) -> Result<String, Error>
Converts this OpenApi to YAML String. This method essentially calls serde_yaml::to_string method.
sourcepub fn merge(self, other: OpenApi) -> Self
pub fn merge(self, other: OpenApi) -> Self
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 exists item will be overwrite.
For servers, tags and security_requirements the whole item will be used for
comparison.
Note! info, openapi and external_docs will not be merged.
sourcepub fn servers<S: IntoIterator<Item = Server>>(self, servers: S) -> Self
pub fn servers<S: IntoIterator<Item = Server>>(self, servers: S) -> Self
Add iterator of Servers to configure target servers.
sourcepub fn paths<P: Into<Paths>>(self, paths: P) -> Self
pub fn paths<P: Into<Paths>>(self, paths: P) -> Self
Set paths to configure operations and endpoints of the API.
sourcepub fn add_path<P, I>(self, path: P, item: I) -> Selfwhere
P: Into<String>,
I: Into<PathItem>,
pub fn add_path<P, I>(self, path: P, item: I) -> Selfwhere P: Into<String>, I: Into<PathItem>,
Add PathItem to configure operations and endpoints of the API.
sourcepub fn components(self, components: impl Into<Components>) -> Self
pub fn components(self, components: impl Into<Components>) -> Self
Add Components to configure reusable schemas.
sourcepub fn security<S: IntoIterator<Item = SecurityRequirement>>(
self,
security: S
) -> Self
pub fn security<S: IntoIterator<Item = SecurityRequirement>>( self, security: S ) -> Self
Add iterator of SecurityRequirements that are globally available for all operations.
Add iterator of Tags to add additional documentation for operations tags.
sourcepub fn external_docs(self, external_docs: ExternalDocs) -> Self
pub fn external_docs(self, external_docs: ExternalDocs) -> Self
Add ExternalDocs for referring additional documentation.