json api work

This commit is contained in:
John Smith 2023-06-03 18:33:27 -04:00
parent 833bb52e23
commit 6a86f2265a
39 changed files with 751 additions and 62 deletions

42
Cargo.lock generated
View File

@ -1678,6 +1678,12 @@ version = "0.3.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0688c2a7f92e427f44895cd63841bff7b29f8d7a1648b9e7e07a4a365b2e1257" checksum = "0688c2a7f92e427f44895cd63841bff7b29f8d7a1648b9e7e07a4a365b2e1257"
[[package]]
name = "dyn-clone"
version = "1.0.11"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "68b0cf012f1230e43cd00ebb729c6bb58707ecfa8ad08b52ef3a4ccd2697fc30"
[[package]] [[package]]
name = "ed25519" name = "ed25519"
version = "1.5.3" version = "1.5.3"
@ -4689,6 +4695,30 @@ dependencies = [
"winapi-util", "winapi-util",
] ]
[[package]]
name = "schemars"
version = "0.8.12"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "02c613288622e5f0c3fdc5dbd4db1c5fbe752746b1d1a56a0630b78fd00de44f"
dependencies = [
"dyn-clone",
"schemars_derive",
"serde",
"serde_json",
]
[[package]]
name = "schemars_derive"
version = "0.8.12"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "109da1e6b197438deb6db99952990c7f959572794b80ff93707d55a232545e7c"
dependencies = [
"proc-macro2",
"quote",
"serde_derive_internals",
"syn 1.0.109",
]
[[package]] [[package]]
name = "scoped-tls" name = "scoped-tls"
version = "1.0.1" version = "1.0.1"
@ -4854,6 +4884,17 @@ dependencies = [
"syn 2.0.18", "syn 2.0.18",
] ]
[[package]]
name = "serde_derive_internals"
version = "0.26.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "85bf8229e7920a9f636479437026331ce11aa132b4dde37d121944a44d6e5f3c"
dependencies = [
"proc-macro2",
"quote",
"syn 1.0.109",
]
[[package]] [[package]]
name = "serde_json" name = "serde_json"
version = "1.0.96" version = "1.0.96"
@ -6212,6 +6253,7 @@ dependencies = [
"rusqlite", "rusqlite",
"rustls 0.19.1", "rustls 0.19.1",
"rustls-pemfile 0.2.1", "rustls-pemfile 0.2.1",
"schemars",
"secrecy", "secrecy",
"send_wrapper 0.6.0", "send_wrapper 0.6.0",
"serde", "serde",

View File

@ -72,6 +72,7 @@ data-encoding = { version = "^2" }
weak-table = "0.3.2" weak-table = "0.3.2"
range-set-blaze = "0.1.5" range-set-blaze = "0.1.5"
argon2 = "0.5.0" argon2 = "0.5.0"
schemars = "0.8.12"
# Dependencies for native builds only # Dependencies for native builds only
# Linux, Windows, Mac, iOS, Android # Linux, Windows, Mac, iOS, Android

View File

@ -500,9 +500,10 @@ struct Question @0xd8510bc33492ef70 {
findBlockQ @9 :OperationFindBlockQ; findBlockQ @9 :OperationFindBlockQ;
# Tunnel operations # Tunnel operations
startTunnelQ @10 :OperationStartTunnelQ; # #[cfg(feature="unstable-tunnels")]
completeTunnelQ @11 :OperationCompleteTunnelQ; # startTunnelQ @10 :OperationStartTunnelQ;
cancelTunnelQ @12 :OperationCancelTunnelQ; # completeTunnelQ @11 :OperationCompleteTunnelQ;
# cancelTunnelQ @12 :OperationCancelTunnelQ;
} }
} }
@ -537,9 +538,10 @@ struct Answer @0xacacb8b6988c1058 {
findBlockA @7 :OperationFindBlockA; findBlockA @7 :OperationFindBlockA;
# Tunnel operations # Tunnel operations
startTunnelA @8 :OperationStartTunnelA; # #[cfg(feature="unstable-tunnels")]
completeTunnelA @9 :OperationCompleteTunnelA; # startTunnelA @8 :OperationStartTunnelA;
cancelTunnelA @10 :OperationCancelTunnelA; # completeTunnelA @9 :OperationCompleteTunnelA;
# cancelTunnelA @10 :OperationCancelTunnelA;
} }
} }

View File

@ -25,11 +25,10 @@ pub use none::*;
#[cfg(feature = "enable-crypto-vld0")] #[cfg(feature = "enable-crypto-vld0")]
pub use vld0::*; pub use vld0::*;
use crate::*; use super::*;
use core::convert::TryInto; use core::convert::TryInto;
use hashlink::linked_hash_map::Entry; use hashlink::linked_hash_map::Entry;
use hashlink::LruCache; use hashlink::LruCache;
use serde::{Deserialize, Serialize};
/// Handle to a particular cryptosystem /// Handle to a particular cryptosystem
pub type CryptoSystemVersion = Arc<dyn CryptoSystem + Send + Sync>; pub type CryptoSystemVersion = Arc<dyn CryptoSystem + Send + Sync>;

View File

