Skip to main content

LeaseSummary

Struct LeaseSummary 

Source
#[non_exhaustive]
pub struct LeaseSummary { pub lease_epoch: LeaseEpoch, pub worker_instance_id: WorkerInstanceId, pub expires_at: TimestampMs, pub lease_id: LeaseId, pub attempt_index: AttemptIndex, pub last_heartbeat_at: Option<TimestampMs>, }
Expand description

Currently-held lease summary inside an ExecutionSnapshot.

#[non_exhaustive]. New fields may be added in minor releases — use LeaseSummary::new plus the fluent with_* setters to construct one, and match with .. in destructuring.

§Field provenance (FF#278)

  • lease_id — minted at claim time (ff_claim_execution / ff_claim_resumed_execution), cleared atomically with the other lease fields on revoke/expire/complete. Stable for the lifetime of a single lease; a fresh one is minted per re-claim. Defaults to the nil UUID when a backend does not surface per-lease ids (treat as “field not populated”).
  • attempt_index — the 1-based attempt counter (current_attempt_index on exec_core). Set atomically with current_attempt_id at claim time; always populated while a Valkey-backed lease is held.
  • last_heartbeat_at — the most recent ff_renew_lease timestamp (lease_last_renewed_at on exec_core). None when the field is empty (e.g. legacy data pre-0.9, or a backend that does not surface per-renewal heartbeats).

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§lease_epoch: LeaseEpoch§worker_instance_id: WorkerInstanceId§expires_at: TimestampMs§lease_id: LeaseId

Per-lease unique identity. Correlates audit-log entries, reclaim events, and recovery traces.

§attempt_index: AttemptIndex

1-based attempt counter; .0 mirrors current_attempt_index on exec_core.

§last_heartbeat_at: Option<TimestampMs>

Most recent heartbeat (lease-renewal) timestamp. None when the backend does not surface per-renewal ticks on this lease.

Implementations§

Source§

impl LeaseSummary

Source

pub fn new( lease_epoch: LeaseEpoch, worker_instance_id: WorkerInstanceId, expires_at: TimestampMs, ) -> Self

Construct a LeaseSummary with the three always-present fields. Use the with_* setters to populate the FF#278 additions (lease_id, attempt_index, last_heartbeat_at); otherwise they default to the nil / zero / empty forms, which callers should treat as “field not surfaced by this backend”.

See ExecutionSnapshot::new for the broader #[non_exhaustive] construction rationale.

Source

pub fn with_lease_id(self, lease_id: LeaseId) -> Self

Set the lease’s unique identity (FF#278).

Source

pub fn with_attempt_index(self, attempt_index: AttemptIndex) -> Self

Set the 1-based attempt counter (FF#278).

Source

pub fn with_last_heartbeat_at(self, ts: TimestampMs) -> Self

Set the most recent heartbeat timestamp (FF#278).

Trait Implementations§

Source§

impl Clone for LeaseSummary

Source§

fn clone(&self) -> LeaseSummary

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 LeaseSummary

Source§

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

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

impl PartialEq for LeaseSummary

Source§

fn eq(&self, other: &LeaseSummary) -> 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 Eq for LeaseSummary

Source§

impl StructuralPartialEq for LeaseSummary

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> 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> 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.