config work
This commit is contained in:
parent
205a6a8fd1
commit
effc4aeeac
1
Cargo.lock
generated
1
Cargo.lock
generated
@ -3776,6 +3776,7 @@ version = "0.1.0"
|
|||||||
dependencies = [
|
dependencies = [
|
||||||
"async-std",
|
"async-std",
|
||||||
"async-tungstenite 0.8.0",
|
"async-tungstenite 0.8.0",
|
||||||
|
"async_executors",
|
||||||
"bugsalot",
|
"bugsalot",
|
||||||
"capnp",
|
"capnp",
|
||||||
"capnp-rpc",
|
"capnp-rpc",
|
||||||
|
@ -13,6 +13,7 @@ path = "src/main.rs"
|
|||||||
[dependencies]
|
[dependencies]
|
||||||
async-std = { version = "^1.9", features = ["unstable", "attributes"] }
|
async-std = { version = "^1.9", features = ["unstable", "attributes"] }
|
||||||
async-tungstenite = { version = "^0.8", features = ["async-std-runtime"] }
|
async-tungstenite = { version = "^0.8", features = ["async-std-runtime"] }
|
||||||
|
async_executors = { version = "^0", default-features = false, features = [ "async_std" ]}
|
||||||
cursive = { path = "../external/cursive/cursive", default-features = false, features = ["crossterm-backend", "toml"]}
|
cursive = { path = "../external/cursive/cursive", default-features = false, features = ["crossterm-backend", "toml"]}
|
||||||
cursive-flexi-logger-view = { path = "../external/cursive-flexi-logger-view" }
|
cursive-flexi-logger-view = { path = "../external/cursive-flexi-logger-view" }
|
||||||
cursive_buffered_backend = { path = "../external/cursive_buffered_backend" }
|
cursive_buffered_backend = { path = "../external/cursive_buffered_backend" }
|
||||||
|
@ -1,13 +1,13 @@
|
|||||||
use crate::command_processor::*;
|
use crate::command_processor::*;
|
||||||
use crate::veilid_client_capnp::*;
|
use crate::veilid_client_capnp::*;
|
||||||
use veilid_core::xx::*;
|
use async_executors::{AsyncStd, LocalSpawnHandleExt};
|
||||||
|
|
||||||
use capnp::capability::Promise;
|
use capnp::capability::Promise;
|
||||||
use capnp_rpc::{pry, rpc_twoparty_capnp, twoparty, Disconnector, RpcSystem};
|
use capnp_rpc::{pry, rpc_twoparty_capnp, twoparty, Disconnector, RpcSystem};
|
||||||
use futures::AsyncReadExt;
|
use futures::AsyncReadExt;
|
||||||
use std::cell::RefCell;
|
use std::cell::RefCell;
|
||||||
use std::net::SocketAddr;
|
use std::net::SocketAddr;
|
||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
|
use veilid_core::xx::*;
|
||||||
|
|
||||||
struct VeilidClientImpl {
|
struct VeilidClientImpl {
|
||||||
comproc: CommandProcessor,
|
comproc: CommandProcessor,
|
||||||
@ -152,19 +152,29 @@ impl ClientApiConnection {
|
|||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Send the request and get the state object and the registration object
|
// Process the rpc system until we decide we're done
|
||||||
if let Ok(response) = request.send().promise.await {
|
if let Ok(rpc_jh) = AsyncStd.spawn_handle_local(rpc_system) {
|
||||||
if let Ok(response) = response.get() {
|
// Send the request and get the state object and the registration object
|
||||||
if let Ok(_registration) = response.get_registration() {
|
if let Ok(response) = request.send().promise.await {
|
||||||
if let Ok(state) = response.get_state() {
|
if let Ok(response) = response.get() {
|
||||||
// Set up our state for the first time
|
if let Ok(_registration) = response.get_registration() {
|
||||||
if self.process_veilid_state(state).await.is_ok() {
|
if let Ok(state) = response.get_state() {
|
||||||
// Don't drop the registration
|
// Set up our state for the first time
|
||||||
rpc_system.await.map_err(map_to_string)?;
|
if self.process_veilid_state(state).await.is_ok() {
|
||||||
|
// Don't drop the registration, doing so will remove the client
|
||||||
|
// object mapping from the server which we need for the update backchannel
|
||||||
|
|
||||||
|
// Wait until rpc system completion or disconnect was requested
|
||||||
|
if let Err(e) = rpc_jh.await {
|
||||||
|
error!("Client RPC system error: {}", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
error!("Failed to spawn client RPC system");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Drop the server and disconnector too (if we still have it)
|
// Drop the server and disconnector too (if we still have it)
|
||||||
|
@ -29,35 +29,55 @@ impl ProtectedStore {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn delete_all(&self) -> Result<(), String> {
|
||||||
|
// Delete all known keys
|
||||||
|
if self.remove_user_secret_string("node_id").await? {
|
||||||
|
debug!("deleted protected_store key 'node_id'");
|
||||||
|
}
|
||||||
|
if self.remove_user_secret_string("node_id_secret").await? {
|
||||||
|
debug!("deleted protected_store key 'node_id_secret'");
|
||||||
|
}
|
||||||
|
if self.remove_user_secret_string("_test_key").await? {
|
||||||
|
debug!("deleted protected_store key '_test_key'");
|
||||||
|
}
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn init(&self) -> Result<(), String> {
|
pub async fn init(&self) -> Result<(), String> {
|
||||||
let c = self.config.get();
|
let c = self.config.get();
|
||||||
let mut inner = self.inner.lock();
|
{
|
||||||
if !c.protected_store.always_use_insecure_storage {
|
let mut inner = self.inner.lock();
|
||||||
cfg_if! {
|
if !c.protected_store.always_use_insecure_storage {
|
||||||
if #[cfg(target_os = "android")] {
|
cfg_if! {
|
||||||
inner.keyring_manager = KeyringManager::new_secure(&c.program_name, intf::native::utils::android::get_android_globals()).ok();
|
if #[cfg(target_os = "android")] {
|
||||||
} else {
|
inner.keyring_manager = KeyringManager::new_secure(&c.program_name, intf::native::utils::android::get_android_globals()).ok();
|
||||||
inner.keyring_manager = KeyringManager::new_secure(&c.program_name).ok();
|
} else {
|
||||||
|
inner.keyring_manager = KeyringManager::new_secure(&c.program_name).ok();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (c.protected_store.always_use_insecure_storage
|
||||||
|
|| c.protected_store.allow_insecure_fallback)
|
||||||
|
&& inner.keyring_manager.is_none()
|
||||||
|
{
|
||||||
|
let insecure_fallback_directory =
|
||||||
|
Path::new(&c.protected_store.insecure_fallback_directory);
|
||||||
|
let insecure_keyring_file = insecure_fallback_directory
|
||||||
|
.to_owned()
|
||||||
|
.join("insecure_keyring");
|
||||||
|
inner.keyring_manager = Some(
|
||||||
|
KeyringManager::new_insecure(&c.program_name, &insecure_keyring_file)
|
||||||
|
.map_err(map_to_string)
|
||||||
|
.map_err(logthru_pstore!(error))?,
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if inner.keyring_manager.is_none() {
|
||||||
|
return Err("Could not initialize the protected store.".to_owned());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (c.protected_store.always_use_insecure_storage
|
|
||||||
|| c.protected_store.allow_insecure_fallback)
|
if c.protected_store.delete {
|
||||||
&& inner.keyring_manager.is_none()
|
self.delete_all().await?;
|
||||||
{
|
|
||||||
let insecure_fallback_directory =
|
|
||||||
Path::new(&c.protected_store.insecure_fallback_directory);
|
|
||||||
let insecure_keyring_file = insecure_fallback_directory
|
|
||||||
.to_owned()
|
|
||||||
.join("insecure_keyring");
|
|
||||||
inner.keyring_manager = Some(
|
|
||||||
KeyringManager::new_insecure(&c.program_name, &insecure_keyring_file)
|
|
||||||
.map_err(map_to_string)
|
|
||||||
.map_err(logthru_pstore!(error))?,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if inner.keyring_manager.is_none() {
|
|
||||||
return Err("Could not initialize the protected store.".to_owned());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Ok(())
|
Ok(())
|
||||||
|
@ -27,6 +27,12 @@ impl TableStore {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub async fn delete_all(&self) -> Result<(), String> {
|
||||||
|
// Delete all known keys
|
||||||
|
self.delete("crypto_caches").await?;
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
pub async fn init(&self) -> Result<(), String> {
|
pub async fn init(&self) -> Result<(), String> {
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
@ -141,6 +141,13 @@ pub struct VeilidConfigNetwork {
|
|||||||
#[derive(Default, Clone)]
|
#[derive(Default, Clone)]
|
||||||
pub struct VeilidConfigTableStore {
|
pub struct VeilidConfigTableStore {
|
||||||
pub directory: String,
|
pub directory: String,
|
||||||
|
pub delete: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Default, Clone)]
|
||||||
|
pub struct VeilidConfigBlockStore {
|
||||||
|
pub directory: String,
|
||||||
|
pub delete: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Clone)]
|
#[derive(Default, Clone)]
|
||||||
@ -148,6 +155,7 @@ pub struct VeilidConfigProtectedStore {
|
|||||||
pub allow_insecure_fallback: bool,
|
pub allow_insecure_fallback: bool,
|
||||||
pub always_use_insecure_storage: bool,
|
pub always_use_insecure_storage: bool,
|
||||||
pub insecure_fallback_directory: String,
|
pub insecure_fallback_directory: String,
|
||||||
|
pub delete: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Clone)]
|
#[derive(Default, Clone)]
|
||||||
@ -168,6 +176,7 @@ pub struct VeilidConfigInner {
|
|||||||
pub capabilities: VeilidConfigCapabilities,
|
pub capabilities: VeilidConfigCapabilities,
|
||||||
pub protected_store: VeilidConfigProtectedStore,
|
pub protected_store: VeilidConfigProtectedStore,
|
||||||
pub table_store: VeilidConfigTableStore,
|
pub table_store: VeilidConfigTableStore,
|
||||||
|
pub block_store: VeilidConfigBlockStore,
|
||||||
pub network: VeilidConfigNetwork,
|
pub network: VeilidConfigNetwork,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -216,9 +225,13 @@ impl VeilidConfig {
|
|||||||
get_config!(inner.capabilities.protocol_connect_wss);
|
get_config!(inner.capabilities.protocol_connect_wss);
|
||||||
get_config!(inner.capabilities.protocol_accept_wss);
|
get_config!(inner.capabilities.protocol_accept_wss);
|
||||||
get_config!(inner.table_store.directory);
|
get_config!(inner.table_store.directory);
|
||||||
|
get_config!(inner.table_store.delete);
|
||||||
|
get_config!(inner.block_store.directory);
|
||||||
|
get_config!(inner.block_store.delete);
|
||||||
get_config!(inner.protected_store.allow_insecure_fallback);
|
get_config!(inner.protected_store.allow_insecure_fallback);
|
||||||
get_config!(inner.protected_store.always_use_insecure_storage);
|
get_config!(inner.protected_store.always_use_insecure_storage);
|
||||||
get_config!(inner.protected_store.insecure_fallback_directory);
|
get_config!(inner.protected_store.insecure_fallback_directory);
|
||||||
|
get_config!(inner.protected_store.delete);
|
||||||
get_config!(inner.network.node_id);
|
get_config!(inner.network.node_id);
|
||||||
get_config!(inner.network.node_id_secret);
|
get_config!(inner.network.node_id_secret);
|
||||||
get_config!(inner.network.max_connections);
|
get_config!(inner.network.max_connections);
|
||||||
|
@ -124,6 +124,12 @@ impl VeilidCore {
|
|||||||
crypto.init().await?;
|
crypto.init().await?;
|
||||||
inner.crypto = Some(crypto.clone());
|
inner.crypto = Some(crypto.clone());
|
||||||
|
|
||||||
|
// Set up block store
|
||||||
|
// trace!("VeilidCore::internal_startup init block store");
|
||||||
|
// let block_store = BlockStore::new(config.clone());
|
||||||
|
// block_store.init().await?;
|
||||||
|
// inner.block_store = Some(block_store.clone();)
|
||||||
|
|
||||||
// Set up attachment manager
|
// Set up attachment manager
|
||||||
trace!("VeilidCore::internal_startup init attachment manager");
|
trace!("VeilidCore::internal_startup init attachment manager");
|
||||||
let cb = setup.update_callback;
|
let cb = setup.update_callback;
|
||||||
|
@ -101,6 +101,13 @@ pub struct VeilidConfigNetwork {
|
|||||||
#[derive(Default, Clone)]
|
#[derive(Default, Clone)]
|
||||||
pub struct VeilidConfigTableStore {
|
pub struct VeilidConfigTableStore {
|
||||||
pub directory: String,
|
pub directory: String,
|
||||||
|
pub delete: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Default, Clone)]
|
||||||
|
pub struct VeilidConfigBlockStore {
|
||||||
|
pub directory: String,
|
||||||
|
pub delete: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Clone)]
|
#[derive(Default, Clone)]
|
||||||
@ -108,6 +115,7 @@ pub struct VeilidConfigProtectedStore {
|
|||||||
pub allow_insecure_fallback: bool,
|
pub allow_insecure_fallback: bool,
|
||||||
pub always_use_insecure_storage: bool,
|
pub always_use_insecure_storage: bool,
|
||||||
pub insecure_fallback_directory: String,
|
pub insecure_fallback_directory: String,
|
||||||
|
pub delete: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Default, Clone)]
|
#[derive(Default, Clone)]
|
||||||
@ -128,6 +136,7 @@ pub struct VeilidConfig {
|
|||||||
pub capabilities: VeilidConfigCapabilities,
|
pub capabilities: VeilidConfigCapabilities,
|
||||||
pub protected_store: VeilidConfigProtectedStore,
|
pub protected_store: VeilidConfigProtectedStore,
|
||||||
pub table_store: VeilidConfigTableStore,
|
pub table_store: VeilidConfigTableStore,
|
||||||
|
pub block_store: VeilidConfigBlockStore,
|
||||||
pub network: VeilidConfigNetwork,
|
pub network: VeilidConfigNetwork,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,10 +1,9 @@
|
|||||||
use crate::settings::*;
|
use crate::settings::*;
|
||||||
use std::ffi::OsStr;
|
|
||||||
use clap::{App, Arg, ArgMatches};
|
use clap::{App, Arg, ArgMatches};
|
||||||
|
use std::ffi::OsStr;
|
||||||
use std::str::FromStr;
|
use std::str::FromStr;
|
||||||
|
|
||||||
fn do_clap_matches(default_config_path: &OsStr) -> Result<clap::ArgMatches, clap::Error> {
|
fn do_clap_matches(default_config_path: &OsStr) -> Result<clap::ArgMatches, clap::Error> {
|
||||||
|
|
||||||
let matches = App::new("veilid-server")
|
let matches = App::new("veilid-server")
|
||||||
.version("0.1")
|
.version("0.1")
|
||||||
.about("Veilid Server")
|
.about("Veilid Server")
|
||||||
@ -22,6 +21,7 @@ fn do_clap_matches(default_config_path: &OsStr) -> Result<clap::ArgMatches, clap
|
|||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.value_name("FILE")
|
.value_name("FILE")
|
||||||
.default_value_os(default_config_path)
|
.default_value_os(default_config_path)
|
||||||
|
.allow_invalid_utf8(true)
|
||||||
.help("Specify a configuration file to use"),
|
.help("Specify a configuration file to use"),
|
||||||
).arg(
|
).arg(
|
||||||
Arg::new("attach")
|
Arg::new("attach")
|
||||||
@ -54,7 +54,21 @@ fn do_clap_matches(default_config_path: &OsStr) -> Result<clap::ArgMatches, clap
|
|||||||
.long("generate-dht-key")
|
.long("generate-dht-key")
|
||||||
.help("Only generate a new dht key and print it"),
|
.help("Only generate a new dht key and print it"),
|
||||||
)
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::new("delete-protected-store")
|
||||||
|
.long("delete-protected-store")
|
||||||
|
.help("Delete the entire contents of the protected store (DANGER, NO UNDO!)"),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::new("delete-table-store")
|
||||||
|
.long("delete-table-store")
|
||||||
|
.help("Delete the entire contents of the table store (DANGER, NO UNDO!)"),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::new("delete-block-store")
|
||||||
|
.long("delete-block-store")
|
||||||
|
.help("Delete the entire contents of the block store (DANGER, NO UNDO!)"),
|
||||||
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("dump-config")
|
Arg::new("dump-config")
|
||||||
.long("dump-config")
|
.long("dump-config")
|
||||||
@ -73,18 +87,17 @@ fn do_clap_matches(default_config_path: &OsStr) -> Result<clap::ArgMatches, clap
|
|||||||
.help("Enable local peer scope")
|
.help("Enable local peer scope")
|
||||||
);
|
);
|
||||||
|
|
||||||
#[cfg(debug_assertions)]
|
#[cfg(debug_assertions)]
|
||||||
let matches = matches.arg(
|
let matches = matches.arg(
|
||||||
Arg::new("wait-for-debug")
|
Arg::new("wait-for-debug")
|
||||||
.long("wait-for-debug")
|
.long("wait-for-debug")
|
||||||
.help("Wait for debugger to attach"),
|
.help("Wait for debugger to attach"),
|
||||||
);
|
);
|
||||||
|
|
||||||
Ok(matches.get_matches())
|
Ok(matches.get_matches())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn process_command_line() -> Result<(Settings, ArgMatches), String> {
|
pub fn process_command_line() -> Result<(Settings, ArgMatches), String> {
|
||||||
|
|
||||||
// Get command line options
|
// Get command line options
|
||||||
let default_config_path = Settings::get_default_config_path();
|
let default_config_path = Settings::get_default_config_path();
|
||||||
let matches = do_clap_matches(default_config_path.as_os_str())
|
let matches = do_clap_matches(default_config_path.as_os_str())
|
||||||
@ -126,6 +139,7 @@ pub fn process_command_line() -> Result<(Settings, ArgMatches), String> {
|
|||||||
}
|
}
|
||||||
settingsrw.testing.subnode_index = subnode_index;
|
settingsrw.testing.subnode_index = subnode_index;
|
||||||
}
|
}
|
||||||
|
|
||||||
if matches.occurrences_of("debug") != 0 {
|
if matches.occurrences_of("debug") != 0 {
|
||||||
settingsrw.logging.terminal.enabled = true;
|
settingsrw.logging.terminal.enabled = true;
|
||||||
settingsrw.logging.terminal.level = LogLevel::Debug;
|
settingsrw.logging.terminal.level = LogLevel::Debug;
|
||||||
@ -140,6 +154,15 @@ pub fn process_command_line() -> Result<(Settings, ArgMatches), String> {
|
|||||||
if matches.is_present("local") {
|
if matches.is_present("local") {
|
||||||
settingsrw.core.network.enable_local_peer_scope = true;
|
settingsrw.core.network.enable_local_peer_scope = true;
|
||||||
}
|
}
|
||||||
|
if matches.occurrences_of("delete-protected-store") != 0 {
|
||||||
|
settingsrw.core.protected_store.delete = true;
|
||||||
|
}
|
||||||
|
if matches.occurrences_of("delete-block-store") != 0 {
|
||||||
|
settingsrw.core.block_store.delete = true;
|
||||||
|
}
|
||||||
|
if matches.occurrences_of("delete-table-store") != 0 {
|
||||||
|
settingsrw.core.table_store.delete = true;
|
||||||
|
}
|
||||||
if matches.occurrences_of("bootstrap") != 0 {
|
if matches.occurrences_of("bootstrap") != 0 {
|
||||||
let bootstrap = match matches.value_of("bootstrap") {
|
let bootstrap = match matches.value_of("bootstrap") {
|
||||||
Some(x) => {
|
Some(x) => {
|
||||||
|
@ -33,8 +33,8 @@ fn main() -> Result<(), String> {
|
|||||||
.map_err(|e| e.to_string());
|
.map_err(|e| e.to_string());
|
||||||
}
|
}
|
||||||
|
|
||||||
// --- Generate Id ---
|
// --- Generate DHT Key ---
|
||||||
if matches.occurrences_of("generate-id") != 0 {
|
if matches.occurrences_of("generate-dht-key") != 0 {
|
||||||
let (key, secret) = veilid_core::generate_secret();
|
let (key, secret) = veilid_core::generate_secret();
|
||||||
println!("Public: {}\nSecret: {}", key.encode(), secret.encode());
|
println!("Public: {}\nSecret: {}", key.encode(), secret.encode());
|
||||||
return Ok(());
|
return Ok(());
|
||||||
|
@ -39,8 +39,13 @@ core:
|
|||||||
allow_insecure_fallback: true
|
allow_insecure_fallback: true
|
||||||
always_use_insecure_storage: false
|
always_use_insecure_storage: false
|
||||||
insecure_fallback_directory: '%INSECURE_FALLBACK_DIRECTORY%'
|
insecure_fallback_directory: '%INSECURE_FALLBACK_DIRECTORY%'
|
||||||
|
delete: false
|
||||||
table_store:
|
table_store:
|
||||||
directory: '%TABLE_STORE_DIRECTORY%'
|
directory: '%TABLE_STORE_DIRECTORY%'
|
||||||
|
delete: false
|
||||||
|
block_store:
|
||||||
|
directory: '%BLOCK_STORE_DIRECTORY%'
|
||||||
|
delete: false
|
||||||
network:
|
network:
|
||||||
max_connections: 16
|
max_connections: 16
|
||||||
connection_initial_timeout: 2000000
|
connection_initial_timeout: 2000000
|
||||||
@ -124,6 +129,10 @@ core:
|
|||||||
"%TABLE_STORE_DIRECTORY%",
|
"%TABLE_STORE_DIRECTORY%",
|
||||||
&Settings::get_default_table_store_path().to_string_lossy(),
|
&Settings::get_default_table_store_path().to_string_lossy(),
|
||||||
)
|
)
|
||||||
|
.replace(
|
||||||
|
"%BLOCK_STORE_DIRECTORY%",
|
||||||
|
&Settings::get_default_block_store_path().to_string_lossy(),
|
||||||
|
)
|
||||||
.replace(
|
.replace(
|
||||||
"%INSECURE_FALLBACK_DIRECTORY%",
|
"%INSECURE_FALLBACK_DIRECTORY%",
|
||||||
&Settings::get_default_protected_store_insecure_fallback_directory().to_string_lossy(),
|
&Settings::get_default_protected_store_insecure_fallback_directory().to_string_lossy(),
|
||||||
@ -532,6 +541,13 @@ pub struct Testing {
|
|||||||
#[derive(Debug, Deserialize, Serialize)]
|
#[derive(Debug, Deserialize, Serialize)]
|
||||||
pub struct TableStore {
|
pub struct TableStore {
|
||||||
pub directory: PathBuf,
|
pub directory: PathBuf,
|
||||||
|
pub delete: bool,
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Deserialize, Serialize)]
|
||||||
|
pub struct BlockStore {
|
||||||
|
pub directory: PathBuf,
|
||||||
|
pub delete: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, Serialize)]
|
#[derive(Debug, Deserialize, Serialize)]
|
||||||
@ -539,12 +555,14 @@ pub struct ProtectedStore {
|
|||||||
pub allow_insecure_fallback: bool,
|
pub allow_insecure_fallback: bool,
|
||||||
pub always_use_insecure_storage: bool,
|
pub always_use_insecure_storage: bool,
|
||||||
pub insecure_fallback_directory: PathBuf,
|
pub insecure_fallback_directory: PathBuf,
|
||||||
|
pub delete: bool,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Deserialize, Serialize)]
|
#[derive(Debug, Deserialize, Serialize)]
|
||||||
pub struct Core {
|
pub struct Core {
|
||||||
pub protected_store: ProtectedStore,
|
pub protected_store: ProtectedStore,
|
||||||
pub table_store: TableStore,
|
pub table_store: TableStore,
|
||||||
|
pub block_store: BlockStore,
|
||||||
pub network: Network,
|
pub network: Network,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -693,6 +711,20 @@ impl Settings {
|
|||||||
default_config_path
|
default_config_path
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn get_default_block_store_path() -> PathBuf {
|
||||||
|
// Get default configuration file location
|
||||||
|
let mut default_config_path;
|
||||||
|
|
||||||
|
if let Some(my_proj_dirs) = ProjectDirs::from("org", "Veilid", "Veilid") {
|
||||||
|
default_config_path = PathBuf::from(my_proj_dirs.data_local_dir());
|
||||||
|
} else {
|
||||||
|
default_config_path = PathBuf::from("./");
|
||||||
|
}
|
||||||
|
default_config_path.push("block_store");
|
||||||
|
|
||||||
|
default_config_path
|
||||||
|
}
|
||||||
|
|
||||||
pub fn get_default_protected_store_insecure_fallback_directory() -> PathBuf {
|
pub fn get_default_protected_store_insecure_fallback_directory() -> PathBuf {
|
||||||
// Get default configuration file location
|
// Get default configuration file location
|
||||||
let mut default_config_path;
|
let mut default_config_path;
|
||||||
@ -740,6 +772,8 @@ impl Settings {
|
|||||||
.to_string_lossy()
|
.to_string_lossy()
|
||||||
.to_string(),
|
.to_string(),
|
||||||
)),
|
)),
|
||||||
|
"protected_store.delete" => Ok(Box::new(inner.core.protected_store.delete)),
|
||||||
|
|
||||||
"table_store.directory" => Ok(Box::new(
|
"table_store.directory" => Ok(Box::new(
|
||||||
inner
|
inner
|
||||||
.core
|
.core
|
||||||
@ -748,6 +782,18 @@ impl Settings {
|
|||||||
.to_string_lossy()
|
.to_string_lossy()
|
||||||
.to_string(),
|
.to_string(),
|
||||||
)),
|
)),
|
||||||
|
"table_store.delete" => Ok(Box::new(inner.core.table_store.delete)),
|
||||||
|
|
||||||
|
"block_store.directory" => Ok(Box::new(
|
||||||
|
inner
|
||||||
|
.core
|
||||||
|
.block_store
|
||||||
|
.directory
|
||||||
|
.to_string_lossy()
|
||||||
|
.to_string(),
|
||||||
|
)),
|
||||||
|
"block_store.delete" => Ok(Box::new(inner.core.block_store.delete)),
|
||||||
|
|
||||||
"network.max_connections" => Ok(Box::new(inner.core.network.max_connections)),
|
"network.max_connections" => Ok(Box::new(inner.core.network.max_connections)),
|
||||||
"network.connection_initial_timeout" => {
|
"network.connection_initial_timeout" => {
|
||||||
Ok(Box::new(inner.core.network.connection_initial_timeout))
|
Ok(Box::new(inner.core.network.connection_initial_timeout))
|
||||||
@ -1070,16 +1116,27 @@ mod tests {
|
|||||||
assert_eq!(s.logging.client.enabled, true);
|
assert_eq!(s.logging.client.enabled, true);
|
||||||
assert_eq!(s.logging.client.level, LogLevel::Info);
|
assert_eq!(s.logging.client.level, LogLevel::Info);
|
||||||
assert_eq!(s.testing.subnode_index, 0);
|
assert_eq!(s.testing.subnode_index, 0);
|
||||||
|
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
s.core.table_store.directory,
|
s.core.table_store.directory,
|
||||||
Settings::get_default_table_store_path()
|
Settings::get_default_table_store_path()
|
||||||
);
|
);
|
||||||
|
assert_eq!(s.core.table_store.delete, false);
|
||||||
|
|
||||||
|
assert_eq!(
|
||||||
|
s.core.block_store.directory,
|
||||||
|
Settings::get_default_block_store_path()
|
||||||
|
);
|
||||||
|
assert_eq!(s.core.block_store.delete, false);
|
||||||
|
|
||||||
assert_eq!(s.core.protected_store.allow_insecure_fallback, true);
|
assert_eq!(s.core.protected_store.allow_insecure_fallback, true);
|
||||||
assert_eq!(s.core.protected_store.always_use_insecure_storage, false);
|
assert_eq!(s.core.protected_store.always_use_insecure_storage, false);
|
||||||
assert_eq!(
|
assert_eq!(
|
||||||
s.core.protected_store.insecure_fallback_directory,
|
s.core.protected_store.insecure_fallback_directory,
|
||||||
Settings::get_default_protected_store_insecure_fallback_directory()
|
Settings::get_default_protected_store_insecure_fallback_directory()
|
||||||
);
|
);
|
||||||
|
assert_eq!(s.core.protected_store.delete, false);
|
||||||
|
|
||||||
assert_eq!(s.core.network.max_connections, 16);
|
assert_eq!(s.core.network.max_connections, 16);
|
||||||
assert_eq!(s.core.network.connection_initial_timeout, 2_000_000u64);
|
assert_eq!(s.core.network.connection_initial_timeout, 2_000_000u64);
|
||||||
assert_eq!(s.core.network.node_id, veilid_core::DHTKey::default());
|
assert_eq!(s.core.network.node_id, veilid_core::DHTKey::default());
|
||||||
|
Loading…
Reference in New Issue
Block a user