In a basic application scenario this group or library collections are included together.
**app_env** is <u>used</u> even inside other libraries.
Updating packages or dependencies shoud be keep in sync among <u>Cargo.toml</u> declarations.
### How to use
1 - Clone or download this lib in a path, better outside of target development
2 - Get current version from <u>Cargo.toml</u>
3 - <u>For each member of</u> of **Defs Library** one line like the one below should be included in <u>target development Cargo.toml</u> (adjust version & path) and **use** whatever is need.
```toml
app_auth = { version = "0.1.0", path = "../lib/defs/app_auth" }
```
To include all libraries:
```toml
app_auth = { version = "0.1.0", path = "../lib/defs/app_auth" }
app_env = { version = "0.1.0", path = "../lib/defs/app_env" }
app_errors = { version = "0.1.0", path = "../lib/defs/app_errors" }
app_file = { version = "0.1.0", path = "../lib/defs/app_file" }
kloud = { version = "0.1.0", path = "../lib/defs/kloud" }
```
### Structure
Each directory contains a Library dedicated to applications common needs:
Inside of each directory README.md and TODO.md files has more details.
#### app_auth
An authorization library based in [Casbin](https://casbin.org/) [Rust library](https://github.com/casbin/casbin-rs)
<pre>
app_auth/
├── Cargo.toml
├── README.md
├── TODO.md
└── src
└── lib.rs
</pre>
#### app_env
Dedicated to load configuration, enviroment settings, profiles, collections, etc.