2019-12-23 15:24:36 +03:00
|
|
|
|
# itconfig
|
2022-07-18 14:36:24 +03:00
|
|
|
|
|
2021-02-24 13:22:58 +03:00
|
|
|
|
[![Build Status](https://travis-ci.org/icetemple/itconfig-rs.svg?branch=main)](https://travis-ci.org/icetemple/itconfig-rs)
|
2020-11-12 10:45:06 +03:00
|
|
|
|
[![unsafe forbidden](https://img.shields.io/badge/unsafe-forbidden-success.svg)](https://github.com/rust-secure-code/safety-dance/)
|
2019-12-25 11:16:31 +03:00
|
|
|
|
[![Documentation](https://docs.rs/itconfig/badge.svg)](https://docs.rs/itconfig)
|
2021-02-25 12:58:01 +03:00
|
|
|
|
[![Crates.io](https://img.shields.io/crates/v/itconfig)](https://crates.io/crates/itconfig)
|
|
|
|
|
![Crates.io](https://img.shields.io/crates/l/itconfig)
|
2019-12-24 19:37:55 +03:00
|
|
|
|
|
2019-12-23 15:24:36 +03:00
|
|
|
|
Easy build a configs from environment variables and use it in globally.
|
|
|
|
|
|
|
|
|
|
We recommend you start with the [documentation].
|
|
|
|
|
|
2020-01-10 08:23:06 +03:00
|
|
|
|
## Motivation
|
|
|
|
|
|
2022-07-18 14:36:24 +03:00
|
|
|
|
I began to use rust with web programming experience where environment variables
|
|
|
|
|
are widely used and often there are more then 50 of them. First I looked at
|
|
|
|
|
already created libraries. But there it's necessary to initialise structure that
|
|
|
|
|
needs to be moved to each function where you need variable. It uses little bit
|
|
|
|
|
memory, but configuration lifetime is as long as application lifetime. Because
|
|
|
|
|
of it I decided to create my own library.
|
2020-01-10 08:23:06 +03:00
|
|
|
|
|
2020-03-12 23:20:34 +03:00
|
|
|
|
## Installation
|
|
|
|
|
|
2022-07-21 18:55:16 +03:00
|
|
|
|
The MSRV is 1.39.0
|
2020-03-12 23:20:34 +03:00
|
|
|
|
|
2022-07-18 14:36:24 +03:00
|
|
|
|
Add `itconfig = { version = "1.0", features = ["macro"] }` as a dependency in
|
|
|
|
|
`Cargo.toml`.
|
2020-03-12 23:20:34 +03:00
|
|
|
|
|
|
|
|
|
`Cargo.toml` example:
|
|
|
|
|
|
|
|
|
|
```toml
|
|
|
|
|
[package]
|
|
|
|
|
name = "my-crate"
|
|
|
|
|
version = "0.1.0"
|
|
|
|
|
authors = ["Me <user@rust-lang.org>"]
|
|
|
|
|
|
|
|
|
|
[dependencies]
|
|
|
|
|
itconfig = { version = "1.0", features = ["macro"] }
|
|
|
|
|
```
|
|
|
|
|
|
2021-04-16 10:35:42 +03:00
|
|
|
|
## Basic usage
|
2019-12-23 15:24:36 +03:00
|
|
|
|
|
|
|
|
|
```rust
|
2020-03-12 23:20:34 +03:00
|
|
|
|
use itconfig::config;
|
2019-12-26 08:26:27 +03:00
|
|
|
|
use std::env;
|
|
|
|
|
//use dotenv::dotenv;
|
2019-12-23 15:24:36 +03:00
|
|
|
|
|
|
|
|
|
config! {
|
2020-01-10 23:42:41 +03:00
|
|
|
|
DEBUG: bool => false,
|
2021-02-23 23:44:17 +03:00
|
|
|
|
|
2020-01-10 23:42:41 +03:00
|
|
|
|
#[env_name = "APP_HOST"]
|
2020-01-07 22:36:50 +03:00
|
|
|
|
HOST: String => "127.0.0.1",
|
2021-02-23 23:44:17 +03:00
|
|
|
|
|
2021-04-16 10:35:42 +03:00
|
|
|
|
database {
|
|
|
|
|
URL < (
|
|
|
|
|
"postgres://",
|
|
|
|
|
POSTGRES_USERNAME => "user",
|
|
|
|
|
":",
|
|
|
|
|
POSTGRES_PASSWORD => "pass",
|
|
|
|
|
"@",
|
|
|
|
|
POSTGRES_HOST => "localhost:5432",
|
|
|
|
|
"/",
|
|
|
|
|
POSTGRES_DB => "test",
|
|
|
|
|
),
|
|
|
|
|
|
|
|
|
|
pool {
|
|
|
|
|
MAX_SIZE: usize => 15,
|
|
|
|
|
},
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
sentry {
|
|
|
|
|
DSN: Option<&'static str>,
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
feature {
|
|
|
|
|
static CORS: bool => false,
|
|
|
|
|
|
|
|
|
|
static GRAPHQL_PLAYGROUND: bool => false,
|
|
|
|
|
},
|
2019-12-23 15:24:36 +03:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
fn main () {
|
2020-07-08 16:50:41 +03:00
|
|
|
|
// dotenv().expect("dotenv setup to be successful");
|
|
|
|
|
// or
|
2021-04-16 10:35:42 +03:00
|
|
|
|
env::set_var("FEATURE_CORS", "true");
|
2021-02-23 23:44:17 +03:00
|
|
|
|
|
2020-03-12 23:20:34 +03:00
|
|
|
|
config::init();
|
|
|
|
|
assert_eq!(config::HOST(), String::from("127.0.0.1"));
|
2021-04-16 10:35:42 +03:00
|
|
|
|
assert_eq!(config::database::URL(), String::from("postgres://user:pass@localhost:5432/test"));
|
|
|
|
|
assert_eq!(config::database::pool::MAX_SIZE(), 15);
|
|
|
|
|
assert_eq!(config::sentry::DSN(), None);
|
|
|
|
|
assert_eq!(config::feature::CORS(), true);
|
2019-12-23 15:24:36 +03:00
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2022-07-18 14:36:24 +03:00
|
|
|
|
Macro is an optional feature, disabled by default. You can use this library
|
|
|
|
|
without macro
|
2020-01-19 17:33:46 +03:00
|
|
|
|
|
|
|
|
|
```rust
|
|
|
|
|
use itconfig::*;
|
|
|
|
|
use std::env;
|
|
|
|
|
// use dotenv::dotenv;
|
|
|
|
|
|
|
|
|
|
fn main() {
|
2020-07-08 16:50:41 +03:00
|
|
|
|
// dotenv().expect("dotenv setup to be successful");
|
|
|
|
|
// or
|
2020-01-19 17:33:46 +03:00
|
|
|
|
env::set_var("DATABASE_URL", "postgres://127.0.0.1:5432/test");
|
|
|
|
|
|
|
|
|
|
let database_url = get_env::<String>("DATABASE_URL").unwrap();
|
|
|
|
|
let new_profile: bool = get_env_or_default("FEATURE_NEW_PROFILE", false);
|
|
|
|
|
let articles_per_page: u32 = get_env_or_set_default("ARTICLES_PER_PAGE", 10);
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2019-12-24 19:37:55 +03:00
|
|
|
|
## Running tests
|
|
|
|
|
|
|
|
|
|
```bash
|
2021-02-23 23:44:17 +03:00
|
|
|
|
cargo test --all-features
|
2019-12-24 19:37:55 +03:00
|
|
|
|
```
|
|
|
|
|
|
2020-01-21 11:12:12 +03:00
|
|
|
|
## Available features
|
|
|
|
|
|
2022-07-18 14:36:24 +03:00
|
|
|
|
- **default** - ["primitives"]
|
|
|
|
|
- **macro** - Activates `config!` macros for easy configure web application.
|
|
|
|
|
- **primitives** - Group for features: `numbers` and `bool`.
|
|
|
|
|
- **numbers** - Group for features: `int`, `uint` and `float`.
|
|
|
|
|
- **int** - Group for features: `i8`, `i16`, `i32`, `i64`, `i128` and `isize`.
|
|
|
|
|
- **uint** - Group for features: `u8`, `u16`, `u32`, `u64`, `u128` and `usize`.
|
|
|
|
|
- **float** - Group for features: `f32` and `f64`
|
|
|
|
|
- **i8** - impl EnvString for `i8` type
|
|
|
|
|
- **i16** - impl EnvString for `i16` type
|
|
|
|
|
- **i32** - impl EnvString for `i32` type
|
|
|
|
|
- **i64** - impl EnvString for `i64` type
|
|
|
|
|
- **i128** - impl EnvString for `i128` type
|
|
|
|
|
- **isize** - impl EnvString for `isize` type
|
|
|
|
|
- **u8** - impl EnvString for `u8` type
|
|
|
|
|
- **u16** - impl EnvString for `u16` type
|
|
|
|
|
- **u32** - impl EnvString for `u32` type
|
|
|
|
|
- **u64** - impl EnvString for `u64` type
|
|
|
|
|
- **u128** - impl EnvString for `u128` type
|
|
|
|
|
- **usize** - impl EnvString for `usize` type
|
|
|
|
|
- **f32** - impl EnvString for `f32` type
|
|
|
|
|
- **f64** - impl EnvString for `f64` type
|
|
|
|
|
- **bool** - impl EnvString for `bool` type
|
|
|
|
|
- **json_array** - Add EnvString impl for vector type (uses optional
|
|
|
|
|
`serde_json` package). ⚠ **_DEPRECATED_**
|
2020-01-21 11:12:12 +03:00
|
|
|
|
|
2019-12-24 19:37:55 +03:00
|
|
|
|
## License
|
|
|
|
|
|
|
|
|
|
[MIT] © [Ice Temple](https://github.com/icetemple)
|
|
|
|
|
|
|
|
|
|
## Contributors
|
|
|
|
|
|
2022-07-18 14:36:24 +03:00
|
|
|
|
[pleshevskiy](https://github.com/pleshevskiy) (Dmitriy Pleshevskiy) – creator,
|
|
|
|
|
maintainer.
|
2019-12-23 15:24:36 +03:00
|
|
|
|
|
|
|
|
|
[documentation]: https://docs.rs/itconfig
|
2019-12-24 19:37:55 +03:00
|
|
|
|
[MIT]: https://github.com/icetemple/itconfig-rs/blob/master/LICENSE
|