Dependency Injection in Rust
This crate provides integration support between coi
and rocket
. It
exposes an inject
procedural attribute macro to generate the code for
retrieving your dependencies from a Container
registered with rocket
.
```rust,no_run
// What's needed for the example fn below use rocket::get; use rocket_contrib::json::Json; use std::sync::Arc;
// Add the inject
attribute to the function you want to inject
// What this crate provides
fn get(
id: u64,
// Add the inject
field attribute to each attribute you want
// injected
#[inject] service: Arc
// Just data models for the above fn use serde::Serialize;
struct DataDto { name: String, }
impl DataDto { fn from(data: Data) -> Self { Self { name: data.name } } }
// An example of what's usually needed to make effective use of this // crate is below use coi::Inject;
// This section shows coi being put to use // It's very important that the version of coi and the version // of coi-rocket used match since coi-rocket implements // some coi traits
// Here we're marking a trait as injectable
trait IService: Inject {
fn get(&self, id: u64) -> Result
// And here we're marking a type that's capable of providing the
// above trait struct ServiceImpl {
// Here we're injecting a dependency. // Normal impl for struct
impl ServiceImpl {
fn new(repo: Arc // Normal impl of trait for struct
impl IService for ServiceImpl {
fn get(&self, id: u64) -> Resultfromdb(id)
}
} // The data that will be passed between services
struct Data {
id: u64,
name: String,
} // Here's the trait from above
trait IRepo: Inject {
fn readfromdb(&self, id: u64) -> Result
// And it's setup below struct RepoImpl; impl IRepo for RepoImpl {
fn readfromdb(&self, id: u64) -> Result
fn main() {
use rocket::{routes, Rocket};
use coi::container; }
``` See the repo [
Licensed under either of Apache License, Version
2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in this crate by you, as defined in the Apache-2.0 license, shall
be dual licensed as above, without any additional terms or conditions.
[derive(Inject)]
[coi(provides dyn IService with ServiceImpl::new(repo))]
ServiceImpl
does
// not need to know how to get this value.
#[coi(inject)]
repo: Arc[derive(Inject)]
[coi(provides dyn IRepo with RepoImpl)]
// Construct your coi container with your keys and providers
// See the coi crate for more details
let container = container!{
repo => RepoImplProvider; scoped,
service => ServiceImplProvider; scoped
};
Rocket::ignite()
// Don't forget to manage the container so it can be used!
.manage(container)
.mount("/", routes![get])
.launch();
coi-rocket-sample
] for a more involved example.License
SPDX-License-Identifier: MIT OR Apache-2.0