ProjectContext

Struct ProjectContext 

Source
pub struct ProjectContext<S: BootstrapPhase = Initialized> { /* private fields */ }
Expand description

Shared context and configs for all apps. Used in conjunction with the Project trait.

Implementations§

Source§

impl<S: BootstrapPhase<Config = Arc<ProjectConfig>>> ProjectContext<S>

Source

pub fn config(&self) -> &ProjectConfig

Returns the configuration for the project.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let config = request.context().config();
    // can also be accessed via:
    let config = request.project_config();

    let db_url = &config.database.url;

    // ...
}
Source§

impl<S: BootstrapPhase<Apps = Vec<Box<dyn App>>>> ProjectContext<S>

Source

pub fn apps(&self) -> &[Box<dyn App>]

Returns the apps for the project.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let apps = request.context().apps();

    // ...
}
Source§

impl<S: BootstrapPhase<Router = Arc<Router>>> ProjectContext<S>

Source

pub fn router(&self) -> &Arc<Router>

Returns the router for the project.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let router = request.context().config();
    // can also be accessed via:
    let router = request.router();

    let num_routes = router.routes().len();

    // ...
}
Source§

impl<S: BootstrapPhase<AuthBackend = Arc<dyn AuthBackend>>> ProjectContext<S>

Source

pub fn auth_backend(&self) -> &Arc<dyn AuthBackend>

Returns the authentication backend for the project.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let auth_backend = request.context().auth_backend();
    // ...
}
Source§

impl<S: BootstrapPhase<Email = Email>> ProjectContext<S>

Source

pub fn email(&self) -> &Email

Available on crate feature email only.

Returns the email service for the project.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let email = request.context().email();
    // ...
}
Source§

impl<S: BootstrapPhase<Cache = Cache>> ProjectContext<S>

Source

pub fn cache(&self) -> &Cache

Available on crate feature cache only.

Returns the cache for the project.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let cache = request.context().cache();
    // ...
}
Source§

impl<S: BootstrapPhase<Database = Option<Database>>> ProjectContext<S>

Source

pub fn try_database(&self) -> Option<&Database>

Available on crate feature db only.

Returns the database for the project, if it is enabled.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let database = request.context().try_database();
    if let Some(database) = database {
        // do something with the database
    } else {
        // database is not enabled
    }
}
Source

pub fn database(&self) -> &Database

Available on crate feature db only.

Returns the database for the project, if it is enabled.

§Panics

This method panics if the database is not enabled.

§Examples
use cot::request::{Request, RequestExt};
use cot::response::Response;

async fn index(request: Request) -> cot::Result<Response> {
    let database = request.context().database();
    // use the database
}

Trait Implementations§

Source§

impl<S: BootstrapPhase> Debug for ProjectContext<S>
where S::Config: Debug, S::Router: Debug, S::Database: Debug, S::Cache: Debug, S::Email: Debug,

Source§

fn fmt(&self, __derive_more_f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<S> Freeze for ProjectContext<S>

§

impl<S> RefUnwindSafe for ProjectContext<S>

§

impl<S> Send for ProjectContext<S>

§

impl<S> Sync for ProjectContext<S>

§

impl<S> Unpin for ProjectContext<S>

§

impl<S> UnwindSafe for ProjectContext<S>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> Chain<T> for T

Source§

fn len(&self) -> usize

The number of items that this chain link consists of.
Source§

fn append_to(self, v: &mut Vec<T>)

Append the elements in this link to the chain.
Source§

impl<T> Fake for T

Source§

fn fake<U>(&self) -> U
where Self: FakeBase<U>,

Source§

fn fake_with_rng<U, R>(&self, rng: &mut R) -> U
where R: Rng + ?Sized, Self: FakeBase<U>,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoApi for T

Source§

fn into_api<A>(self) -> UseApi<T, A>

into UseApi
Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> IntoField<Auto<T>> for T

Source§

fn into_field(self) -> Auto<T>

Available on crate feature db only.
Converts the type to the field type.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

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
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<A, B, T> HttpServerConnExec<A, B> for T
where B: Body,