pub struct DMSCAppRuntime { /* private fields */ }Expand description
Public-facing application runtime.
The DMSCAppRuntime manages the application lifecycle, including module initialization,
startup, and shutdown. It also handles the execution of both synchronous and asynchronous modules.
§Usage
use dmsc::prelude::*;
#[tokio::main]
async fn main() -> DMSCResult<()> {
let app = DMSCAppBuilder::new()
.with_config("config.yaml")?
.build()?;
app.run(|ctx| async move {
ctx.logger().info("service", "DMSC service started")?;
Ok(())
}).await
}Implementations§
Source§impl DMSCAppRuntime
impl DMSCAppRuntime
Sourcepub fn new(ctx: DMSCServiceContext, modules: Vec<ModuleSlot>) -> Self
pub fn new(ctx: DMSCServiceContext, modules: Vec<ModuleSlot>) -> Self
Sourcepub async fn run<F, Fut>(self, f: F) -> DMSCResult<()>
pub async fn run<F, Fut>(self, f: F) -> DMSCResult<()>
Run the application lifecycle.
This method executes the complete application lifecycle, including:
- Emitting startup hooks
- Initializing synchronous modules
- Starting synchronous modules
- Initializing and starting asynchronous modules
- Running the application business logic via the provided closure
- Shutting down asynchronous modules
- Shutting down synchronous modules
- Emitting shutdown hooks
§Parameters
f: A closure that takes aDMSCServiceContextand returns aDMSCResult<()>. This closure contains the application’s business logic and is executed after all modules have been initialized and started, but before any modules are shut down.
§Returns
A DMSCResult indicating success or failure.
§Errors
Returns an error if:
- A critical module fails during execution
- The provided closure returns an error
Trait Implementations§
Source§impl Clone for DMSCAppRuntime
impl Clone for DMSCAppRuntime
Source§fn clone(&self) -> DMSCAppRuntime
fn clone(&self) -> DMSCAppRuntime
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<'py> IntoPyObject<'py> for DMSCAppRuntime
impl<'py> IntoPyObject<'py> for DMSCAppRuntime
Source§type Target = DMSCAppRuntime
type Target = DMSCAppRuntime
The Python output type
Source§type Output = Bound<'py, <DMSCAppRuntime as IntoPyObject<'py>>::Target>
type Output = Bound<'py, <DMSCAppRuntime as IntoPyObject<'py>>::Target>
The smart pointer type to use. Read more
Source§fn into_pyobject(
self,
py: Python<'py>,
) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
fn into_pyobject( self, py: Python<'py>, ) -> Result<<Self as IntoPyObject<'_>>::Output, <Self as IntoPyObject<'_>>::Error>
Performs the conversion.
Source§impl PyClass for DMSCAppRuntime
impl PyClass for DMSCAppRuntime
Source§impl PyClassImpl for DMSCAppRuntime
impl PyClassImpl for DMSCAppRuntime
Source§const IS_BASETYPE: bool = false
const IS_BASETYPE: bool = false
#[pyclass(subclass)]
Source§const IS_SUBCLASS: bool = false
const IS_SUBCLASS: bool = false
#[pyclass(extends=…)]
Source§const IS_MAPPING: bool = false
const IS_MAPPING: bool = false
#[pyclass(mapping)]
Source§const IS_SEQUENCE: bool = false
const IS_SEQUENCE: bool = false
#[pyclass(sequence)]
Source§const IS_IMMUTABLE_TYPE: bool = false
const IS_IMMUTABLE_TYPE: bool = false
#[pyclass(immutable_type)]
Source§const RAW_DOC: &'static CStr = c"Public-facing application runtime.\n\nThe `DMSCAppRuntime` manages the application lifecycle, including module initialization,\nstartup, and shutdown. It also handles the execution of both synchronous and asynchronous modules.\n\n## Usage\n\n```rust\nuse dmsc::prelude::*;\n\n#[tokio::main]\nasync fn main() -> DMSCResult<()> {\n let app = DMSCAppBuilder::new()\n .with_config(\"config.yaml\")?\n .build()?;\n \n app.run(|ctx| async move {\n ctx.logger().info(\"service\", \"DMSC service started\")?;\n Ok(())\n }).await\n}\n```\x00"
const RAW_DOC: &'static CStr = c"Public-facing application runtime.\n\nThe `DMSCAppRuntime` manages the application lifecycle, including module initialization,\nstartup, and shutdown. It also handles the execution of both synchronous and asynchronous modules.\n\n## Usage\n\n```rust\nuse dmsc::prelude::*;\n\n#[tokio::main]\nasync fn main() -> DMSCResult<()> {\n let app = DMSCAppBuilder::new()\n .with_config(\"config.yaml\")?\n .build()?;\n \n app.run(|ctx| async move {\n ctx.logger().info(\"service\", \"DMSC service started\")?;\n Ok(())\n }).await\n}\n```\x00"
Docstring for the class provided on the struct or enum. Read more
Source§const DOC: &'static CStr
const DOC: &'static CStr
Fully rendered class doc, including the
text_signature if a constructor is defined. Read moreSource§type ThreadChecker = SendablePyClass<DMSCAppRuntime>
type ThreadChecker = SendablePyClass<DMSCAppRuntime>
This handles following two situations: Read more
Source§type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
type PyClassMutability = <<PyAny as PyClassBaseType>::PyClassMutability as PyClassMutability>::MutableChild
Immutable or mutable
Source§type BaseNativeType = PyAny
type BaseNativeType = PyAny
The closest native ancestor. This is
PyAny by default, and when you declare
#[pyclass(extends=PyDict)], it’s PyDict.fn items_iter() -> PyClassItemsIter
fn lazy_type_object() -> &'static LazyTypeObject<Self>
fn dict_offset() -> Option<isize>
fn weaklist_offset() -> Option<isize>
Source§impl PyMethods<DMSCAppRuntime> for PyClassImplCollector<DMSCAppRuntime>
impl PyMethods<DMSCAppRuntime> for PyClassImplCollector<DMSCAppRuntime>
fn py_methods(self) -> &'static PyClassItems
Source§impl PyTypeInfo for DMSCAppRuntime
impl PyTypeInfo for DMSCAppRuntime
Source§fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
fn type_object_raw(py: Python<'_>) -> *mut PyTypeObject
Returns the PyTypeObject instance for this type.
§fn type_object(py: Python<'_>) -> Bound<'_, PyType>
fn type_object(py: Python<'_>) -> Bound<'_, PyType>
Returns the safe abstraction over the type object.
§fn is_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object is an instance of this type or a subclass of this type.§fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
fn is_exact_type_of(object: &Bound<'_, PyAny>) -> bool
Checks if
object is an instance of this type.impl DerefToPyAny for DMSCAppRuntime
impl ExtractPyClassWithClone for DMSCAppRuntime
Auto Trait Implementations§
impl Freeze for DMSCAppRuntime
impl !RefUnwindSafe for DMSCAppRuntime
impl Send for DMSCAppRuntime
impl Sync for DMSCAppRuntime
impl Unpin for DMSCAppRuntime
impl !UnwindSafe for DMSCAppRuntime
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
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§impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
impl<'py, T> IntoPyObjectExt<'py> for Twhere
T: IntoPyObject<'py>,
§fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
fn into_bound_py_any(self, py: Python<'py>) -> Result<Bound<'py, PyAny>, PyErr>
Converts
self into an owned Python object, dropping type information.§fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
fn into_py_any(self, py: Python<'py>) -> Result<Py<PyAny>, PyErr>
Converts
self into an owned Python object, dropping type information and unbinding it
from the 'py lifetime.§fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
fn into_pyobject_or_pyerr(self, py: Python<'py>) -> Result<Self::Output, PyErr>
Converts
self into a Python object. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::RequestSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> PyErrArguments for T
impl<T> PyErrArguments for T
§impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
impl<T> PyTypeCheck for Twhere
T: PyTypeInfo,
§const NAME: &'static str = T::NAME
const NAME: &'static str = T::NAME
👎Deprecated since 0.27.0: Use ::classinfo_object() instead and format the type name at runtime. Note that using built-in cast features is often better than manual PyTypeCheck usage.
Name of self. This is used in error messages, for example.
§fn type_check(object: &Bound<'_, PyAny>) -> bool
fn type_check(object: &Bound<'_, PyAny>) -> bool
§fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
fn classinfo_object(py: Python<'_>) -> Bound<'_, PyAny>
Returns the expected type as a possible argument for the
isinstance and issubclass function. Read more