Skip to main content

MegaArgs

Struct MegaArgs 

Source
pub struct MegaArgs {
Show 19 fields pub mega_id: MegaId, pub backend_url: String, pub lease_lifetime_secs: u64, pub lease_renewal_interval_secs: u64, pub lsp: LspInfo, pub lsp_url: String, pub mega_inactivity_secs: u64, pub memory_overhead: u64, pub oauth: Option<OAuthConfig>, pub runner_url: String, pub rust_backtrace: Option<String>, pub rust_log: Option<String>, pub sgx_heap_size: u64, pub untrusted_deploy_env: DeployEnv, pub untrusted_esplora_urls: Vec<String>, pub untrusted_network: Network, pub user_inactivity_secs: u64, pub usernode_buffer_slots: usize, pub usernode_memory: u64,
}

Fields§

§mega_id: MegaId

A randomly generated id for this mega node.

§backend_url: String

protocol://host:port of the backend.

§lease_lifetime_secs: u64

Maximum duration for user node leases (in seconds).

§lease_renewal_interval_secs: u64

Interval at which user nodes should renew their leases (in seconds).

§lsp: LspInfo

info relating to Lexe’s LSP.

§lsp_url: String

protocol://host:port of the LSP’s HTTP server.

§mega_inactivity_secs: u64

How long the meganode can remain inactive before it shuts itself down.

§memory_overhead: u64

An estimate of the amount of enclave heap consumed by shared meganode components such as the network graph, Tokio, connection pools, etc.

§oauth: Option<OAuthConfig>

configuration info for Google OAuth2. Required only if running in staging / prod.

§runner_url: String

protocol://host:port of the runner.

§rust_backtrace: Option<String>

The value to set for RUST_BACKTRACE. Does nothing if set to None. Passed as an arg since envs aren’t available in SGX.

§rust_log: Option<String>

The value to set for RUST_LOG. Does nothing if set to None. Passed as an arg since envs aren’t available in SGX.

§sgx_heap_size: u64

the allocatable memory available to this enclave in SGX.

§untrusted_deploy_env: DeployEnv

The current deploy environment passed to us by Lexe (or someone in Lexe’s cloud). This input should be treated as untrusted.

§untrusted_esplora_urls: Vec<String>

Esplora urls which someone in Lexe’s infra says we should use. We’ll only use urls contained in our whitelist.

§untrusted_network: Network

The current deploy network passed to us by Lexe (or someone in Lexe’s cloud). This input should be treated as untrusted.

§user_inactivity_secs: u64

How long the usernode can remain inactive (in seconds) before it gets evicted by the UserRunner.

§usernode_buffer_slots: usize

The # of usernodes that the meganode tries to maintain capacity for. Users are evicted when remaining memory fits fewer than this amount.

§usernode_memory: u64

An estimate of the amount of enclave heap consumed by each usernode.

Trait Implementations§

Source§

impl Clone for MegaArgs

Source§

fn clone(&self) -> MegaArgs

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for MegaArgs

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for MegaArgs

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl EnclaveArgs for MegaArgs

Source§

const NAME: &str = "mega"

The name of the command, e.g. “run”, “provision”, “mega”
Source§

fn to_command(&self, bin_path: &Path) -> Command

Construct a std::process::Command from the contained args. Requires the path to the binary.
Source§

fn append_args(&self, cmd: &mut Command)

Serialize and append the contained args to an existing std::process::Command.
Source§

fn from_json_str(json_str: &str) -> Result<Self, Error>

Source§

fn to_json_string(&self) -> String

Source§

impl PartialEq for MegaArgs

Source§

fn eq(&self, other: &MegaArgs) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for MegaArgs

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for MegaArgs

Source§

impl StructuralPartialEq for MegaArgs

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<F, T, U> Apply<F, U> for T
where F: FnOnce(T) -> U,

Source§

fn apply(self, f: F) -> U

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,