mirror of
				https://github.com/meilisearch/meilisearch.git
				synced 2025-10-25 04:56:28 +00:00 
			
		
		
		
	chore(http): migrate from structopt to clap3
This commit is contained in:
		| @@ -67,7 +67,7 @@ serde_json = { version = "1.0.67", features = ["preserve_order"] } | ||||
| sha2 = "0.9.6" | ||||
| siphasher = "0.3.7" | ||||
| slice-group-by = "0.2.6" | ||||
| structopt = "0.3.25" | ||||
| clap = { version = "3.0", features = ["derive", "env"] } | ||||
| sysinfo = "0.20.2" | ||||
| tar = "0.4.37" | ||||
| tempfile = "3.2.0" | ||||
|   | ||||
| @@ -2,12 +2,12 @@ use std::env; | ||||
| use std::sync::Arc; | ||||
|  | ||||
| use actix_web::HttpServer; | ||||
| use clap::Parser; | ||||
| use meilisearch_auth::AuthController; | ||||
| use meilisearch_http::analytics; | ||||
| use meilisearch_http::analytics::Analytics; | ||||
| use meilisearch_http::{create_app, setup_meilisearch, Opt}; | ||||
| use meilisearch_lib::MeiliSearch; | ||||
| use structopt::StructOpt; | ||||
|  | ||||
| #[cfg(target_os = "linux")] | ||||
| #[global_allocator] | ||||
| @@ -29,7 +29,7 @@ fn setup(opt: &Opt) -> anyhow::Result<()> { | ||||
|  | ||||
| #[actix_web::main] | ||||
| async fn main() -> anyhow::Result<()> { | ||||
|     let opt = Opt::from_args(); | ||||
|     let opt = Opt::parse(); | ||||
|  | ||||
|     setup(&opt)?; | ||||
|  | ||||
|   | ||||
| @@ -4,127 +4,127 @@ use std::path::PathBuf; | ||||
| use std::sync::Arc; | ||||
|  | ||||
| use byte_unit::Byte; | ||||
| use clap::Parser; | ||||
| use meilisearch_lib::options::IndexerOpts; | ||||
| use rustls::internal::pemfile::{certs, pkcs8_private_keys, rsa_private_keys}; | ||||
| use rustls::{ | ||||
|     AllowAnyAnonymousOrAuthenticatedClient, AllowAnyAuthenticatedClient, NoClientAuth, | ||||
|     RootCertStore, | ||||
| }; | ||||
| use structopt::StructOpt; | ||||
|  | ||||
| const POSSIBLE_ENV: [&str; 2] = ["development", "production"]; | ||||
|  | ||||
| #[derive(Debug, Clone, StructOpt)] | ||||
| #[derive(Debug, Clone, Parser)] | ||||
| pub struct Opt { | ||||
|     /// The destination where the database must be created. | ||||
|     #[structopt(long, env = "MEILI_DB_PATH", default_value = "./data.ms")] | ||||
|     #[clap(long, env = "MEILI_DB_PATH", default_value = "./data.ms")] | ||||
|     pub db_path: PathBuf, | ||||
|  | ||||
|     /// The address on which the http server will listen. | ||||
|     #[structopt(long, env = "MEILI_HTTP_ADDR", default_value = "127.0.0.1:7700")] | ||||
|     #[clap(long, env = "MEILI_HTTP_ADDR", default_value = "127.0.0.1:7700")] | ||||
|     pub http_addr: String, | ||||
|  | ||||
|     /// The master key allowing you to do everything on the server. | ||||
|     #[structopt(long, env = "MEILI_MASTER_KEY")] | ||||
|     #[clap(long, env = "MEILI_MASTER_KEY")] | ||||
|     pub master_key: Option<String>, | ||||
|  | ||||
|     /// This environment variable must be set to `production` if you 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. | ||||
|     #[structopt(long, env = "MEILI_ENV", default_value = "development", possible_values = &POSSIBLE_ENV)] | ||||
|     #[clap(long, env = "MEILI_ENV", default_value = "development", possible_values = &POSSIBLE_ENV)] | ||||
|     pub env: String, | ||||
|  | ||||
|     /// Do not send analytics to Meili. | ||||
|     #[cfg(all(not(debug_assertions), feature = "analytics"))] | ||||
|     #[structopt(long, env = "MEILI_NO_ANALYTICS")] | ||||
|     pub no_analytics: Option<Option<bool>>, | ||||
|     #[clap(long, env = "MEILI_NO_ANALYTICS")] | ||||
|     pub no_analytics: bool, | ||||
|  | ||||
|     /// The maximum size, in bytes, of the main lmdb database directory | ||||
|     #[structopt(long, env = "MEILI_MAX_INDEX_SIZE", default_value = "100 GiB")] | ||||
|     #[clap(long, env = "MEILI_MAX_INDEX_SIZE", default_value = "100 GiB")] | ||||
|     pub max_index_size: Byte, | ||||
|  | ||||
|     /// The maximum size, in bytes, of the update lmdb database directory | ||||
|     #[structopt(long, env = "MEILI_MAX_TASK_DB_SIZE", default_value = "100 GiB")] | ||||
|     #[clap(long, env = "MEILI_MAX_TASK_DB_SIZE", default_value = "100 GiB")] | ||||
|     pub max_task_db_size: Byte, | ||||
|  | ||||
|     /// The maximum size, in bytes, of accepted JSON payloads | ||||
|     #[structopt(long, env = "MEILI_HTTP_PAYLOAD_SIZE_LIMIT", default_value = "100 MB")] | ||||
|     #[clap(long, env = "MEILI_HTTP_PAYLOAD_SIZE_LIMIT", default_value = "100 MB")] | ||||
|     pub http_payload_size_limit: Byte, | ||||
|  | ||||
|     /// Read server certificates from CERTFILE. | ||||
|     /// This should contain PEM-format certificates | ||||
|     /// in the right order (the first certificate should | ||||
|     /// certify KEYFILE, the last should be a root CA). | ||||
|     #[structopt(long, env = "MEILI_SSL_CERT_PATH", parse(from_os_str))] | ||||
|     #[clap(long, env = "MEILI_SSL_CERT_PATH", parse(from_os_str))] | ||||
|     pub ssl_cert_path: Option<PathBuf>, | ||||
|  | ||||
|     /// Read private key from KEYFILE.  This should be a RSA | ||||
|     /// private key or PKCS8-encoded private key, in PEM format. | ||||
|     #[structopt(long, env = "MEILI_SSL_KEY_PATH", parse(from_os_str))] | ||||
|     #[clap(long, env = "MEILI_SSL_KEY_PATH", parse(from_os_str))] | ||||
|     pub ssl_key_path: Option<PathBuf>, | ||||
|  | ||||
|     /// Enable client authentication, and accept certificates | ||||
|     /// signed by those roots provided in CERTFILE. | ||||
|     #[structopt(long, env = "MEILI_SSL_AUTH_PATH", parse(from_os_str))] | ||||
|     #[clap(long, env = "MEILI_SSL_AUTH_PATH", parse(from_os_str))] | ||||
|     pub ssl_auth_path: Option<PathBuf>, | ||||
|  | ||||
|     /// Read DER-encoded OCSP response from OCSPFILE and staple to certificate. | ||||
|     /// Optional | ||||
|     #[structopt(long, env = "MEILI_SSL_OCSP_PATH", parse(from_os_str))] | ||||
|     #[clap(long, env = "MEILI_SSL_OCSP_PATH", parse(from_os_str))] | ||||
|     pub ssl_ocsp_path: Option<PathBuf>, | ||||
|  | ||||
|     /// Send a fatal alert if the client does not complete client authentication. | ||||
|     #[structopt(long, env = "MEILI_SSL_REQUIRE_AUTH")] | ||||
|     #[clap(long, env = "MEILI_SSL_REQUIRE_AUTH")] | ||||
|     pub ssl_require_auth: bool, | ||||
|  | ||||
|     /// SSL support session resumption | ||||
|     #[structopt(long, env = "MEILI_SSL_RESUMPTION")] | ||||
|     #[clap(long, env = "MEILI_SSL_RESUMPTION")] | ||||
|     pub ssl_resumption: bool, | ||||
|  | ||||
|     /// SSL support tickets. | ||||
|     #[structopt(long, env = "MEILI_SSL_TICKETS")] | ||||
|     #[clap(long, env = "MEILI_SSL_TICKETS")] | ||||
|     pub ssl_tickets: bool, | ||||
|  | ||||
|     /// Defines the path of the snapshot file to import. | ||||
|     /// This option will, by default, stop the process if a database already exist or if no snapshot exists at | ||||
|     /// the given path. If this option is not specified no snapshot is imported. | ||||
|     #[structopt(long)] | ||||
|     #[clap(long)] | ||||
|     pub import_snapshot: Option<PathBuf>, | ||||
|  | ||||
|     /// The engine will ignore a missing snapshot and not return an error in such case. | ||||
|     #[structopt(long, requires = "import-snapshot")] | ||||
|     #[clap(long, requires = "import-snapshot")] | ||||
|     pub ignore_missing_snapshot: bool, | ||||
|  | ||||
|     /// The engine will skip snapshot importation and not return an error in such case. | ||||
|     #[structopt(long, requires = "import-snapshot")] | ||||
|     #[clap(long, requires = "import-snapshot")] | ||||
|     pub ignore_snapshot_if_db_exists: bool, | ||||
|  | ||||
|     /// Defines the directory path where meilisearch will create snapshot each snapshot_time_gap. | ||||
|     #[structopt(long, env = "MEILI_SNAPSHOT_DIR", default_value = "snapshots/")] | ||||
|     #[clap(long, env = "MEILI_SNAPSHOT_DIR", default_value = "snapshots/")] | ||||
|     pub snapshot_dir: PathBuf, | ||||
|  | ||||
|     /// Activate snapshot scheduling. | ||||
|     #[structopt(long, env = "MEILI_SCHEDULE_SNAPSHOT")] | ||||
|     #[clap(long, env = "MEILI_SCHEDULE_SNAPSHOT")] | ||||
|     pub schedule_snapshot: bool, | ||||
|  | ||||
|     /// Defines time interval, in seconds, between each snapshot creation. | ||||
|     #[structopt(long, env = "MEILI_SNAPSHOT_INTERVAL_SEC", default_value = "86400")] // 24h | ||||
|     #[clap(long, env = "MEILI_SNAPSHOT_INTERVAL_SEC", default_value = "86400")] // 24h | ||||
|     pub snapshot_interval_sec: u64, | ||||
|  | ||||
|     /// Folder where dumps are created when the dump route is called. | ||||
|     #[structopt(long, env = "MEILI_DUMPS_DIR", default_value = "dumps/")] | ||||
|     #[clap(long, env = "MEILI_DUMPS_DIR", default_value = "dumps/")] | ||||
|     pub dumps_dir: PathBuf, | ||||
|  | ||||
|     /// Import a dump from the specified path, must be a `.dump` file. | ||||
|     #[structopt(long, conflicts_with = "import-snapshot")] | ||||
|     #[clap(long, conflicts_with = "import-snapshot")] | ||||
|     pub import_dump: Option<PathBuf>, | ||||
|  | ||||
|     /// Set the log level | ||||
|     #[structopt(long, env = "MEILI_LOG_LEVEL", default_value = "info")] | ||||
|     #[clap(long, env = "MEILI_LOG_LEVEL", default_value = "info")] | ||||
|     pub log_level: String, | ||||
|  | ||||
|     #[structopt(skip)] | ||||
|     #[clap(skip)] | ||||
|     pub indexer_options: IndexerOpts, | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user