@ -47,6 +47,7 @@ use rkyv::{
Archive as RkyvArchive, Deserialize as RkyvDeserialize, Serialize as RkyvSerialize, Archive as RkyvArchive, Deserialize as RkyvDeserialize, Serialize as RkyvSerialize,
}; };
type RkyvDefaultValidator<'t> = rkyv::validation::validators::DefaultValidator<'t>; type RkyvDefaultValidator<'t> = rkyv::validation::validators::DefaultValidator<'t>;
use schemars::{schema_for, JsonSchema};
use serde::*; use serde::*;
pub mod veilid_capnp { pub mod veilid_capnp {

View File

@ -22,6 +22,7 @@ mod signed_relayed_node_info;
mod signed_value_data; mod signed_value_data;
mod signed_value_descriptor; mod signed_value_descriptor;
mod socket_address; mod socket_address;
#[cfg(feature = "unstable-tunnels")]
mod tunnel; mod tunnel;
mod typed_key; mod typed_key;
mod typed_signature; mod typed_signature;
@ -50,6 +51,7 @@ pub use signed_relayed_node_info::*;
pub use signed_value_data::*; pub use signed_value_data::*;
pub use signed_value_descriptor::*; pub use signed_value_descriptor::*;
pub use socket_address::*; pub use socket_address::*;
#[cfg(feature = "unstable-tunnels")]
pub use tunnel::*; pub use tunnel::*;
pub use typed_key::*; pub use typed_key::*;
pub use typed_signature::*; pub use typed_signature::*;

View File

@ -39,8 +39,11 @@ pub enum RPCAnswerDetail {
WatchValueA(RPCOperationWatchValueA), WatchValueA(RPCOperationWatchValueA),
SupplyBlockA(RPCOperationSupplyBlockA), SupplyBlockA(RPCOperationSupplyBlockA),
FindBlockA(RPCOperationFindBlockA), FindBlockA(RPCOperationFindBlockA),
#[cfg(feature = "unstable-tunnels")]
StartTunnelA(RPCOperationStartTunnelA), StartTunnelA(RPCOperationStartTunnelA),
#[cfg(feature = "unstable-tunnels")]
CompleteTunnelA(RPCOperationCompleteTunnelA), CompleteTunnelA(RPCOperationCompleteTunnelA),
#[cfg(feature = "unstable-tunnels")]
CancelTunnelA(RPCOperationCancelTunnelA), CancelTunnelA(RPCOperationCancelTunnelA),
} }
@ -55,8 +58,11 @@ impl RPCAnswerDetail {
RPCAnswerDetail::WatchValueA(_) => "WatchValueA", RPCAnswerDetail::WatchValueA(_) => "WatchValueA",
RPCAnswerDetail::SupplyBlockA(_) => "SupplyBlockA", RPCAnswerDetail::SupplyBlockA(_) => "SupplyBlockA",
RPCAnswerDetail::FindBlockA(_) => "FindBlockA", RPCAnswerDetail::FindBlockA(_) => "FindBlockA",
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::StartTunnelA(_) => "StartTunnelA", RPCAnswerDetail::StartTunnelA(_) => "StartTunnelA",
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::CompleteTunnelA(_) => "CompleteTunnelA", RPCAnswerDetail::CompleteTunnelA(_) => "CompleteTunnelA",
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::CancelTunnelA(_) => "CancelTunnelA", RPCAnswerDetail::CancelTunnelA(_) => "CancelTunnelA",
} }
} }
@ -70,8 +76,11 @@ impl RPCAnswerDetail {
RPCAnswerDetail::WatchValueA(r) => r.validate(validate_context), RPCAnswerDetail::WatchValueA(r) => r.validate(validate_context),
RPCAnswerDetail::SupplyBlockA(r) => r.validate(validate_context), RPCAnswerDetail::SupplyBlockA(r) => r.validate(validate_context),
RPCAnswerDetail::FindBlockA(r) => r.validate(validate_context), RPCAnswerDetail::FindBlockA(r) => r.validate(validate_context),
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::StartTunnelA(r) => r.validate(validate_context), RPCAnswerDetail::StartTunnelA(r) => r.validate(validate_context),
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::CompleteTunnelA(r) => r.validate(validate_context), RPCAnswerDetail::CompleteTunnelA(r) => r.validate(validate_context),
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::CancelTunnelA(r) => r.validate(validate_context), RPCAnswerDetail::CancelTunnelA(r) => r.validate(validate_context),
} }
} }
@ -120,16 +129,19 @@ impl RPCAnswerDetail {
let out = RPCOperationFindBlockA::decode(&op_reader)?; let out = RPCOperationFindBlockA::decode(&op_reader)?;
RPCAnswerDetail::FindBlockA(out) RPCAnswerDetail::FindBlockA(out)
} }
#[cfg(feature = "unstable-tunnels")]
veilid_capnp::answer::detail::StartTunnelA(r) => { veilid_capnp::answer::detail::StartTunnelA(r) => {
let op_reader = r.map_err(RPCError::protocol)?; let op_reader = r.map_err(RPCError::protocol)?;
let out = RPCOperationStartTunnelA::decode(&op_reader)?; let out = RPCOperationStartTunnelA::decode(&op_reader)?;
RPCAnswerDetail::StartTunnelA(out) RPCAnswerDetail::StartTunnelA(out)
} }
#[cfg(feature = "unstable-tunnels")]
veilid_capnp::answer::detail::CompleteTunnelA(r) => { veilid_capnp::answer::detail::CompleteTunnelA(r) => {
let op_reader = r.map_err(RPCError::protocol)?; let op_reader = r.map_err(RPCError::protocol)?;
let out = RPCOperationCompleteTunnelA::decode(&op_reader)?; let out = RPCOperationCompleteTunnelA::decode(&op_reader)?;
RPCAnswerDetail::CompleteTunnelA(out) RPCAnswerDetail::CompleteTunnelA(out)
} }
#[cfg(feature = "unstable-tunnels")]
veilid_capnp::answer::detail::CancelTunnelA(r) => { veilid_capnp::answer::detail::CancelTunnelA(r) => {
let op_reader = r.map_err(RPCError::protocol)?; let op_reader = r.map_err(RPCError::protocol)?;
let out = RPCOperationCancelTunnelA::decode(&op_reader)?; let out = RPCOperationCancelTunnelA::decode(&op_reader)?;
@ -155,12 +167,15 @@ impl RPCAnswerDetail {
d.encode(&mut builder.reborrow().init_supply_block_a()) d.encode(&mut builder.reborrow().init_supply_block_a())
} }
RPCAnswerDetail::FindBlockA(d) => d.encode(&mut builder.reborrow().init_find_block_a()), RPCAnswerDetail::FindBlockA(d) => d.encode(&mut builder.reborrow().init_find_block_a()),
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::StartTunnelA(d) => { RPCAnswerDetail::StartTunnelA(d) => {
d.encode(&mut builder.reborrow().init_start_tunnel_a()) d.encode(&mut builder.reborrow().init_start_tunnel_a())
} }
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::CompleteTunnelA(d) => { RPCAnswerDetail::CompleteTunnelA(d) => {
d.encode(&mut builder.reborrow().init_complete_tunnel_a()) d.encode(&mut builder.reborrow().init_complete_tunnel_a())
} }
#[cfg(feature = "unstable-tunnels")]
RPCAnswerDetail::CancelTunnelA(d) => { RPCAnswerDetail::CancelTunnelA(d) => {
d.encode(&mut builder.reborrow().init_cancel_tunnel_a()) d.encode(&mut builder.reborrow().init_cancel_tunnel_a())
} }

View File

@ -2,8 +2,6 @@ mod answer;
mod operation; mod operation;
mod operation_app_call; mod operation_app_call;
mod operation_app_message; mod operation_app_message;
mod operation_cancel_tunnel;
mod operation_complete_tunnel;
mod operation_find_block; mod operation_find_block;
mod operation_find_node; mod operation_find_node;
mod operation_get_value; mod operation_get_value;
@ -11,7 +9,6 @@ mod operation_return_receipt;
mod operation_route; mod operation_route;
mod operation_set_value; mod operation_set_value;
mod operation_signal; mod operation_signal;
mod operation_start_tunnel;
mod operation_status; mod operation_status;
mod operation_supply_block; mod operation_supply_block;
mod operation_validate_dial_info; mod operation_validate_dial_info;
@ -21,12 +18,17 @@ mod question;
mod respond_to; mod respond_to;
mod statement; mod statement;
#[cfg(feature = "unstable-tunnels")]
mod operation_cancel_tunnel;
#[cfg(feature = "unstable-tunnels")]
mod operation_complete_tunnel;
#[cfg(feature = "unstable-tunnels")]
mod operation_start_tunnel;
pub use answer::*; pub use answer::*;
pub use operation::*; pub use operation::*;
pub use operation_app_call::*; pub use operation_app_call::*;
pub use operation_app_message::*; pub use operation_app_message::*;
pub use operation_cancel_tunnel::*;
pub use operation_complete_tunnel::*;
pub use operation_find_block::*; pub use operation_find_block::*;
pub use operation_find_node::*; pub use operation_find_node::*;
pub use operation_get_value::*; pub use operation_get_value::*;
@ -34,7 +36,6 @@ pub use operation_return_receipt::*;
pub use operation_route::*; pub use operation_route::*;
pub use operation_set_value::*; pub use operation_set_value::*;
pub use operation_signal::*; pub use operation_signal::*;
pub use operation_start_tunnel::*;
pub use operation_status::*; pub use operation_status::*;
pub use operation_supply_block::*; pub use operation_supply_block::*;
pub use operation_validate_dial_info::*; pub use operation_validate_dial_info::*;
@ -44,4 +45,11 @@ pub use question::*;
pub use respond_to::*; pub use respond_to::*;
pub use statement::*; pub use statement::*;
#[cfg(feature = "unstable-tunnels")]
pub use operation_cancel_tunnel::*;
#[cfg(feature = "unstable-tunnels")]
pub use operation_complete_tunnel::*;
#[cfg(feature = "unstable-tunnels")]
pub use operation_start_tunnel::*;
use super::*; use super::*;

View File

@ -1,5 +1,6 @@
use super::*; use super::*;
#[cfg(feature = "unstable-tunnels")]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct RPCOperationCancelTunnelQ { pub struct RPCOperationCancelTunnelQ {
id: TunnelId, id: TunnelId,
@ -37,6 +38,7 @@ impl RPCOperationCancelTunnelQ {
} }
} }
#[cfg(feature = "unstable-tunnels")]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub enum RPCOperationCancelTunnelA { pub enum RPCOperationCancelTunnelA {
Tunnel(TunnelId), Tunnel(TunnelId),

