pub struct DaemonLock {
pub pid: u32,
pub started_ts: u64,
pub repo_root: String,
pub actor_id: String,
pub host_id: String,
pub ipc_endpoint: String,
pub lease_ms: u64,
pub last_heartbeat_ts: u64,
pub expires_ts: u64,
}Expand description
Daemon lock stored at .git/grite/actors/<actor_id>/daemon.lock
Fields§
§pid: u32Process ID of the lock holder
started_ts: u64When the daemon started (Unix timestamp in ms)
repo_root: StringRepository root path
actor_id: StringActor ID (hex-encoded)
host_id: StringStable host identifier
ipc_endpoint: StringUnix socket path (e.g., “/tmp/grite-daemon.sock”)
lease_ms: u64Lease duration in milliseconds
last_heartbeat_ts: u64Last heartbeat timestamp (Unix timestamp in ms)
expires_ts: u64When the lock expires (Unix timestamp in ms)
Implementations§
Source§impl DaemonLock
impl DaemonLock
Sourcepub fn new(
pid: u32,
repo_root: String,
actor_id: String,
host_id: String,
ipc_endpoint: String,
) -> Self
pub fn new( pid: u32, repo_root: String, actor_id: String, host_id: String, ipc_endpoint: String, ) -> Self
Create a new daemon lock
Sourcepub fn with_lease(self, lease_ms: u64) -> Self
pub fn with_lease(self, lease_ms: u64) -> Self
Create a lock with a custom lease duration
Sourcepub fn is_expired(&self) -> bool
pub fn is_expired(&self) -> bool
Check if the lock has expired
Sourcepub fn is_owned_by_current_process(&self) -> bool
pub fn is_owned_by_current_process(&self) -> bool
Check if the lock is held by this process
Sourcepub fn time_remaining_ms(&self) -> u64
pub fn time_remaining_ms(&self) -> u64
Remaining time until expiration in milliseconds
Sourcepub fn lock_path(data_dir: &Path) -> PathBuf
pub fn lock_path(data_dir: &Path) -> PathBuf
Get the lock file path for an actor data directory
Sourcepub fn acquire(
data_dir: &Path,
repo_root: String,
actor_id: String,
host_id: String,
ipc_endpoint: String,
) -> Result<Self, IpcError>
pub fn acquire( data_dir: &Path, repo_root: String, actor_id: String, host_id: String, ipc_endpoint: String, ) -> Result<Self, IpcError>
Try to acquire the lock
Returns Ok(lock) if acquired, Err if held by another non-expired process. Uses atomic file creation to prevent two processes from acquiring the lock simultaneously when an expired lock is being replaced.
Trait Implementations§
Source§impl Clone for DaemonLock
impl Clone for DaemonLock
Source§fn clone(&self) -> DaemonLock
fn clone(&self) -> DaemonLock
1.0.0 (const: unstable) · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreSource§impl Debug for DaemonLock
impl Debug for DaemonLock
Source§impl<'de> Deserialize<'de> for DaemonLock
impl<'de> Deserialize<'de> for DaemonLock
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Auto Trait Implementations§
impl Freeze for DaemonLock
impl RefUnwindSafe for DaemonLock
impl Send for DaemonLock
impl Sync for DaemonLock
impl Unpin for DaemonLock
impl UnsafeUnpin for DaemonLock
impl UnwindSafe for DaemonLock
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.