// This file is part of Moonfire NVR, a security camera network video recorder. // Copyright (C) 2022 The Moonfire NVR Authors; see AUTHORS and LICENSE.txt. // SPDX-License-Identifier: GPL-v3.0-or-later WITH GPL-3.0-linking-exception. //! Runtime configuration file (`/etc/moonfire-nvr.conf`). use std::path::PathBuf; use serde::Deserialize; fn default_db_dir() -> PathBuf { "/var/lib/moonfire-nvr/db".into() } fn default_ui_dir() -> PathBuf { "/usr/local/lib/moonfire-nvr/ui".into() } /// Top-level configuration file object. #[derive(Debug, Deserialize)] #[serde(rename_all = "camelCase")] pub struct ConfigFile { pub binds: Vec, /// Directory holding the SQLite3 index database. #[serde(default = "default_db_dir")] pub db_dir: PathBuf, /// Directory holding user interface files (`.html`, `.js`, etc). #[serde(default = "default_ui_dir")] pub ui_dir: PathBuf, /// The number of worker threads used by the asynchronous runtime. /// /// Defaults to the number of cores on the system. #[serde(default)] pub worker_threads: Option, /// RTSP library to use for fetching the cameras' video stream. /// Moonfire NVR is in the process of switching from `ffmpeg` (used since /// the beginning of the project) to `retina` (a pure-Rust RTSP library /// developed by Moonfire NVR's author). #[serde(default)] pub rtsp_library: crate::stream::RtspLibrary, } /// Per-bind configuration. #[derive(Debug, Deserialize)] #[serde(rename_all = "camelCase")] pub struct BindConfig { /// The address to bind to. #[serde(flatten)] pub address: AddressConfig, /// Allow unauthenticated API access on this bind, with the given /// permissions (defaults to empty). /// /// Note that even an empty string allows some basic access that would be rejected if the /// argument were omitted. #[serde(default)] pub allow_unauthenticated_permissions: Option, /// Trusts `X-Real-IP:` and `X-Forwarded-Proto:` headers on the incoming request. /// /// Set this only after ensuring your proxy server is configured to set them /// and that no untrusted requests bypass the proxy server. You may want to /// specify a localhost bind address. #[serde(default)] pub trust_forward_hdrs: bool, } #[derive(Debug, Deserialize)] #[serde(rename_all = "camelCase")] pub enum AddressConfig { /// IPv4 address such as `0.0.0.0:8080` or `127.0.0.1:8080`. Ipv4(std::net::SocketAddrV4), /// IPv6 address such as `[::]:8080` or `[::1]:8080`. Ipv6(std::net::SocketAddrV6), // TODO: /// Unix socket path such as `/var/lib/moonfire-nvr/sock`. // Unix(PathBuf), // TODO: SystemdFileDescriptorName(String), see // https://www.freedesktop.org/software/systemd/man/systemd.socket.html } /// JSON analog of `Permissions` defined in `db/proto/schema.proto`. #[derive(Debug, Default, Deserialize)] #[serde(rename_all = "camelCase")] pub struct Permissions { view_video: bool, read_camera_configs: bool, update_signals: bool, } impl Permissions { pub fn as_proto(&self) -> db::schema::Permissions { db::schema::Permissions { view_video: self.view_video, read_camera_configs: self.read_camera_configs, update_signals: self.update_signals, ..Default::default() } } }