2023-01-06 11:40:41 -06:00
|
|
|
# Moonfire NVR Configuration File
|
|
|
|
|
|
|
|
Moonfire NVR has a small runtime configuration file. By default it's called
|
|
|
|
`/etc/moonfire-nvr.toml`. You can specify a different path on the commandline,
|
|
|
|
e.g. as follows:
|
|
|
|
|
|
|
|
```console
|
|
|
|
$ moonfire-nvr run --config /path/to/config.toml
|
|
|
|
```
|
|
|
|
|
|
|
|
`.toml` refers to [Tom's Obvious Minimal Language](https://toml.io/en/). This
|
|
|
|
is a line-based config format with `[section]` boundaries and `# comment`
|
|
|
|
lines, meant to be more easily edited by humans.
|
|
|
|
|
|
|
|
## Examples
|
|
|
|
|
2023-10-19 22:31:39 -07:00
|
|
|
### Starter config
|
|
|
|
|
2023-01-06 11:40:41 -06:00
|
|
|
The following is a starter config which allows connecting and viewing video with no authentication:
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[[binds]]
|
|
|
|
ipv4 = "0.0.0.0:8080"
|
|
|
|
allowUnauthenticatedPermissions = { viewVideo = true }
|
|
|
|
|
|
|
|
[[binds]]
|
|
|
|
unix = "/var/lib/moonfire-nvr/sock"
|
|
|
|
ownUidIsPrivileged = true
|
|
|
|
```
|
|
|
|
|
2023-10-19 22:31:39 -07:00
|
|
|
### Authenticated config
|
|
|
|
|
2023-01-06 11:40:41 -06:00
|
|
|
The following is for a more secure setup with authentication and a TLS proxy
|
|
|
|
server in front, as in [guide/secure.md](../guide/secure.md).
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[[binds]]
|
|
|
|
ipv4 = "0.0.0.0:8080"
|
|
|
|
trustForwardHeaders = true
|
|
|
|
|
|
|
|
[[binds]]
|
|
|
|
unix = "/var/lib/moonfire-nvr/sock"
|
|
|
|
ownUidIsPrivileged = true
|
|
|
|
```
|
|
|
|
|
2023-10-19 22:31:39 -07:00
|
|
|
### `systemd` socket activation
|
|
|
|
|
|
|
|
`systemd` socket activation (Linux-only) expects `systemd` to create the sockets
|
|
|
|
on behalf of Moonfire NVR. This can speed startup of services that depend on them and allow
|
|
|
|
Moonfire to bind to privileged ports (80 or 443) without root privileges. The latter is
|
|
|
|
expected to be more useful once
|
|
|
|
[moonfire-nvr#27](https://github.com/scottlamb/moonfire-nvr/issues/27) is
|
|
|
|
complete and Moonfire is suitable for direct use as an Internet-facing webserver.
|
|
|
|
|
|
|
|
To set this up, you'll need an additional systemd unit file for each socket and
|
|
|
|
to reference them from `/etc/moonfire-nvr.toml`. Be sure to run `sudo systemctl
|
|
|
|
daemon-reload` to tell `systemd` to read in the new unit files. Your
|
|
|
|
`moonfire-nvr.service` file should also `Requires=` each socket file.
|
|
|
|
|
|
|
|
#### `/etc/moonfire-nvr.toml`
|
|
|
|
|
|
|
|
```toml
|
|
|
|
[[binds]]
|
|
|
|
systemd = "moonfire-nvr-tcp.socket"
|
|
|
|
allowUnauthenticatedPermissions = { viewVideo = true }
|
|
|
|
|
|
|
|
[[binds]]
|
|
|
|
systemd = "moonfire-nvr-unix.socket"
|
|
|
|
ownUidIsPrivileged = true
|
|
|
|
```
|
|
|
|
|
|
|
|
### `/etc/systemd/system/moonfire-nvr.service`
|
|
|
|
|
|
|
|
```ini
|
|
|
|
[Unit]
|
|
|
|
Requires=moonfire-nvr-tcp.socket
|
|
|
|
Requires=moonfire-nvr-unix.socket
|
|
|
|
# ...rest as before...
|
|
|
|
```
|
|
|
|
|
|
|
|
### `/etc/systemd/system/moonfire-nvr-tcp.socket`
|
|
|
|
|
|
|
|
```ini
|
|
|
|
[Socket]
|
|
|
|
ListenStream=80
|
|
|
|
Service=moonfire-nvr.service
|
|
|
|
```
|
|
|
|
|
|
|
|
### `/etc/systemd/system/moonfire-nvr-unix.socket`
|
|
|
|
|
|
|
|
```ini
|
|
|
|
[Socket]
|
|
|
|
ListenStream=/var/lib/moonfire-nvr/sock
|
|
|
|
Service=moonfire-nvr.service
|
|
|
|
```
|
|
|
|
|
2023-01-06 11:40:41 -06:00
|
|
|
## Reference
|
|
|
|
|
|
|
|
At the top level, before any `[[bind]]` lines, the following
|
|
|
|
keys are understood:
|
|
|
|
|
|
|
|
* `dbDir`: path to the SQLite database directory. Defaults to `/var/lib/moonfire-nvr/db`.
|
2024-01-31 17:06:21 -08:00
|
|
|
* `uiDir`: UI to serve; can be a path. Defaults to the special value
|
|
|
|
`uiDir = { bundled = true }` if a UI was built into the binary, or
|
|
|
|
`/usr/local/lib/moonfire-nvr/ui` otherwise. Release builds have UIs
|
|
|
|
built in; you can replicate this yourself via `--features=bundled` or `--features=bundled-ui`
|
2024-01-31 17:12:44 -08:00
|
|
|
when [building the server](../guide/build.md). **Note:** it's unusual
|
|
|
|
to override this value. For UI development, a much more pleasant
|
|
|
|
workflow is to use a hot-reloading proxy server as described in
|
|
|
|
[this guide](../guide/developing-ui.md).
|
2023-01-06 11:40:41 -06:00
|
|
|
* `workerThreads`: number of [tokio](https://tokio.rs/) worker threads to
|
|
|
|
use. Defaults to the number of CPUs on the system. This normally does not
|
|
|
|
need to be changed, but reducing it may slightly lower idle CPU usage.
|
|
|
|
|
|
|
|
A useful config will bind at least one socket for clients to connect to. Each
|
|
|
|
should start with a `[[binds]]` line and specify one of the following:
|
|
|
|
|
|
|
|
* `ipv4`: an IPv4 socket address. `0.0.0.0:8080` would allow connections from outside the machine;
|
|
|
|
`127.0.0.1:8080` would allow connections only from the local host.
|
2023-10-19 22:31:39 -07:00
|
|
|
* `ipv6`: an IPv6 socket address. `[::0]:8080` would allow connections from outside the machine;
|
2023-01-06 11:40:41 -06:00
|
|
|
`[[::1]:8080` would allow connections from only the local host.
|
|
|
|
* `unix`: a path in the local filesystem where a UNIX-domain socket can be created. Permissions on the
|
|
|
|
enclosing directories control which users are allowed to connect to it. Web browsers typically don't
|
|
|
|
support directly connecting to UNIX domain sockets, but other tools do, e.g.:
|
|
|
|
* `curl --unix-socket /var/lib/moonfire-nvr/sock http://nvr/api/` will
|
|
|
|
issue a request from the commandline. (The hostname in the URL doesn't
|
|
|
|
matter.)
|
|
|
|
* `ssh -L localhost:8080:/var/lib/moonfire-nvr/sock moonfire-nvr@nvr-host`
|
|
|
|
will allow a web browser on your local machine to connect to the
|
|
|
|
Moonfire NVR instance on `nvr-host` via https://localhost:8080/. If
|
|
|
|
`ownUidIsPrivileged` is specified (see below), it will additionally
|
|
|
|
have all permissions.
|
2023-10-19 22:31:39 -07:00
|
|
|
* `systemd` (Linux-only): a name of a socket passed from `systemd`. See
|
|
|
|
[`systemd.socket(5)`](https://www.freedesktop.org/software/systemd/man/latest/systemd.socket.html)
|
|
|
|
for more information, or the example above.
|
2023-01-06 11:40:41 -06:00
|
|
|
|
|
|
|
Additional options within `[[binds]]`:
|
|
|
|
|
|
|
|
* `ownUidIsPrivileged` (UNIX domain sockets only): boolean. If true, a client
|
|
|
|
running as Moonfire NVR's own uid can perform any action without additional
|
|
|
|
authentication. Once the configuration UI is complete, this will be a handy
|
|
|
|
way to set up the first user accounts.
|
|
|
|
* `allowUnauthenticatedPermissions`: dictionary. Clients connecting to this
|
|
|
|
bind will have the specified permissions, even without UID or session
|
|
|
|
authentication. The supported permissions are as in the [`Permissions`
|
|
|
|
section of api.md](api.md#permissions).
|
|
|
|
* `trustForwardHeaders`: boolean. Moonfire NVR will look for `X-Real-IP` and
|
|
|
|
`X-Forwarded-Proto` headers added by a proxy server to determine the
|
|
|
|
client's IP address and protocol (`http` or `https`). See
|
|
|
|
[guide/secure.md](../guide/secure.md) for more information. *Note:* when
|
|
|
|
using this option, ensure that untrusted clients can't bypass the proxy
|
|
|
|
server, or they will be able to disguise their true origin.
|