pub struct Metadata<'a>(/* private fields */);
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)>
pub fn render<S, C>(&self, name: S, context: C) -> Option<(ContentType, String)>
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.
source§fn from_request<'life0, 'async_trait>(
request: &'r Request<'life0>
) -> Pin<Box<dyn Future<Output = Outcome<Metadata<'r>, (Status, ()), Status>> + Send + 'async_trait>>where
'r: 'async_trait,
'life0: 'async_trait,
Metadata<'r>: 'async_trait,
fn from_request<'life0, 'async_trait>(
request: &'r Request<'life0>
) -> Pin<Box<dyn Future<Output = Outcome<Metadata<'r>, (Status, ()), Status>> + Send + 'async_trait>>where
'r: 'async_trait,
'life0: 'async_trait,
Metadata<'r>: 'async_trait,
Self
from the incoming request metadata. Read moreAuto 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§
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> 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>,
self
into a collection.fn mapped<U, F, A>(self, f: F) -> SmallVec<A>where
F: FnMut(T) -> U,
A: Array<Item = U>,
§impl<T> Paint for Twhere
T: ?Sized,
impl<T> Paint for Twhere
T: ?Sized,
§fn fg(&self, value: Color) -> Painted<&T>
fn fg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self
with the foreground set to
value
.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like red()
and
green()
, which have the same functionality but are
pithier.
Example
Set foreground color to white using fg()
:
use yansi::{Paint, Color};
painted.fg(Color::White);
Set foreground color to white using white()
.
use yansi::Paint;
painted.white();
§fn bright_black(&self) -> Painted<&T>
fn bright_black(&self) -> Painted<&T>
§fn bright_red(&self) -> Painted<&T>
fn bright_red(&self) -> Painted<&T>
§fn bright_green(&self) -> Painted<&T>
fn bright_green(&self) -> Painted<&T>
§fn bright_yellow(&self) -> Painted<&T>
fn bright_yellow(&self) -> Painted<&T>
§fn bright_blue(&self) -> Painted<&T>
fn bright_blue(&self) -> Painted<&T>
§fn bright_magenta(&self) -> Painted<&T>
fn bright_magenta(&self) -> Painted<&T>
§fn bright_cyan(&self) -> Painted<&T>
fn bright_cyan(&self) -> Painted<&T>
§fn bright_white(&self) -> Painted<&T>
fn bright_white(&self) -> Painted<&T>
§fn bg(&self, value: Color) -> Painted<&T>
fn bg(&self, value: Color) -> Painted<&T>
Returns a styled value derived from self
with the background set to
value
.
This method should be used rarely. Instead, prefer to use color-specific
builder methods like on_red()
and
on_green()
, which have the same functionality but
are pithier.
Example
Set background color to red using fg()
:
use yansi::{Paint, Color};
painted.bg(Color::Red);
Set background color to red using on_red()
.
use yansi::Paint;
painted.on_red();
§fn on_primary(&self) -> Painted<&T>
fn on_primary(&self) -> Painted<&T>
§fn on_magenta(&self) -> Painted<&T>
fn on_magenta(&self) -> Painted<&T>
§fn on_bright_black(&self) -> Painted<&T>
fn on_bright_black(&self) -> Painted<&T>
§fn on_bright_red(&self) -> Painted<&T>
fn on_bright_red(&self) -> Painted<&T>
§fn on_bright_green(&self) -> Painted<&T>
fn on_bright_green(&self) -> Painted<&T>
§fn on_bright_yellow(&self) -> Painted<&T>
fn on_bright_yellow(&self) -> Painted<&T>
§fn on_bright_blue(&self) -> Painted<&T>
fn on_bright_blue(&self) -> Painted<&T>
§fn on_bright_magenta(&self) -> Painted<&T>
fn on_bright_magenta(&self) -> Painted<&T>
§fn on_bright_cyan(&self) -> Painted<&T>
fn on_bright_cyan(&self) -> Painted<&T>
§fn on_bright_white(&self) -> Painted<&T>
fn on_bright_white(&self) -> Painted<&T>
§fn attr(&self, value: Attribute) -> Painted<&T>
fn attr(&self, value: Attribute) -> Painted<&T>
Enables the styling [Attribute
] value
.
This method should be used rarely. Instead, prefer to use
attribute-specific builder methods like bold()
and
underline()
, which have the same functionality
but are pithier.
Example
Make text bold using attr()
:
use yansi::{Paint, Attribute};
painted.attr(Attribute::Bold);
Make text bold using using bold()
.
use yansi::Paint;
painted.bold();
§fn rapid_blink(&self) -> Painted<&T>
fn rapid_blink(&self) -> Painted<&T>
§fn quirk(&self, value: Quirk) -> Painted<&T>
fn quirk(&self, value: Quirk) -> Painted<&T>
Enables the yansi
[Quirk
] value
.
This method should be used rarely. Instead, prefer to use quirk-specific
builder methods like mask()
and
wrap()
, which have the same functionality but are
pithier.
Example
Enable wrapping using .quirk()
:
use yansi::{Paint, Quirk};
painted.quirk(Quirk::Wrap);
Enable wrapping using wrap()
.
use yansi::Paint;
painted.wrap();
§fn whenever(&self, value: Condition) -> Painted<&T>
fn whenever(&self, value: Condition) -> Painted<&T>
Conditionally enable styling based on whether the [Condition
] value
applies. Replaces any previous condition.
See the crate level docs for more details.
Example
Enable styling painted
only when both stdout
and stderr
are TTYs:
use yansi::{Paint, Condition};
painted.red().on_yellow().whenever(Condition::STDOUTERR_ARE_TTY);