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
sourceimpl 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
sourceimpl<'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
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcefn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
sourcefn 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.
fn mapped<U, F, A>(self, f: F) -> SmallVec<A> where
F: FnMut(T) -> U,
A: Array<Item = U>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
fn vzip(self) -> V
sourceimpl<T> WithSubscriber for T
impl<T> WithSubscriber for T
sourcefn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> where
S: Into<Dispatch>,
Attaches the provided Subscriber
to this type, returning a
WithDispatch
wrapper. Read more
sourcefn with_current_subscriber(self) -> WithDispatch<Self>
fn with_current_subscriber(self) -> WithDispatch<Self>
Attaches the current default Subscriber
to this type, returning a
WithDispatch
wrapper. Read more