A compile-time enforced authorization framework for Rust applications.
In typical applications, authorization checks are performed in seemingly random locations. This leads to implicit assumptions on what kinds of permissions or checks have been enforced at various parts of the codebase. For example:
```rust
fn handler(req: Request) -> Result
// makes no assumptions on a user's permissions or access, initially
fn privileged_fn(user: User) -> Result
// action otherprivilegedfn(user) }
// Implicitly depends on user having the "SimplePermissions" permission or role.
fn otherprivilegedfn(user: User) -> Result
// advanced action
Ok(()) } ```
DACquiri does things differently.
With DACquiri, you explicitly declare your authorization requirements in the function definition. DACquiri will, at compile-time, enforce all code-paths invoking your function will have checked the appropriate authorization requirements beforehand.
With DACquiri, you:
Missing an authorization check? That's a compile-time error.
Missing DACquiri? That's your error.