dipper
An out-of-the-box modular dependency injection web application framework.

Install
Run the following Cargo command in your project directory:
cargo add dipper
Or add the following line to your Cargo.toml:
dipper = "0.1"
Example
#![allow(missing_docs)]
use dipper::mode::ENV_EDOP_MODE;
use dipper::prelude::*;
use std::env;
use std::sync::Arc;
#[tokio::main]
async fn main() {
env::set_var(ENV_EDOP_MODE, "test");
init_otel!();
new_app![Calculate].with_component_parameters::<Calculate>(CalculateParameters { state: 1 }).run().await;
}
pub trait Module: Interface {
fn add(&self, left: i64, right: i64) -> i64;
}
#[derive(Clone)]
#[dipper(Module)]
pub struct Calculate {
state: i64,
}
impl Interface for Calculate {
fn manifest(&self) -> Manifest {
Manifest::default().with_name("Calculate".to_owned()).with_summary("Calculate. For example, addition.".to_owned())
}
fn route(self: Arc<Self>, blank_router: Router) -> Router {
blank_router
.path("calculate")
.push(Router::with_path("add1").get(self.add1()))
.push(Router::with_path("add2").get(self.add2()))
.push(Router::with_path("add3").get(Self::add3()))
}
}
impl Module for Calculate {
fn add(&self, left: i64, right: i64) -> i64 {
({ self.state + left + right }).instrument(info_span!("add")).into_inner()
}
}
#[dipper]
impl Calculate {
#[dipper(handler)]
fn add1(&self, left: QueryParam<i64>, right: QueryParam<i64>) -> String {
self.add(*left, *right).to_string()
}
#[dipper(endpoint)]
pub(crate) fn add2(self: ::std::sync::Arc<Self>, left: QueryParam<i64>, right: QueryParam<i64>) -> String {
self.add(*left, *right).to_string()
}
#[dipper(endpoint(responses((status_code = 400, description = "Wrong request parameters."))))]
pub fn add3(left: QueryParam<i64>, right: QueryParam<i64>) -> String {
(*left + *right).to_string()
}
}
Browse http://localhost:8888/swagger-ui and open the OpenAPI online test.