View File

@ -1,5 +1,6 @@
use super::*; use super::*;
#[cfg(feature = "unstable-tunnels")]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct RPCOperationCompleteTunnelQ { pub struct RPCOperationCompleteTunnelQ {
id: TunnelId, id: TunnelId,
@ -74,6 +75,7 @@ impl RPCOperationCompleteTunnelQ {
} }
} }
#[cfg(feature = "unstable-tunnels")]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub enum RPCOperationCompleteTunnelA { pub enum RPCOperationCompleteTunnelA {
Tunnel(FullTunnel), Tunnel(FullTunnel),

View File

@ -1,5 +1,6 @@
use super::*; use super::*;
#[cfg(feature = "unstable-tunnels")]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub struct RPCOperationStartTunnelQ { pub struct RPCOperationStartTunnelQ {
id: TunnelId, id: TunnelId,
@ -64,6 +65,7 @@ impl RPCOperationStartTunnelQ {
} }
} }
#[cfg(feature = "unstable-tunnels")]
#[derive(Debug, Clone)] #[derive(Debug, Clone)]
pub enum RPCOperationStartTunnelA { pub enum RPCOperationStartTunnelA {
Partial(PartialTunnel), Partial(PartialTunnel),

View File

@ -51,8 +51,11 @@ pub enum RPCQuestionDetail {
WatchValueQ(RPCOperationWatchValueQ), WatchValueQ(RPCOperationWatchValueQ),
SupplyBlockQ(RPCOperationSupplyBlockQ), SupplyBlockQ(RPCOperationSupplyBlockQ),
FindBlockQ(RPCOperationFindBlockQ), FindBlockQ(RPCOperationFindBlockQ),
#[cfg(feature = "unstable-tunnels")]
StartTunnelQ(RPCOperationStartTunnelQ), StartTunnelQ(RPCOperationStartTunnelQ),
#[cfg(feature = "unstable-tunnels")]
CompleteTunnelQ(RPCOperationCompleteTunnelQ), CompleteTunnelQ(RPCOperationCompleteTunnelQ),
#[cfg(feature = "unstable-tunnels")]
CancelTunnelQ(RPCOperationCancelTunnelQ), CancelTunnelQ(RPCOperationCancelTunnelQ),
} }
@ -67,8 +70,11 @@ impl RPCQuestionDetail {
RPCQuestionDetail::WatchValueQ(_) => "WatchValueQ", RPCQuestionDetail::WatchValueQ(_) => "WatchValueQ",
RPCQuestionDetail::SupplyBlockQ(_) => "SupplyBlockQ", RPCQuestionDetail::SupplyBlockQ(_) => "SupplyBlockQ",
RPCQuestionDetail::FindBlockQ(_) => "FindBlockQ", RPCQuestionDetail::FindBlockQ(_) => "FindBlockQ",
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::StartTunnelQ(_) => "StartTunnelQ", RPCQuestionDetail::StartTunnelQ(_) => "StartTunnelQ",
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CompleteTunnelQ(_) => "CompleteTunnelQ", RPCQuestionDetail::CompleteTunnelQ(_) => "CompleteTunnelQ",
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CancelTunnelQ(_) => "CancelTunnelQ", RPCQuestionDetail::CancelTunnelQ(_) => "CancelTunnelQ",
} }
} }
@ -82,8 +88,11 @@ impl RPCQuestionDetail {
RPCQuestionDetail::WatchValueQ(r) => r.validate(validate_context), RPCQuestionDetail::WatchValueQ(r) => r.validate(validate_context),
RPCQuestionDetail::SupplyBlockQ(r) => r.validate(validate_context), RPCQuestionDetail::SupplyBlockQ(r) => r.validate(validate_context),
RPCQuestionDetail::FindBlockQ(r) => r.validate(validate_context), RPCQuestionDetail::FindBlockQ(r) => r.validate(validate_context),
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::StartTunnelQ(r) => r.validate(validate_context), RPCQuestionDetail::StartTunnelQ(r) => r.validate(validate_context),
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CompleteTunnelQ(r) => r.validate(validate_context), RPCQuestionDetail::CompleteTunnelQ(r) => r.validate(validate_context),
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CancelTunnelQ(r) => r.validate(validate_context), RPCQuestionDetail::CancelTunnelQ(r) => r.validate(validate_context),
} }
} }
@ -133,16 +142,19 @@ impl RPCQuestionDetail {
let out = RPCOperationFindBlockQ::decode(&op_reader)?; let out = RPCOperationFindBlockQ::decode(&op_reader)?;
RPCQuestionDetail::FindBlockQ(out) RPCQuestionDetail::FindBlockQ(out)
} }
#[cfg(feature = "unstable-tunnels")]
veilid_capnp::question::detail::StartTunnelQ(r) => { veilid_capnp::question::detail::StartTunnelQ(r) => {
let op_reader = r.map_err(RPCError::protocol)?; let op_reader = r.map_err(RPCError::protocol)?;
let out = RPCOperationStartTunnelQ::decode(&op_reader)?; let out = RPCOperationStartTunnelQ::decode(&op_reader)?;
RPCQuestionDetail::StartTunnelQ(out) RPCQuestionDetail::StartTunnelQ(out)
} }
#[cfg(feature = "unstable-tunnels")]
veilid_capnp::question::detail::CompleteTunnelQ(r) => { veilid_capnp::question::detail::CompleteTunnelQ(r) => {
let op_reader = r.map_err(RPCError::protocol)?; let op_reader = r.map_err(RPCError::protocol)?;
let out = RPCOperationCompleteTunnelQ::decode(&op_reader)?; let out = RPCOperationCompleteTunnelQ::decode(&op_reader)?;
RPCQuestionDetail::CompleteTunnelQ(out) RPCQuestionDetail::CompleteTunnelQ(out)
} }
#[cfg(feature = "unstable-tunnels")]
veilid_capnp::question::detail::CancelTunnelQ(r) => { veilid_capnp::question::detail::CancelTunnelQ(r) => {
let op_reader = r.map_err(RPCError::protocol)?; let op_reader = r.map_err(RPCError::protocol)?;
let out = RPCOperationCancelTunnelQ::decode(&op_reader)?; let out = RPCOperationCancelTunnelQ::decode(&op_reader)?;
@ -170,12 +182,15 @@ impl RPCQuestionDetail {
RPCQuestionDetail::FindBlockQ(d) => { RPCQuestionDetail::FindBlockQ(d) => {
d.encode(&mut builder.reborrow().init_find_block_q()) d.encode(&mut builder.reborrow().init_find_block_q())
} }
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::StartTunnelQ(d) => { RPCQuestionDetail::StartTunnelQ(d) => {
d.encode(&mut builder.reborrow().init_start_tunnel_q()) d.encode(&mut builder.reborrow().init_start_tunnel_q())
} }
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CompleteTunnelQ(d) => { RPCQuestionDetail::CompleteTunnelQ(d) => {
d.encode(&mut builder.reborrow().init_complete_tunnel_q()) d.encode(&mut builder.reborrow().init_complete_tunnel_q())
} }
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CancelTunnelQ(d) => { RPCQuestionDetail::CancelTunnelQ(d) => {
d.encode(&mut builder.reborrow().init_cancel_tunnel_q()) d.encode(&mut builder.reborrow().init_cancel_tunnel_q())
} }

View File

@ -4,8 +4,6 @@ mod fanout_call;
mod operation_waiter; mod operation_waiter;
mod rpc_app_call; mod rpc_app_call;
mod rpc_app_message; mod rpc_app_message;
mod rpc_cancel_tunnel;
mod rpc_complete_tunnel;
mod rpc_error; mod rpc_error;
mod rpc_find_block; mod rpc_find_block;
mod rpc_find_node; mod rpc_find_node;
@ -14,13 +12,19 @@ mod rpc_return_receipt;
mod rpc_route; mod rpc_route;
mod rpc_set_value; mod rpc_set_value;
mod rpc_signal; mod rpc_signal;
mod rpc_start_tunnel;
mod rpc_status; mod rpc_status;
mod rpc_supply_block; mod rpc_supply_block;
mod rpc_validate_dial_info; mod rpc_validate_dial_info;
mod rpc_value_changed; mod rpc_value_changed;
mod rpc_watch_value; mod rpc_watch_value;
#[cfg(feature = "unstable-tunnels")]
mod rpc_cancel_tunnel;
#[cfg(feature = "unstable-tunnels")]
mod rpc_complete_tunnel;
#[cfg(feature = "unstable-tunnels")]
mod rpc_start_tunnel;
pub use coders::*; pub use coders::*;
pub use destination::*; pub use destination::*;
pub use fanout_call::*; pub use fanout_call::*;
@ -1410,8 +1414,11 @@ impl RPCProcessor {
RPCQuestionDetail::WatchValueQ(_) => self.process_watch_value_q(msg).await, RPCQuestionDetail::WatchValueQ(_) => self.process_watch_value_q(msg).await,
RPCQuestionDetail::SupplyBlockQ(_) => self.process_supply_block_q(msg).await, RPCQuestionDetail::SupplyBlockQ(_) => self.process_supply_block_q(msg).await,
RPCQuestionDetail::FindBlockQ(_) => self.process_find_block_q(msg).await, RPCQuestionDetail::FindBlockQ(_) => self.process_find_block_q(msg).await,
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::StartTunnelQ(_) => self.process_start_tunnel_q(msg).await, RPCQuestionDetail::StartTunnelQ(_) => self.process_start_tunnel_q(msg).await,
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CompleteTunnelQ(_) => self.process_complete_tunnel_q(msg).await, RPCQuestionDetail::CompleteTunnelQ(_) => self.process_complete_tunnel_q(msg).await,
#[cfg(feature = "unstable-tunnels")]
RPCQuestionDetail::CancelTunnelQ(_) => self.process_cancel_tunnel_q(msg).await, RPCQuestionDetail::CancelTunnelQ(_) => self.process_cancel_tunnel_q(msg).await,
}, },
RPCOperationKind::Statement(s) => match s.detail() { RPCOperationKind::Statement(s) => match s.detail() {

View File

@ -268,6 +268,7 @@ impl VeilidAPI {
//////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////
// Tunnel Building // Tunnel Building
#[cfg(feature = "unstable-tunnels")]
#[instrument(level = "debug", err, skip(self))] #[instrument(level = "debug", err, skip(self))]
pub async fn start_tunnel( pub async fn start_tunnel(
&self, &self,
@ -277,6 +278,7 @@ impl VeilidAPI {
panic!("unimplemented"); panic!("unimplemented");
} }
#[cfg(feature = "unstable-tunnels")]
#[instrument(level = "debug", err, skip(self))] #[instrument(level = "debug", err, skip(self))]
pub async fn complete_tunnel( pub async fn complete_tunnel(
&self, &self,
@ -287,6 +289,7 @@ impl VeilidAPI {
panic!("unimplemented"); panic!("unimplemented");
} }
#[cfg(feature = "unstable-tunnels")]
#[instrument(level = "debug", err, skip(self))] #[instrument(level = "debug", err, skip(self))]
pub async fn cancel_tunnel(&self, _tunnel_id: TunnelId) -> VeilidAPIResult<bool> { pub async fn cancel_tunnel(&self, _tunnel_id: TunnelId) -> VeilidAPIResult<bool> {
panic!("unimplemented"); panic!("unimplemented");

View File

@ -117,6 +117,7 @@ macro_rules! apibail_already_initialized {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
#[serde(tag = "kind")] #[serde(tag = "kind")]
@ -136,7 +137,10 @@ pub enum VeilidAPIError {
#[error("No connection: {message}")] #[error("No connection: {message}")]
NoConnection { message: String }, NoConnection { message: String },
#[error("Key not found: {key}")] #[error("Key not found: {key}")]
KeyNotFound { key: TypedKey }, KeyNotFound {
#[schemars(with="String")]
key: TypedKey
},
#[error("Internal: {message}")] #[error("Internal: {message}")]
Internal { message: String }, Internal { message: String },
#[error("Unimplemented: {message}")] #[error("Unimplemented: {message}")]

View File

@ -0,0 +1,66 @@
use super::*;
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct CryptoSystemRequest {
cs_id: String,
#[serde(flatten)]
cs_op: CryptoSystemRequestOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct CryptoSystemResponse {
cs_id: String,
#[serde(flatten)]
cs_op: CryptoSystemResponseOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "cs_op")]
pub enum CryptoSystemRequestOp {
Release,
CachedDh,
ComputeDh,
RandomBytes,
DefaultSaltLength,
HashPassword,
VerifyPassword,
DeriveSharedSecret,
RandomNonce,
RandomSharedSecret,
GenerateKeyPair,
GenerateHash,
ValidateKeyPair,
ValidateHash,
Distance,
Sign,
Verify,
AeadOverhead,
DecryptAead,
EncryptAead,
CryptNoAuth,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "cs_op")]
pub enum CryptoSystemResponseOp {
Release,
CachedDh,
ComputeDh,
RandomBytes,
DefaultSaltLength,
HashPassword,
VerifyPassword,
DeriveSharedSecret,
RandomNonce,
RandomSharedSecret,
GenerateKeyPair,
GenerateHash,
ValidateKeyPair,
ValidateHash,
Distance,
Sign,
Verify,
AeadOverhead,
DecryptAead,
EncryptAead,
CryptNoAuth,
}

View File

@ -0,0 +1,203 @@
use super::*;
mod routing_context;
pub use routing_context::*;
mod table_db;
pub use table_db::*;
mod crypto_system;
pub use crypto_system::*;
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct Request {
/// Operation Id (pairs with Response)
id: String,
/// The request operation variant
#[serde(flatten)]
op: RequestOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct Response {
/// Operation Id (pairs with Request)
id: String,
/// The response operation variant
#[serde(flatten)]
op: ResponseOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "op")]
pub enum RequestOp {
GetState,
Attach,
Detach,
NewPrivateRoute,
NewCustomPrivateRoute {
#[schemars(with = "Vec<String>")]
crypto_kinds: Vec<CryptoKind>,
#[serde(default)]
stability: Stability,
#[serde(default)]
sequencing: Sequencing,
},
ImportRemotePrivateRoute {
#[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
blob: Vec<u8>,
},
ReleasePrivateRoute {
#[schemars(with = "String")]
route_id: RouteId,
},
AppCallReply {
#[schemars(with = "String")]
call_id: OperationId,
#[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
message: Vec<u8>,
},
// Routing Context
NewRoutingContext,
RoutingContext(RoutingContextRequest),
// TableDb
OpenTableDb {
name: String,
column_count: u32,
},
DeleteTableDb {
name: String,
},
TableDb(TableDbRequest),
// Crypto
GetCryptoSystem {
#[schemars(with = "String")]
crypto_kind: CryptoKind,
},
BestCryptoSystem,
CryptoSystem(CryptoSystemRequest),
VerifySignatures {
#[schemars(with = "Vec<String>")]
node_ids: Vec<TypedKey>,
#[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
data: Vec<u8>,
#[schemars(with = "Vec<String>")]
signatures: Vec<TypedSignature>,
},
GenerateSignatures {
#[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
data: Vec<u8>,
#[schemars(with = "Vec<String>")]
key_pairs: Vec<TypedKeyPair>,
},
GenerateKeyPair {
#[schemars(with = "String")]
crypto_kind: CryptoKind,
},
// Misc
Now,
Debug {
command: String,
},
VeilidVersionString,
VeilidVersion,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct NewPrivateRouteResult {
#[schemars(with = "String")]
route_id: RouteId,
#[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
blob: Vec<u8>,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "op")]
pub enum ResponseOp {
GetState {
#[serde(flatten)]
result: ApiResult<VeilidState>,
},
Attach {
#[serde(flatten)]
result: ApiResult<()>,
},
Detach {
#[serde(flatten)]
result: ApiResult<()>,
},
NewPrivateRoute {
#[serde(flatten)]
result: ApiResult<NewPrivateRouteResult>,
},
NewCustomPrivateRoute {
#[serde(flatten)]
result: ApiResult<NewPrivateRouteResult>,
},
ImportRemotePrivateRoute,
ReleasePrivateRoute,
AppCallReply,
// Routing Context
NewRoutingContext,
RoutingContext(RoutingContextResponse),
// TableDb
OpenTableDb,
DeleteTableDb,
TableDb(TableDbResponse),
// Crypto
GetCryptoSystem,
BestCryptoSystem,
CryptoSystem(CryptoSystemResponse),
VerifySignatures,
GenerateSignatures,
GenerateKeyPair,
// Misc
Now,
Debug,
VeilidVersionString,
VeilidVersion,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(untagged)]
pub enum ApiResult<T>
where
T: Clone + fmt::Debug + JsonSchema,
{
Ok { value: T },
Err { error: VeilidAPIError },
}
pub fn emit_schemas(out: &mut HashMap<String, String>) {
let schema_request = schema_for!(Request);
let schema_response = schema_for!(Response);
out.insert(
"Request".to_owned(),
serde_json::to_string_pretty(&schema_request).unwrap(),
);
out.insert(
"Response".to_owned(),
serde_json::to_string_pretty(&schema_response).unwrap(),
);
}

View File

@ -0,0 +1,52 @@
use super::*;
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct RoutingContextRequest {
rc_id: String,
#[serde(flatten)]
rc_op: RoutingContextRequestOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct RoutingContextResponse {
rc_id: String,
#[serde(flatten)]
rc_op: RoutingContextResponseOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "rc_op")]
pub enum RoutingContextRequestOp {
Release,
WithPrivacy,
WithCustomPrivacy,
WithSequencing,
AppCall,
AppMessage,
CreateDhtRecord,
OpenDhtRecord,
CloseDhtRecord,
DeleteDhtRecord,
GetDhtValue,
SetDhtValue,
WatchDhtValues,
CancelDhtWatch,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "rc_op")]
pub enum RoutingContextResponseOp {
Release,
WithPrivacy,
WithCustomPrivacy,
WithSequencing,
AppCall,
AppMessage,
CreateDhtRecord,
OpenDhtRecord,
CloseDhtRecord,
DeleteDhtRecord,
GetDhtValue,
SetDhtValue,
WatchDhtValues,
CancelDhtWatch,
}

View File

@ -0,0 +1,26 @@
use super::*;
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct TableDbRequest {
db_id: String,
#[serde(flatten)]
db_op: TableDbRequestOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
pub struct TableDbResponse {
db_id: String,
#[serde(flatten)]
db_op: TableDbResponseOp,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "db_op")]
pub enum TableDbRequestOp {
Release,
}
#[derive(Debug, Clone, Serialize, Deserialize, JsonSchema)]
#[serde(tag = "db_op")]
pub enum TableDbResponseOp {
Release,
}

View File

@ -3,6 +3,7 @@
mod api; mod api;
mod debug; mod debug;
mod error; mod error;
mod json_api;
mod routing_context; mod routing_context;
mod serialize_helpers; mod serialize_helpers;
mod types; mod types;
@ -12,6 +13,7 @@ pub mod tests;
pub use api::*; pub use api::*;
pub use debug::*; pub use debug::*;
pub use error::*; pub use error::*;
pub use json_api::*;
pub use routing_context::*; pub use routing_context::*;
pub use serialize_helpers::*; pub use serialize_helpers::*;
pub use types::*; pub use types::*;

View File

@ -9,11 +9,10 @@ pub fn serialize<T: Integer + Serialize, S: Serializer>(
v: &RangeSetBlaze<T>, v: &RangeSetBlaze<T>,
s: S, s: S,
) -> Result<S::Ok, S::Error> { ) -> Result<S::Ok, S::Error> {
let cnt = v.ranges_len() * 2; let cnt = v.ranges_len();
let mut seq = s.serialize_seq(Some(cnt))?; let mut seq = s.serialize_seq(Some(cnt))?;
for range in v.ranges() { for range in v.ranges() {
seq.serialize_element(range.start())?; seq.serialize_element(&(range.start(), range.end()))?;
seq.serialize_element(range.end())?;
} }
seq.end() seq.end()
} }
@ -41,10 +40,7 @@ pub fn deserialize<'de, T: Integer + Deserialize<'de>, D: Deserializer<'de>>(
{ {
let mut values = RangeSetBlaze::<T>::new(); let mut values = RangeSetBlaze::<T>::new();
while let Some(start) = seq.next_element()? { while let Some((start, end)) = seq.next_element()? {
let Some(end) = seq.next_element()? else {
break;
};
values.ranges_insert(start..=end); values.ranges_insert(start..=end);
} }

View File

@ -18,10 +18,19 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[repr(C, align(8))] #[repr(C, align(8))]
#[archive_attr(repr(C, align(8)), derive(CheckBytes))] #[archive_attr(repr(C, align(8)), derive(CheckBytes))]
pub struct AlignedU64(u64); #[serde(transparent)]
pub struct AlignedU64(
#[serde(
serialize_with = "json_as_string::serialize",
deserialize_with = "json_as_string::deserialize"
)]
#[schemars(with = "String")]
u64,
);
impl From<u64> for AlignedU64 { impl From<u64> for AlignedU64 {
fn from(v: u64) -> Self { fn from(v: u64) -> Self {

View File

@ -2,15 +2,33 @@ use super::*;
/// Direct statement blob passed to hosting application for processing /// Direct statement blob passed to hosting application for processing
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidAppMessage { pub struct VeilidAppMessage {
/// Some(sender) if the message was sent directly, None if received via a private/safety route /// Some(sender) if the message was sent directly, None if received via a private/safety route
#[serde(with = "opt_json_as_string")] #[serde(
serialize_with = "opt_json_as_string::serialize",
deserialize_with = "opt_json_as_string::deserialize"
)]
#[schemars(with = "Option<String>")]
sender: Option<TypedKey>, sender: Option<TypedKey>,
/// The content of the message to deliver to the application /// The content of the message to deliver to the application
#[serde(with = "json_as_base64")] #[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
message: Vec<u8>, message: Vec<u8>,
} }
@ -29,18 +47,41 @@ impl VeilidAppMessage {
/// Direct question blob passed to hosting application for processing to send an eventual AppReply /// Direct question blob passed to hosting application for processing to send an eventual AppReply
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidAppCall { pub struct VeilidAppCall {
/// Some(sender) if the request was sent directly, None if received via a private/safety route /// Some(sender) if the request was sent directly, None if received via a private/safety route
#[serde(with = "opt_json_as_string")] #[serde(
serialize_with = "opt_json_as_string::serialize",
deserialize_with = "opt_json_as_string::deserialize"
)]
#[schemars(with = "Option<String>")]
sender: Option<TypedKey>, sender: Option<TypedKey>,
/// The content of the request to deliver to the application /// The content of the request to deliver to the application
#[serde(with = "json_as_base64")] #[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
message: Vec<u8>, message: Vec<u8>,
/// The id to reply to /// The id to reply to
#[serde(with = "json_as_string")] #[serde(
serialize_with = "json_as_string::serialize",
deserialize_with = "json_as_string::deserialize"
)]
#[schemars(with = "String")]
id: OperationId, id: OperationId,
} }

View File

@ -13,15 +13,19 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct DHTRecordDescriptor { pub struct DHTRecordDescriptor {
/// DHT Key = Hash(ownerKeyKind) of: [ ownerKeyValue, schema ] /// DHT Key = Hash(ownerKeyKind) of: [ ownerKeyValue, schema ]
#[schemars(with = "String")]
key: TypedKey, key: TypedKey,
/// The public key of the owner /// The public key of the owner
#[schemars(with = "String")]
owner: PublicKey, owner: PublicKey,
/// If this key is being created: Some(the secret key of the owner) /// If this key is being created: Some(the secret key of the owner)
/// If this key is just being opened: None /// If this key is just being opened: None
#[schemars(with = "Option<String>")]
owner_secret: Option<SecretKey>, owner_secret: Option<SecretKey>,
/// The schema in use associated with the key /// The schema in use associated with the key
schema: DHTSchema, schema: DHTSchema,

View File

@ -13,6 +13,7 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct DHTSchemaDFLT { pub struct DHTSchemaDFLT {

View File

@ -19,6 +19,7 @@ pub use smpl::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
#[serde(tag = "kind")] #[serde(tag = "kind")]

View File

@ -13,10 +13,12 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct DHTSchemaSMPLMember { pub struct DHTSchemaSMPLMember {
/// Member key /// Member key
#[schemars(with = "String")]
pub m_key: PublicKey, pub m_key: PublicKey,
/// Member subkey count /// Member subkey count
pub m_cnt: u16, pub m_cnt: u16,
@ -35,6 +37,7 @@ pub struct DHTSchemaSMPLMember {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct DHTSchemaSMPL { pub struct DHTSchemaSMPL {

View File

@ -13,11 +13,23 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct ValueData { pub struct ValueData {
/// An increasing sequence number to time-order the DHT record changes
seq: ValueSeqNum, seq: ValueSeqNum,
/// The contents of a DHT Record
#[serde(
serialize_with = "json_as_base64::serialize",
deserialize_with = "json_as_base64::deserialize"
)]
#[schemars(with = "String")]
data: Vec<u8>, data: Vec<u8>,
/// The public identity key of the writer of the data
#[schemars(with = "String")]
writer: PublicKey, writer: PublicKey,
} }
impl ValueData { impl ValueData {

View File

@ -15,11 +15,16 @@ use range_set_blaze::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct ValueSubkeyRangeSet { pub struct ValueSubkeyRangeSet {
#[with(RkyvRangeSetBlaze)] #[with(RkyvRangeSetBlaze)]
#[serde(with = "serialize_range_set_blaze")] #[serde(
serialize_with = "serialize_range_set_blaze::serialize",
deserialize_with = "serialize_range_set_blaze::deserialize"
)]
#[schemars(with = "Vec<(u32,u32)>")]
data: RangeSetBlaze<ValueSubkey>, data: RangeSetBlaze<ValueSubkey>,
} }

View File

@ -15,8 +15,11 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes, PartialOrd, Ord, PartialEq, Eq, Hash))] #[archive_attr(repr(C), derive(CheckBytes, PartialOrd, Ord, PartialEq, Eq, Hash))]
#[serde(try_from = "String")]
#[serde(into = "String")]
pub struct FourCC(pub [u8; 4]); pub struct FourCC(pub [u8; 4]);
impl From<[u8; 4]> for FourCC { impl From<[u8; 4]> for FourCC {
@ -37,6 +40,12 @@ impl From<FourCC> for u32 {
} }
} }
impl From<FourCC> for String {
fn from(u: FourCC) -> Self {
String::from_utf8_lossy(&u.0).to_string()
}
}
impl TryFrom<&[u8]> for FourCC { impl TryFrom<&[u8]> for FourCC {
type Error = VeilidAPIError; type Error = VeilidAPIError;
fn try_from(b: &[u8]) -> Result<Self, Self::Error> { fn try_from(b: &[u8]) -> Result<Self, Self::Error> {
@ -44,6 +53,13 @@ impl TryFrom<&[u8]> for FourCC {
} }
} }
impl TryFrom<String> for FourCC {
type Error = VeilidAPIError;
fn try_from(s: String) -> Result<Self, Self::Error> {
Self::from_str(s.as_str())
}
}
impl fmt::Display for FourCC { impl fmt::Display for FourCC {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> {
write!(f, "{}", String::from_utf8_lossy(&self.0)) write!(f, "{}", String::from_utf8_lossy(&self.0))

View File

@ -4,6 +4,7 @@ mod dht;
mod fourcc; mod fourcc;
mod safety; mod safety;
mod stats; mod stats;
#[cfg(feature = "unstable-tunnels")]
mod tunnel; mod tunnel;
mod veilid_log; mod veilid_log;
mod veilid_state; mod veilid_state;
@ -16,6 +17,7 @@ pub use dht::*;
pub use fourcc::*; pub use fourcc::*;
pub use safety::*; pub use safety::*;
pub use stats::*; pub use stats::*;
#[cfg(feature = "unstable-tunnels")]
pub use tunnel::*; pub use tunnel::*;
pub use veilid_log::*; pub use veilid_log::*;
pub use veilid_state::*; pub use veilid_state::*;

View File

@ -15,6 +15,7 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum Sequencing { pub enum Sequencing {
@ -44,6 +45,7 @@ impl Default for Sequencing {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum Stability { pub enum Stability {
@ -72,6 +74,7 @@ impl Default for Stability {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum SafetySelection { pub enum SafetySelection {
@ -111,10 +114,12 @@ impl Default for SafetySelection {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct SafetySpec { pub struct SafetySpec {
/// preferred safety route set id if it still exists /// preferred safety route set id if it still exists
#[schemars(with = "Option<String>")]
pub preferred_route: Option<RouteId>, pub preferred_route: Option<RouteId>,
/// must be greater than 0 /// must be greater than 0
pub hop_count: usize, pub hop_count: usize,

View File

@ -11,14 +11,12 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct LatencyStats { pub struct LatencyStats {
#[serde(with = "json_as_string")]
pub fastest: TimestampDuration, // fastest latency in the ROLLING_LATENCIES_SIZE last latencies pub fastest: TimestampDuration, // fastest latency in the ROLLING_LATENCIES_SIZE last latencies
#[serde(with = "json_as_string")]
pub average: TimestampDuration, // average latency over the ROLLING_LATENCIES_SIZE last latencies pub average: TimestampDuration, // average latency over the ROLLING_LATENCIES_SIZE last latencies
#[serde(with = "json_as_string")]
pub slowest: TimestampDuration, // slowest latency in the ROLLING_LATENCIES_SIZE last latencies pub slowest: TimestampDuration, // slowest latency in the ROLLING_LATENCIES_SIZE last latencies
} }
@ -33,16 +31,13 @@ pub struct LatencyStats {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct TransferStats { pub struct TransferStats {
#[serde(with = "json_as_string")]
pub total: ByteCount, // total amount transferred ever pub total: ByteCount, // total amount transferred ever
#[serde(with = "json_as_string")]
pub maximum: ByteCount, // maximum rate over the ROLLING_TRANSFERS_SIZE last amounts pub maximum: ByteCount, // maximum rate over the ROLLING_TRANSFERS_SIZE last amounts
#[serde(with = "json_as_string")]
pub average: ByteCount, // average rate over the ROLLING_TRANSFERS_SIZE last amounts pub average: ByteCount, // average rate over the ROLLING_TRANSFERS_SIZE last amounts
#[serde(with = "json_as_string")]
pub minimum: ByteCount, // minimum rate over the ROLLING_TRANSFERS_SIZE last amounts pub minimum: ByteCount, // minimum rate over the ROLLING_TRANSFERS_SIZE last amounts
} }
@ -57,6 +52,7 @@ pub struct TransferStats {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct TransferStatsDownUp { pub struct TransferStatsDownUp {
@ -75,17 +71,15 @@ pub struct TransferStatsDownUp {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct RPCStats { pub struct RPCStats {
pub messages_sent: u32, // number of rpcs that have been sent in the total_time range pub messages_sent: u32, // number of rpcs that have been sent in the total_time range
pub messages_rcvd: u32, // number of rpcs that have been received in the total_time range pub messages_rcvd: u32, // number of rpcs that have been received in the total_time range
pub questions_in_flight: u32, // number of questions issued that have yet to be answered pub questions_in_flight: u32, // number of questions issued that have yet to be answered
#[serde(with = "opt_json_as_string")]
pub last_question_ts: Option<Timestamp>, // when the peer was last questioned (either successfully or not) and we wanted an answer pub last_question_ts: Option<Timestamp>, // when the peer was last questioned (either successfully or not) and we wanted an answer
#[serde(with = "opt_json_as_string")]
pub last_seen_ts: Option<Timestamp>, // when the peer was last seen for any reason, including when we first attempted to reach out to it pub last_seen_ts: Option<Timestamp>, // when the peer was last seen for any reason, including when we first attempted to reach out to it
#[serde(with = "opt_json_as_string")]
pub first_consecutive_seen_ts: Option<Timestamp>, // the timestamp of the first consecutive proof-of-life for this node (an answer or received question) pub first_consecutive_seen_ts: Option<Timestamp>, // the timestamp of the first consecutive proof-of-life for this node (an answer or received question)
pub recent_lost_answers: u32, // number of answers that have been lost since we lost reliability pub recent_lost_answers: u32, // number of answers that have been lost since we lost reliability
pub failed_to_send: u32, // number of messages that have failed to send since we last successfully sent one pub failed_to_send: u32, // number of messages that have failed to send since we last successfully sent one
@ -102,10 +96,10 @@ pub struct RPCStats {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct PeerStats { pub struct PeerStats {
#[serde(with = "json_as_string")]
pub time_added: Timestamp, // when the peer was added to the routing table pub time_added: Timestamp, // when the peer was added to the routing table
pub rpc_stats: RPCStats, // information about RPCs pub rpc_stats: RPCStats, // information about RPCs
pub latency: Option<LatencyStats>, // latencies for communications with the peer pub latency: Option<LatencyStats>, // latencies for communications with the peer

View File

@ -1,8 +1,11 @@
#[cfg(feature = "unstable-tunnels")]
use super::*; use super::*;
/// Tunnel identifier /// Tunnel identifier
#[cfg(feature = "unstable-tunnels")]
pub type TunnelId = AlignedU64; pub type TunnelId = AlignedU64;
#[cfg(feature = "unstable-tunnels")]
#[derive( #[derive(
Copy, Copy,
Clone, Clone,
@ -16,6 +19,7 @@ pub type TunnelId = AlignedU64;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum TunnelMode { pub enum TunnelMode {
@ -23,6 +27,7 @@ pub enum TunnelMode {
Turn, Turn,
} }
#[cfg(feature = "unstable-tunnels")]
#[derive( #[derive(
Copy, Copy,
Clone, Clone,
@ -36,6 +41,7 @@ pub enum TunnelMode {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum TunnelError { pub enum TunnelError {
@ -45,13 +51,17 @@ pub enum TunnelError {
NoCapacity, // Endpoint is full NoCapacity, // Endpoint is full
} }
#[derive(Clone, Debug, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize)] #[cfg(feature = "unstable-tunnels")]
#[derive(
Clone, Debug, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, JsonSchema,
)]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct TunnelEndpoint { pub struct TunnelEndpoint {
pub mode: TunnelMode, pub mode: TunnelMode,
pub description: String, // XXX: TODO pub description: String, // XXX: TODO
} }
#[cfg(feature = "unstable-tunnels")]
impl Default for TunnelEndpoint { impl Default for TunnelEndpoint {
fn default() -> Self { fn default() -> Self {
Self { Self {
@ -61,8 +71,17 @@ impl Default for TunnelEndpoint {
} }
} }
#[cfg(feature = "unstable-tunnels")]
#[derive( #[derive(
Clone, Debug, Default, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Clone,
Debug,
Default,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct FullTunnel { pub struct FullTunnel {
@ -72,8 +91,17 @@ pub struct FullTunnel {
pub remote: TunnelEndpoint, pub remote: TunnelEndpoint,
} }
#[cfg(feature = "unstable-tunnels")]
#[derive( #[derive(
Clone, Debug, Default, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Clone,
Debug,
Default,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct PartialTunnel { pub struct PartialTunnel {

View File

@ -14,6 +14,7 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum VeilidLogLevel { pub enum VeilidLogLevel {
@ -78,7 +79,16 @@ impl fmt::Display for VeilidLogLevel {
/// A VeilidCore log message with optional backtrace /// A VeilidCore log message with optional backtrace
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidLog { pub struct VeilidLog {

View File

@ -12,6 +12,7 @@ use super::*;
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
pub enum AttachmentState { pub enum AttachmentState {
@ -60,7 +61,16 @@ impl TryFrom<String> for AttachmentState {
} }
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidStateAttachment { pub struct VeilidStateAttachment {
@ -70,39 +80,76 @@ pub struct VeilidStateAttachment {
} }
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct PeerTableData { pub struct PeerTableData {
#[schemars(with = "Vec<String>")]
pub node_ids: Vec<TypedKey>, pub node_ids: Vec<TypedKey>,
pub peer_address: String, pub peer_address: String,
pub peer_stats: PeerStats, pub peer_stats: PeerStats,
} }
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidStateNetwork { pub struct VeilidStateNetwork {
pub started: bool, pub started: bool,
#[serde(with = "json_as_string")]
pub bps_down: ByteCount, pub bps_down: ByteCount,
#[serde(with = "json_as_string")]
pub bps_up: ByteCount, pub bps_up: ByteCount,
pub peers: Vec<PeerTableData>, pub peers: Vec<PeerTableData>,
} }
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidRouteChange { pub struct VeilidRouteChange {
#[schemars(with = "Vec<String>")]
pub dead_routes: Vec<RouteId>, pub dead_routes: Vec<RouteId>,
#[schemars(with = "Vec<String>")]
pub dead_remote_routes: Vec<RouteId>, pub dead_remote_routes: Vec<RouteId>,
} }
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidStateConfig { pub struct VeilidStateConfig {
@ -110,17 +157,29 @@ pub struct VeilidStateConfig {
} }
#[derive( #[derive(
Debug, Clone, PartialEq, Eq, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, Debug,
Clone,
PartialEq,
Eq,
Serialize,
Deserialize,
RkyvArchive,
RkyvSerialize,
RkyvDeserialize,
JsonSchema,
)] )]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidValueChange { pub struct VeilidValueChange {
#[schemars(with = "String")]
key: TypedKey, key: TypedKey,
subkeys: Vec<ValueSubkey>, subkeys: Vec<ValueSubkey>,
count: u32, count: u32,
value: ValueData, value: ValueData,
} }
#[derive(Debug, Clone, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize)] #[derive(
Debug, Clone, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, JsonSchema,
)]
#[archive_attr(repr(u8), derive(CheckBytes))] #[archive_attr(repr(u8), derive(CheckBytes))]
#[serde(tag = "kind")] #[serde(tag = "kind")]
pub enum VeilidUpdate { pub enum VeilidUpdate {
@ -135,7 +194,9 @@ pub enum VeilidUpdate {
Shutdown, Shutdown,
} }
#[derive(Debug, Clone, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize)] #[derive(
Debug, Clone, Serialize, Deserialize, RkyvArchive, RkyvSerialize, RkyvDeserialize, JsonSchema,
)]
#[archive_attr(repr(C), derive(CheckBytes))] #[archive_attr(repr(C), derive(CheckBytes))]
pub struct VeilidState { pub struct VeilidState {
pub attachment: VeilidStateAttachment, pub attachment: VeilidStateAttachment,

View File

@ -25,6 +25,7 @@ pub type ConfigCallback = Arc<dyn Fn(String) -> ConfigCallbackReturn + Send + Sy
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigHTTPS { pub struct VeilidConfigHTTPS {
pub enabled: bool, pub enabled: bool,
@ -54,6 +55,7 @@ pub struct VeilidConfigHTTPS {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigHTTP { pub struct VeilidConfigHTTP {
pub enabled: bool, pub enabled: bool,
@ -79,6 +81,7 @@ pub struct VeilidConfigHTTP {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigApplication { pub struct VeilidConfigApplication {
pub https: VeilidConfigHTTPS, pub https: VeilidConfigHTTPS,
@ -106,6 +109,7 @@ pub struct VeilidConfigApplication {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigUDP { pub struct VeilidConfigUDP {
pub enabled: bool, pub enabled: bool,
@ -135,6 +139,7 @@ pub struct VeilidConfigUDP {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigTCP { pub struct VeilidConfigTCP {
pub connect: bool, pub connect: bool,
@ -166,6 +171,7 @@ pub struct VeilidConfigTCP {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigWS { pub struct VeilidConfigWS {
pub connect: bool, pub connect: bool,
@ -198,6 +204,7 @@ pub struct VeilidConfigWS {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigWSS { pub struct VeilidConfigWSS {
pub connect: bool, pub connect: bool,
@ -226,6 +233,7 @@ pub struct VeilidConfigWSS {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigProtocol { pub struct VeilidConfigProtocol {
pub udp: VeilidConfigUDP, pub udp: VeilidConfigUDP,
@ -253,6 +261,7 @@ pub struct VeilidConfigProtocol {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigTLS { pub struct VeilidConfigTLS {
pub certificate_path: String, pub certificate_path: String,
@ -273,6 +282,7 @@ pub struct VeilidConfigTLS {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigDHT { pub struct VeilidConfigDHT {
pub max_find_node_count: u32, pub max_find_node_count: u32,
@ -309,6 +319,7 @@ pub struct VeilidConfigDHT {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigRPC { pub struct VeilidConfigRPC {
pub concurrency: u32, pub concurrency: u32,
@ -333,9 +344,12 @@ pub struct VeilidConfigRPC {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigRoutingTable { pub struct VeilidConfigRoutingTable {
#[schemars(with = "Vec<String>")]
pub node_id: TypedKeySet, pub node_id: TypedKeySet,
#[schemars(with = "Vec<String>")]
pub node_id_secret: TypedSecretSet, pub node_id_secret: TypedSecretSet,
pub bootstrap: Vec<String>, pub bootstrap: Vec<String>,
pub limit_over_attached: u32, pub limit_over_attached: u32,
@ -358,6 +372,7 @@ pub struct VeilidConfigRoutingTable {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigNetwork { pub struct VeilidConfigNetwork {
pub connection_initial_timeout_ms: u32, pub connection_initial_timeout_ms: u32,
@ -391,6 +406,7 @@ pub struct VeilidConfigNetwork {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigTableStore { pub struct VeilidConfigTableStore {
pub directory: String, pub directory: String,
@ -408,6 +424,7 @@ pub struct VeilidConfigTableStore {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigBlockStore { pub struct VeilidConfigBlockStore {
pub directory: String, pub directory: String,
@ -425,6 +442,7 @@ pub struct VeilidConfigBlockStore {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigProtectedStore { pub struct VeilidConfigProtectedStore {
pub allow_insecure_fallback: bool, pub allow_insecure_fallback: bool,
@ -446,6 +464,7 @@ pub struct VeilidConfigProtectedStore {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigCapabilities { pub struct VeilidConfigCapabilities {
pub protocol_udp: bool, pub protocol_udp: bool,
@ -468,6 +487,7 @@ pub struct VeilidConfigCapabilities {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub enum VeilidConfigLogLevel { pub enum VeilidConfigLogLevel {
Off, Off,
@ -537,6 +557,7 @@ impl Default for VeilidConfigLogLevel {
RkyvArchive, RkyvArchive,
RkyvSerialize, RkyvSerialize,
RkyvDeserialize, RkyvDeserialize,
JsonSchema,
)] )]
pub struct VeilidConfigInner { pub struct VeilidConfigInner {
pub program_name: String, pub program_name: String,
@ -737,7 +758,6 @@ impl VeilidConfig {
safe_cfg.protected_store.device_encryption_key_password = "".to_owned(); safe_cfg.protected_store.device_encryption_key_password = "".to_owned();
safe_cfg.protected_store.new_device_encryption_key_password = None; safe_cfg.protected_store.new_device_encryption_key_password = None;
safe_cfg safe_cfg
} }

View File

@ -132,6 +132,14 @@ fn do_clap_matches(default_config_path: &OsStr) -> Result<clap::ArgMatches, clap
.long("dump-txt-record") .long("dump-txt-record")
.help("Prints the bootstrap TXT record for this node and then quits") .help("Prints the bootstrap TXT record for this node and then quits")
) )
.arg(
Arg::new("emit-schema")
.long("emit-schema")
.takes_value(true)
.value_name("schema_name")
.default_missing_value("")
.help("Emits a JSON-Schema for a named type")
)
.arg( .arg(
Arg::new("bootstrap") Arg::new("bootstrap")
.long("bootstrap") .long("bootstrap")

View File

@ -18,6 +18,7 @@ use cfg_if::*;
#[allow(unused_imports)] #[allow(unused_imports)]
use color_eyre::eyre::{bail, ensure, eyre, Result as EyreResult, WrapErr}; use color_eyre::eyre::{bail, ensure, eyre, Result as EyreResult, WrapErr};
use server::*; use server::*;
use std::collections::HashMap;
use std::str::FromStr; use std::str::FromStr;
use tools::*; use tools::*;
use tracing::*; use tracing::*;
@ -71,6 +72,24 @@ fn main() -> EyreResult<()> {
bail!("missing crypto kind"); bail!("missing crypto kind");
} }
} }
// -- Emit JSON-Schema --
if matches.occurrences_of("emit-schema") != 0 {
if let Some(esstr) = matches.value_of("emit-schema") {
let mut schemas = HashMap::<String, String>::new();
veilid_core::emit_schemas(&mut schemas);
if let Some(schema) = schemas.get(esstr) {
println!("{}", schema);
} else {
println!("Valid schemas:");
for s in schemas.keys() {
println!(" {}", s);
}
}
return Ok(());
}
}
// See if we're just running a quick command // See if we're just running a quick command
let (server_mode, success, failure) = if matches.occurrences_of("set-node-id") != 0 { let (server_mode, success, failure) = if matches.occurrences_of("set-node-id") != 0 {