#web #ioc #di #dependency-injection #actix-web #actix

runtime_injector_actix

Runtime dependency injection container for actix-web

3 unstable releases

0.2.0 May 14, 2021
0.1.1 May 8, 2021
0.1.0 May 8, 2021

#45 in #ioc

MIT/Apache

160KB
2K SLoC

runtime_injector_actix

Current version Current documentation

This library provides types to help with injecting services into actix-web applications.

Getting started

Create your injector, then add it as app data to your application:

#[actix::main]
async fn main() -> std::io::Result<()> {
    // Define a module so the container knows what to inject
    let module = define_module! {
        #[cfg(not(test))]
        services = [
            UserAuthenticator::new.transient(),
        ],
        #[cfg(not(debug_assertions))]
        interfaces = {
            dyn UserDatabase = [SqlUserDatabase::new.singleton()],
        },
        #[cfg(debug_assertions)]
        interfaces = {
            dyn UserDatabase = [JsonUserDatabase::new.singleton()],
        },
    };

    // Configure and build the container
    let mut builder = Injector::builder();
    builder.add_module(module);
    let injector = builder.build();

    // Now add it as app data to the application
    HttpServer::new(|| App::new().app_data(injector.clone()).service(index))
        .bind(("127.0.0.1", 8080))?
        .run()
        .await
}

Inject dependencies with Injected<R> in your request handlers:

#[get("/")]
async fn index(
    user_db: Injected<Svc<dyn UserDatabase>>,
    user_auth: Injected<Box<UserAuthenticator>>,
) -> impl Responder {
    todo!()
}

Minimum supported Rust version

As the library is still in development, the only supported Rust version is the most recent version of stable Rust. The library may work on older versions, but there is no guarantee.

License

This library is licensed under your choice of either MIT or Apache 2.0.

Dependencies

~28MB
~589K SLoC