2020-01-19 17:33:46 +03:00
|
|
|
//! # itconfig
|
|
|
|
//!
|
|
|
|
//! Simple configuration with macro for rust application.
|
|
|
|
//!
|
|
|
|
//!
|
|
|
|
//! ## Motivation
|
|
|
|
//!
|
|
|
|
//! 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-03-12 23:20:34 +03:00
|
|
|
//! ## Installation
|
|
|
|
//!
|
|
|
|
//! These macros require a Rust compiler version 1.31 or newer.
|
|
|
|
//!
|
|
|
|
//! Add `itconfig = { version = "1.0", features = ["macro"] }` as a dependency in `Cargo.toml`.
|
|
|
|
//!
|
|
|
|
//!
|
|
|
|
//! `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
|
2020-01-19 17:33:46 +03:00
|
|
|
//!
|
|
|
|
//! ```rust
|
2020-03-12 23:20:34 +03:00
|
|
|
//! use itconfig::config;
|
2020-01-19 17:33:46 +03:00
|
|
|
//! use std::env;
|
2021-04-16 10:35:42 +03:00
|
|
|
//! //use dotenv::dotenv;
|
2020-01-19 17:33:46 +03:00
|
|
|
//!
|
|
|
|
//! config! {
|
2021-04-16 10:35:42 +03:00
|
|
|
//! DEBUG: bool => false,
|
|
|
|
//!
|
|
|
|
//! #[env_name = "APP_HOST"]
|
2020-01-19 17:33:46 +03:00
|
|
|
//! HOST: String => "127.0.0.1",
|
|
|
|
//!
|
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,
|
|
|
|
//! },
|
2020-01-19 17:33:46 +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");
|
2020-01-19 17:33:46 +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);
|
2020-01-19 17:33:46 +03:00
|
|
|
//! }
|
|
|
|
//! ```
|
|
|
|
//!
|
2020-07-08 16:50:41 +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);
|
|
|
|
//! }
|
|
|
|
//! ```
|
|
|
|
//!
|
2020-02-08 20:43:33 +03:00
|
|
|
//! ## Available features
|
|
|
|
//!
|
2020-03-12 23:20:34 +03:00
|
|
|
//! * **default** - ["primitives"]
|
2020-02-08 20:43:33 +03:00
|
|
|
//! * **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`
|
2020-03-17 14:59:33 +03:00
|
|
|
//! * **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
|
2021-04-16 01:12:35 +03:00
|
|
|
//! * **json_array** - Add EnvString impl for vector type (uses optional `serde_json` package). ⚠ **_DEPRECATED_**
|
2020-03-17 14:59:33 +03:00
|
|
|
//!
|
2020-01-19 17:33:46 +03:00
|
|
|
|
2020-01-16 22:05:35 +03:00
|
|
|
// Rustc lints.
|
2020-11-12 10:45:06 +03:00
|
|
|
#![forbid(unsafe_code)]
|
2021-06-22 10:20:22 +03:00
|
|
|
#![forbid(non_ascii_idents)]
|
2020-02-08 20:43:33 +03:00
|
|
|
#![deny(
|
|
|
|
missing_debug_implementations,
|
2022-07-22 13:05:54 +03:00
|
|
|
// missing_docs,
|
2020-02-08 20:43:33 +03:00
|
|
|
unstable_features,
|
|
|
|
unused_imports,
|
2020-07-02 20:54:17 +03:00
|
|
|
unused_qualifications
|
2020-02-08 20:43:33 +03:00
|
|
|
)]
|
2021-04-16 10:31:27 +03:00
|
|
|
// Clippy lints
|
2021-02-23 23:36:33 +03:00
|
|
|
#![deny(clippy::all)]
|
|
|
|
#![allow(clippy::needless_doctest_main)]
|
2019-12-22 13:13:29 +03:00
|
|
|
|
2020-01-16 22:05:35 +03:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
2019-12-22 13:13:29 +03:00
|
|
|
|
2022-07-22 13:05:54 +03:00
|
|
|
pub mod core;
|
2021-02-23 23:36:33 +03:00
|
|
|
mod error;
|
2022-07-22 13:05:54 +03:00
|
|
|
mod utils;
|
2019-12-22 13:13:29 +03:00
|
|
|
|
2022-07-22 13:05:54 +03:00
|
|
|
pub use self::core::*;
|
2021-02-23 23:36:33 +03:00
|
|
|
pub use self::error::*;
|
2022-07-22 13:05:54 +03:00
|
|
|
pub use self::utils::*;
|
2019-12-22 13:13:29 +03:00
|
|
|
|
2020-01-16 22:05:35 +03:00
|
|
|
#[cfg(feature = "macro")]
|
2020-03-12 23:20:34 +03:00
|
|
|
extern crate itconfig_macro;
|
2020-01-16 22:05:35 +03:00
|
|
|
#[cfg(feature = "macro")]
|
2020-07-02 20:54:17 +03:00
|
|
|
pub use itconfig_macro::*;
|