Skip to main content

ServiceDef

Struct ServiceDef 

Source
pub struct ServiceDef {
    pub service: ServiceMeta,
    pub requirements: Option<Requirements>,
    pub ports: Vec<PortDef>,
    pub env: Vec<EnvVar>,
    pub env_groups: Vec<EnvGroup>,
    pub choices: Vec<Choice>,
    pub requires: Vec<ServiceRequirement>,
    pub mappings: Mappings,
    pub integrations: IntegrationFlags,
    pub capabilities: Capabilities,
    pub backup: Option<BackupConfig>,
    pub metrics: Option<MetricsDef>,
}
Expand description

A service definition from a registry’s services/<name>/service.toml.

Fields§

§service: ServiceMeta§requirements: Option<Requirements>§ports: Vec<PortDef>§env: Vec<EnvVar>§env_groups: Vec<EnvGroup>

Optional, user-toggled bundles of env vars. A group is either fully enabled (every member lands in .env) or fully disabled (none do) — makes “client_id without client_secret” unrepresentable.

§choices: Vec<Choice>

Mutually-exclusive choices. Exactly one option per choice is selected and only that option’s env vars are written, so “none selected” and “two at once” are unrepresentable rather than rejected. The sum type to env_group’s product.

§requires: Vec<ServiceRequirement>§mappings: Mappings§integrations: IntegrationFlags§capabilities: Capabilities

Roles this service can play for other services. The dual of IntegrationFlags (which describes what this service consumes). Drives capability-based dispatch — see crate::capability.

§backup: Option<BackupConfig>

Backup configuration. Present only when the author has declared backup = true in [integrations] and the service needs more than the default “back up everything classified as data.” Carries hooks (pre/post dump) and exclude lists.

§metrics: Option<MetricsDef>

Prometheus-style metrics endpoint this service exposes. When set and a metrics-store provider is installed, ryra writes a file_sd scrape target and joins the service to the store’s network.

Implementations§

Source§

impl ServiceDef

Source

pub fn check_architecture(&self) -> Option<String>

Check if this service supports the current system architecture. Returns None if supported (or no restriction), Some(error) if not.

Source

pub fn required_env_vars(&self) -> Vec<&str>

Returns env var names that are required — must be provided during install.

Source

pub fn validate(&self) -> Result<(), String>

Validate structural invariants that serde can’t enforce. Called once after deserialization — if this returns Ok, the definition is safe to use without further checks.

Trait Implementations§

Source§

impl Clone for ServiceDef

Source§

fn clone(&self) -> ServiceDef

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for ServiceDef

Source§

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

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

impl<'de> Deserialize<'de> for ServiceDef

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 Serialize for ServiceDef

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

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<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<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> Same for T

Source§

type Output = T

Should always be Self
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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V