Struct rocket_dyn_templates::Metadata
source · pub struct Metadata<'a>(_);
Expand description
Request guard for dynamically querying template metadata.
Usage
The Metadata
type implements Rocket’s FromRequest
trait, so it can be
used as a request guard in any request handler.
use rocket_dyn_templates::{Template, Metadata, context};
#[get("/")]
fn homepage(metadata: Metadata) -> Template {
// Conditionally render a template if it's available.
if metadata.contains_template("some-template") {
Template::render("some-template", &context)
} else {
Template::render("fallback", &context)
}
}
fn main() {
rocket::build()
.attach(Template::fairing())
// ...
}
Implementations§
source§impl Metadata<'_>
impl Metadata<'_>
sourcepub fn contains_template(&self, name: &str) -> bool
pub fn contains_template(&self, name: &str) -> bool
Returns true
if the template with the given name
is currently
loaded. Otherwise, returns false
.
Example
use rocket_dyn_templates::Metadata;
#[get("/")]
fn handler(metadata: Metadata) {
// Returns `true` if the template with name `"name"` was loaded.
let loaded = metadata.contains_template("name");
}
sourcepub fn reloading(&self) -> bool
pub fn reloading(&self) -> bool
Returns true
if template reloading is enabled.
Example
use rocket_dyn_templates::Metadata;
#[get("/")]
fn handler(metadata: Metadata) {
// Returns `true` if template reloading is enabled.
let reloading = metadata.reloading();
}
sourcepub fn render<S, C>(&self, name: S, context: C) -> Option<(ContentType, String)>where
S: Into<Cow<'static, str>>,
C: Serialize,
pub fn render<S, C>(&self, name: S, context: C) -> Option<(ContentType, String)>where S: Into<Cow<'static, str>>, C: Serialize,
Directly render the template named name
with the context context
into a String
. Also returns the template’s detected ContentType
. See
Template::render()
for more details on rendering.
Examples
use rocket::http::ContentType;
use rocket_dyn_templates::{Metadata, Template, context};
#[get("/")]
fn send_email(metadata: Metadata) -> Option<()> {
let (mime, string) = metadata.render("email", context! {
field: "Hello, world!"
})?;
send_email(mime, string).await?;
Some(())
}
#[get("/")]
fn raw_render(metadata: Metadata) -> Option<(ContentType, String)> {
metadata.render("index", context! { field: "Hello, world!" })
}
// Prefer the following, however, which is nearly identical but pithier:
#[get("/")]
fn render() -> Template {
Template::render("index", context! { field: "Hello, world!" })
}
Trait Implementations§
source§impl<'r> FromRequest<'r> for Metadata<'r>
impl<'r> FromRequest<'r> for Metadata<'r>
Retrieves the template metadata. If a template fairing hasn’t been attached,
an error is printed and an empty Err
with status InternalServerError
(500
) is returned.
Auto Trait Implementations§
impl<'a> !RefUnwindSafe for Metadata<'a>
impl<'a> Send for Metadata<'a>
impl<'a> Sync for Metadata<'a>
impl<'a> Unpin for Metadata<'a>
impl<'a> !UnwindSafe for Metadata<'a>
Blanket Implementations§
§impl<'a, T> AsTaggedExplicit<'a> for Twhere
T: 'a,
impl<'a, T> AsTaggedExplicit<'a> for Twhere T: 'a,
§impl<'a, T> AsTaggedImplicit<'a> for Twhere
T: 'a,
impl<'a, T> AsTaggedImplicit<'a> for Twhere T: 'a,
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> IntoCollection<T> for T
impl<T> IntoCollection<T> for T
§fn into_collection<A>(self) -> SmallVec<A>where
A: Array<Item = T>,
fn into_collection<A>(self) -> SmallVec<A>where A: Array<Item = T>,
Converts
self
into a collection.