Skip to main content

Camera

Struct Camera 

Source
pub struct Camera {
Show 33 fields pub id: String, pub site_id: Option<String>, pub name: String, pub vendor: String, pub model: Option<String>, pub address: Option<String>, pub rtsp_port: i64, pub username: Option<String>, pub password: Option<String>, pub main_stream_url: Option<String>, pub sub_stream_url: Option<String>, pub record_stream: String, pub codec: Option<String>, pub resolution_main: Option<String>, pub resolution_sub: Option<String>, pub fps_main: Option<i64>, pub fps_sub: Option<i64>, pub capabilities: Json<Value>, pub record_enabled: bool, pub segment_seconds: i64, pub retention_hours: i64, pub storage_quota_bytes: Option<i64>, pub record_audio: bool, pub record_mode: String, pub pre_roll_seconds: i64, pub post_roll_seconds: i64, pub mirror_enabled: bool, pub anr_enabled: bool, pub anr_replay_url_template: Option<String>, pub enabled: bool, pub priority: i64, pub created_at: DateTime<Utc>, pub updated_at: DateTime<Utc>,
}
Expand description

Camera row as stored. password is never serialized to clients; use CameraView for output.

Fields§

§id: String§site_id: Option<String>§name: String§vendor: String§model: Option<String>§address: Option<String>§rtsp_port: i64§username: Option<String>§password: Option<String>§main_stream_url: Option<String>§sub_stream_url: Option<String>§record_stream: String§codec: Option<String>§resolution_main: Option<String>§resolution_sub: Option<String>§fps_main: Option<i64>§fps_sub: Option<i64>§capabilities: Json<Value>§record_enabled: bool§segment_seconds: i64§retention_hours: i64§storage_quota_bytes: Option<i64>

Per-camera storage quota in bytes; NULL means no per-camera cap.

§record_audio: bool

Record the camera’s audio stream (pass-through) instead of dropping it.

§record_mode: String

When the recorder runs: continuous | scheduled | event | scheduled_event.

§pre_roll_seconds: i64

Event recording: footage desired BEFORE a trigger (best-effort, see recorder service).

§post_roll_seconds: i64

Event recording: how long the recorder keeps writing after a trigger (the trigger window).

§mirror_enabled: bool

Run a SECOND ffmpeg pipeline writing identical segments to HELDAR_MIRROR_RECORDINGS_DIR (redundant DVR copy). No-op unless the mirror dir is configured.

§anr_enabled: bool

Let the ANR loop re-fetch missed footage from the camera’s onboard storage to fill gaps.

§anr_replay_url_template: Option<String>

Optional replay URL template for ANR ({start}/{end} placeholders); NULL = default Hikvision RTSP playback built from address+credentials.

§enabled: bool§priority: i64

AI decode priority (higher = more important). The frame sampler favors high-priority cameras under fps-budget pressure and sheds low-priority ones first.

§created_at: DateTime<Utc>§updated_at: DateTime<Utc>

Implementations§

Source§

impl Camera

Source

pub fn should_record(&self) -> bool

Whether the recorder should be running a process for this camera.

Trait Implementations§

Source§

impl Clone for Camera

Source§

fn clone(&self) -> Camera

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 Camera

Source§

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

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

impl From<Camera> for CameraView

Source§

fn from(c: Camera) -> Self

Converts to this type from the input type.
Source§

impl<'a, R: Row> FromRow<'a, R> for Camera
where &'a str: ColumnIndex<R>, String: Decode<'a, R::Database> + Type<R::Database>, Option<String>: Decode<'a, R::Database> + Type<R::Database>, i64: Decode<'a, R::Database> + Type<R::Database>, Option<i64>: Decode<'a, R::Database> + Type<R::Database>, Json<Value>: Decode<'a, R::Database> + Type<R::Database>, bool: Decode<'a, R::Database> + Type<R::Database>, DateTime<Utc>: Decode<'a, R::Database> + Type<R::Database>,

Source§

fn from_row(__row: &'a R) -> Result<Self>

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> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<A, B, T> HttpServerConnExec<A, B> for T
where B: Body,

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

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

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

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Sized + Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
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<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