MeiliSearch/meilisearch-http/src/option.rs

30 lines
1.2 KiB
Rust
Raw Normal View History

2019-10-31 15:00:36 +01:00
use structopt::StructOpt;
2020-02-06 15:42:35 +01:00
const POSSIBLE_ENV: [&str; 2] = ["development", "production"];
#[derive(Debug, Clone, StructOpt)]
pub struct Opt {
2019-10-31 15:00:36 +01:00
/// The destination where the database must be created.
#[structopt(long, env = "MEILI_DB_PATH", default_value = "./data.ms")]
pub db_path: String,
2019-10-31 15:00:36 +01:00
/// The address on which the http server will listen.
2019-11-29 15:23:26 +01:00
#[structopt(long, env = "MEILI_HTTP_ADDR", default_value = "127.0.0.1:7700")]
2019-10-31 15:00:36 +01:00
pub http_addr: String,
/// The master key allowing you to do everything on the server.
2020-02-06 15:41:11 +01:00
#[structopt(long, env = "MEILI_MASTER_KEY")]
pub master_key: Option<String>,
2019-11-21 19:15:33 +01:00
2020-02-06 15:42:35 +01:00
/// This environment variable must be set to `production` if your are running in production.
/// If the server is running in development mode more logs will be displayed,
/// and the master key can be avoided which implies that there is no security on the updates routes.
/// This is useful to debug when integrating the engine with another service.
2020-02-06 15:42:35 +01:00
#[structopt(long, env = "MEILI_ENV", default_value = "development", possible_values = &POSSIBLE_ENV)]
pub env: String,
2019-11-21 19:15:33 +01:00
/// Do not send analytics to Meili.
#[structopt(long, env = "MEILI_NO_ANALYTICS")]
pub no_analytics: bool,
2019-10-31 15:00:36 +01:00
}