mirror of
https://github.com/MAGICGrants/truenas-apps.git
synced 2026-01-08 20:18:01 -05:00
1664 lines
101 KiB
JSON
1664 lines
101 KiB
JSON
{
|
|
"1.2.24": {
|
|
"healthy": true,
|
|
"supported": true,
|
|
"healthy_error": null,
|
|
"location": "/__w/apps/apps/trains/community/frigate/1.2.24",
|
|
"last_update": "2025-11-28 16:17:12",
|
|
"required_features": [],
|
|
"human_version": "0.16.2_1.2.24",
|
|
"version": "1.2.24",
|
|
"app_metadata": {
|
|
"annotations": {
|
|
"min_scale_version": "24.10.2.2"
|
|
},
|
|
"app_version": "0.16.2",
|
|
"capabilities": [
|
|
{
|
|
"description": "Frigate is able to change file ownership arbitrarily",
|
|
"name": "CHOWN"
|
|
},
|
|
{
|
|
"description": "Frigate is able to bypass file permission checks",
|
|
"name": "DAC_OVERRIDE"
|
|
},
|
|
{
|
|
"description": "Frigate is able to bypass permission checks for file operations",
|
|
"name": "FOWNER"
|
|
},
|
|
{
|
|
"description": "Frigate is able to send signals to any process",
|
|
"name": "KILL"
|
|
},
|
|
{
|
|
"description": "Frigate is able to access performance monitoring interfaces",
|
|
"name": "PERFMON"
|
|
},
|
|
{
|
|
"description": "Frigate is able to change group ID of processes",
|
|
"name": "SETGID"
|
|
},
|
|
{
|
|
"description": "Frigate is able to change user ID of processes",
|
|
"name": "SETUID"
|
|
}
|
|
],
|
|
"categories": [
|
|
"security"
|
|
],
|
|
"changelog_url": "https://github.com/blakeblackshear/frigate/releases",
|
|
"date_added": "2024-09-12",
|
|
"description": "Frigate is an NVR With Realtime Object Detection for IP Cameras",
|
|
"home": "https://frigate.video/",
|
|
"host_mounts": [],
|
|
"icon": "https://media.sys.truenas.net/apps/frigate/icons/icon.svg",
|
|
"keywords": [
|
|
"camera",
|
|
"nvr"
|
|
],
|
|
"lib_version": "2.1.65",
|
|
"lib_version_hash": "f92a9ee78c78fc77f86e7d8b545bd4c605c31c599e2c5da59f1615aa516cb8b5",
|
|
"maintainers": [
|
|
{
|
|
"email": "dev@truenas.com",
|
|
"name": "truenas",
|
|
"url": "https://www.truenas.com/"
|
|
}
|
|
],
|
|
"name": "frigate",
|
|
"run_as_context": [
|
|
{
|
|
"description": "Frigate runs as root user.",
|
|
"gid": 0,
|
|
"group_name": "root",
|
|
"uid": 0,
|
|
"user_name": "root"
|
|
}
|
|
],
|
|
"screenshots": [
|
|
"https://media.sys.truenas.net/apps/frigate/screenshots/screenshot1.png",
|
|
"https://media.sys.truenas.net/apps/frigate/screenshots/screenshot2.png",
|
|
"https://media.sys.truenas.net/apps/frigate/screenshots/screenshot3.png"
|
|
],
|
|
"sources": [
|
|
"https://github.com/blakeblackshear/frigate"
|
|
],
|
|
"title": "Frigate",
|
|
"train": "community",
|
|
"version": "1.2.24"
|
|
},
|
|
"schema": {
|
|
"groups": [
|
|
{
|
|
"name": "Frigate Configuration",
|
|
"description": "Configure Frigate"
|
|
},
|
|
{
|
|
"name": "Network Configuration",
|
|
"description": "Configure Network for Frigate"
|
|
},
|
|
{
|
|
"name": "Storage Configuration",
|
|
"description": "Configure Storage for Frigate"
|
|
},
|
|
{
|
|
"name": "Labels Configuration",
|
|
"description": "Configure Labels for Frigate"
|
|
},
|
|
{
|
|
"name": "Resources Configuration",
|
|
"description": "Configure Resources for Frigate"
|
|
}
|
|
],
|
|
"questions": [
|
|
{
|
|
"variable": "TZ",
|
|
"group": "Frigate Configuration",
|
|
"label": "Timezone",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "Etc/UTC",
|
|
"required": true,
|
|
"$ref": [
|
|
"definitions/timezone"
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "frigate",
|
|
"label": "",
|
|
"group": "Frigate Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "image_selector",
|
|
"label": "Image Selector",
|
|
"description": "The image to use for Frigate.",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "image",
|
|
"required": true,
|
|
"enum": [
|
|
{
|
|
"value": "image",
|
|
"description": "Normal Image"
|
|
},
|
|
{
|
|
"value": "tensorrt_image",
|
|
"description": "TensorRT Image"
|
|
},
|
|
{
|
|
"value": "rocm_image",
|
|
"description": "ROCm Image"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "shm_size_mb",
|
|
"label": "Shared Memory Size (in MiB)",
|
|
"description": "The size of the shared memory to use for Frigate.",
|
|
"schema": {
|
|
"type": "int",
|
|
"default": 64,
|
|
"min": 30,
|
|
"max": 2048,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "mount_usb_bus",
|
|
"label": "Mount USB Bus",
|
|
"description": "Mount the USB bus to the container.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "devices",
|
|
"label": "Devices",
|
|
"description": "Devices to use for Frigate.\nEg: Host Device: /dev/apex_0, Container Device: /dev/apex_0\n",
|
|
"schema": {
|
|
"type": "list",
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "device",
|
|
"label": "Device",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "host_device",
|
|
"label": "Host Device",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "container_device",
|
|
"label": "Container Device",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "additional_envs",
|
|
"label": "Additional Environment Variables",
|
|
"schema": {
|
|
"type": "list",
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "env",
|
|
"label": "Environment Variable",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "name",
|
|
"label": "Name",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "value",
|
|
"label": "Value",
|
|
"schema": {
|
|
"type": "string"
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "network",
|
|
"label": "",
|
|
"group": "Network Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "host_network",
|
|
"label": "Host Network",
|
|
"description": "Bind to the host network. It's recommended to keep this disabled.\n",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "web_port",
|
|
"label": "WebUI Port (Auth)",
|
|
"description": "The port for Frigate WebUI",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"host_network",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "bind_mode",
|
|
"label": "Port Bind Mode",
|
|
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "published",
|
|
"enum": [
|
|
{
|
|
"value": "published",
|
|
"description": "Publish port on the host for external access"
|
|
},
|
|
{
|
|
"value": "exposed",
|
|
"description": "Expose port for inter-container communication"
|
|
},
|
|
{
|
|
"value": "",
|
|
"description": "None"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "port_number",
|
|
"label": "Port Number",
|
|
"schema": {
|
|
"type": "int",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": 30193,
|
|
"min": 1,
|
|
"max": 65535,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_ips",
|
|
"label": "Host IPs",
|
|
"description": "IPs on the host to bind this port",
|
|
"schema": {
|
|
"type": "list",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "host_ip",
|
|
"label": "Host IP",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"$ref": [
|
|
"definitions/node_bind_ip"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "no_auth_port",
|
|
"label": "WebUI Port (No Auth)",
|
|
"description": "The port for Frigate WebUI (No Auth)",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"host_network",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "bind_mode",
|
|
"label": "Port Bind Mode",
|
|
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "",
|
|
"enum": [
|
|
{
|
|
"value": "published",
|
|
"description": "Publish port on the host for external access"
|
|
},
|
|
{
|
|
"value": "exposed",
|
|
"description": "Expose port for inter-container communication"
|
|
},
|
|
{
|
|
"value": "",
|
|
"description": "None"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "port_number",
|
|
"label": "Port Number",
|
|
"schema": {
|
|
"type": "int",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": 30194,
|
|
"min": 1,
|
|
"max": 65535,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_ips",
|
|
"label": "Host IPs",
|
|
"description": "IPs on the host to bind this port",
|
|
"schema": {
|
|
"type": "list",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "host_ip",
|
|
"label": "Host IP",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"$ref": [
|
|
"definitions/node_bind_ip"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "rtsp_port",
|
|
"label": "RTSP Port",
|
|
"description": "The RTSP port for Frigate.</br>\nInternal port: 8554\n",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"host_network",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "bind_mode",
|
|
"label": "Port Bind Mode",
|
|
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "",
|
|
"enum": [
|
|
{
|
|
"value": "published",
|
|
"description": "Publish port on the host for external access"
|
|
},
|
|
{
|
|
"value": "exposed",
|
|
"description": "Expose port for inter-container communication"
|
|
},
|
|
{
|
|
"value": "",
|
|
"description": "None"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "port_number",
|
|
"label": "Port Number",
|
|
"schema": {
|
|
"type": "int",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": 30195,
|
|
"min": 1,
|
|
"max": 65535,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_ips",
|
|
"label": "Host IPs",
|
|
"description": "IPs on the host to bind this port",
|
|
"schema": {
|
|
"type": "list",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "host_ip",
|
|
"label": "Host IP",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"$ref": [
|
|
"definitions/node_bind_ip"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "webrtc_port",
|
|
"label": "WebRTC Port",
|
|
"description": "The WebRTC port for Frigate.</br>\nInternal port: 8555</br>\nApplies to both TCP and UDP.\n",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"host_network",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "bind_mode",
|
|
"label": "Port Bind Mode",
|
|
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "",
|
|
"enum": [
|
|
{
|
|
"value": "published",
|
|
"description": "Publish port on the host for external access"
|
|
},
|
|
{
|
|
"value": "exposed",
|
|
"description": "Expose port for inter-container communication"
|
|
},
|
|
{
|
|
"value": "",
|
|
"description": "None"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "port_number",
|
|
"label": "Port Number",
|
|
"schema": {
|
|
"type": "int",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": 30196,
|
|
"min": 1,
|
|
"max": 65535,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_ips",
|
|
"label": "Host IPs",
|
|
"description": "IPs on the host to bind this port",
|
|
"schema": {
|
|
"type": "list",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "host_ip",
|
|
"label": "Host IP",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"$ref": [
|
|
"definitions/node_bind_ip"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "go2rtc_port",
|
|
"label": "Go2RTC Port",
|
|
"description": "The port for Frigate Go2RTC",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"host_network",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "bind_mode",
|
|
"label": "Port Bind Mode",
|
|
"description": "The port bind mode.</br>\n- Publish: The port will be published on the host for external access.</br>\n- Expose: The port will be exposed for inter-container communication.</br>\n- None: The port will not be exposed or published.</br>\nNote: If the Dockerfile defines an EXPOSE directive,\nthe port will still be exposed for inter-container communication regardless of this setting.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"default": "",
|
|
"enum": [
|
|
{
|
|
"value": "published",
|
|
"description": "Publish port on the host for external access"
|
|
},
|
|
{
|
|
"value": "exposed",
|
|
"description": "Expose port for inter-container communication"
|
|
},
|
|
{
|
|
"value": "",
|
|
"description": "None"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "port_number",
|
|
"label": "Port Number",
|
|
"schema": {
|
|
"type": "int",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": 30197,
|
|
"min": 1,
|
|
"max": 65535,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_ips",
|
|
"label": "Host IPs",
|
|
"description": "IPs on the host to bind this port",
|
|
"schema": {
|
|
"type": "list",
|
|
"show_if": [
|
|
[
|
|
"bind_mode",
|
|
"=",
|
|
"published"
|
|
]
|
|
],
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "host_ip",
|
|
"label": "Host IP",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"$ref": [
|
|
"definitions/node_bind_ip"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "certificate_id",
|
|
"label": "Certificate",
|
|
"description": "The certificate to use for Frigate.",
|
|
"schema": {
|
|
"type": "int",
|
|
"null": true,
|
|
"$ref": [
|
|
"definitions/certificate"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "storage",
|
|
"label": "",
|
|
"group": "Storage Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "config",
|
|
"label": "Frigate Config Storage",
|
|
"description": "The path to store Frigate Config.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "type",
|
|
"label": "Type",
|
|
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"default": "ix_volume",
|
|
"enum": [
|
|
{
|
|
"value": "host_path",
|
|
"description": "Host Path (Path that already exists on the system)"
|
|
},
|
|
{
|
|
"value": "ix_volume",
|
|
"description": "ixVolume (Dataset created automatically by the system)"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "ix_volume_config",
|
|
"label": "ixVolume Configuration",
|
|
"description": "The configuration for the ixVolume dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"ix_volume"
|
|
]
|
|
],
|
|
"$ref": [
|
|
"normalize/ix_volume"
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "dataset_name",
|
|
"label": "Dataset Name",
|
|
"description": "The name of the dataset to use for storage.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"hidden": true,
|
|
"default": "config"
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl_entries",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": []
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_path_config",
|
|
"label": "Host Path Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"host_path"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": [],
|
|
"$ref": [
|
|
"normalize/acl"
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "path",
|
|
"label": "Host Path",
|
|
"description": "The host path to use for storage.",
|
|
"schema": {
|
|
"type": "hostpath",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "media",
|
|
"label": "Frigate Media Storage",
|
|
"description": "The path to store Frigate Media.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "type",
|
|
"label": "Type",
|
|
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"default": "ix_volume",
|
|
"enum": [
|
|
{
|
|
"value": "host_path",
|
|
"description": "Host Path (Path that already exists on the system)"
|
|
},
|
|
{
|
|
"value": "ix_volume",
|
|
"description": "ixVolume (Dataset created automatically by the system)"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "ix_volume_config",
|
|
"label": "ixVolume Configuration",
|
|
"description": "The configuration for the ixVolume dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"ix_volume"
|
|
]
|
|
],
|
|
"$ref": [
|
|
"normalize/ix_volume"
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "dataset_name",
|
|
"label": "Dataset Name",
|
|
"description": "The name of the dataset to use for storage.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"hidden": true,
|
|
"default": "media"
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl_entries",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": []
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_path_config",
|
|
"label": "Host Path Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"host_path"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": [],
|
|
"$ref": [
|
|
"normalize/acl"
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "path",
|
|
"label": "Host Path",
|
|
"description": "The host path to use for storage.",
|
|
"schema": {
|
|
"type": "hostpath",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "cache",
|
|
"label": "Frigate Cache Storage",
|
|
"description": "The path to store Frigate Cache.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "type",
|
|
"label": "Type",
|
|
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.\ntmpfs: Is a temporary directory that will be created on the RAM.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"default": "ix_volume",
|
|
"enum": [
|
|
{
|
|
"value": "host_path",
|
|
"description": "Host Path (Path that already exists on the system)"
|
|
},
|
|
{
|
|
"value": "ix_volume",
|
|
"description": "ixVolume (Dataset created automatically by the system)"
|
|
},
|
|
{
|
|
"value": "tmpfs",
|
|
"description": "tmpfs (Temporary directory created on the RAM)"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "tmpfs_config",
|
|
"label": "tmpfs Configuration",
|
|
"description": "The configuration for the tmpfs dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"tmpfs"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "size",
|
|
"label": "Tmpfs Size Limit (in Mi)",
|
|
"description": "The maximum size (in Mi) of the temporary directory.</br>\nFor example: 500\n",
|
|
"schema": {
|
|
"type": "int",
|
|
"default": 500,
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "ix_volume_config",
|
|
"label": "ixVolume Configuration",
|
|
"description": "The configuration for the ixVolume dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"ix_volume"
|
|
]
|
|
],
|
|
"$ref": [
|
|
"normalize/ix_volume"
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "dataset_name",
|
|
"label": "Dataset Name",
|
|
"description": "The name of the dataset to use for storage.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"hidden": true,
|
|
"default": "cache"
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl_entries",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": []
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_path_config",
|
|
"label": "Host Path Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"host_path"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": [],
|
|
"$ref": [
|
|
"normalize/acl"
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "path",
|
|
"label": "Host Path",
|
|
"description": "The host path to use for storage.",
|
|
"schema": {
|
|
"type": "hostpath",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "additional_storage",
|
|
"label": "Additional Storage",
|
|
"schema": {
|
|
"type": "list",
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "storageEntry",
|
|
"label": "Storage Entry",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "type",
|
|
"label": "Type",
|
|
"description": "ixVolume: Is dataset created automatically by the system.</br>\nHost Path: Is a path that already exists on the system.</br>\nSMB Share: Is a SMB share that is mounted to as a volume.</br>\nNFS Share: Is a NFS share that is mounted to as a volume.\n",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"default": "ix_volume",
|
|
"enum": [
|
|
{
|
|
"value": "host_path",
|
|
"description": "Host Path (Path that already exists on the system)"
|
|
},
|
|
{
|
|
"value": "ix_volume",
|
|
"description": "ixVolume (Dataset created automatically by the system)"
|
|
},
|
|
{
|
|
"value": "cifs",
|
|
"description": "SMB/CIFS Share (Mounts a volume to a SMB share)"
|
|
},
|
|
{
|
|
"value": "nfs",
|
|
"description": "NFS Share (Mounts a volume to a NFS share)"
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "read_only",
|
|
"label": "Read Only",
|
|
"description": "Mount the volume as read only.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "mount_path",
|
|
"label": "Mount Path",
|
|
"description": "The path inside the container to mount the storage.",
|
|
"schema": {
|
|
"type": "path",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "host_path_config",
|
|
"label": "Host Path Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"host_path"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": [],
|
|
"$ref": [
|
|
"normalize/acl"
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "path",
|
|
"label": "Host Path",
|
|
"description": "The host path to use for storage.",
|
|
"schema": {
|
|
"type": "hostpath",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
false
|
|
]
|
|
],
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "ix_volume_config",
|
|
"label": "ixVolume Configuration",
|
|
"description": "The configuration for the ixVolume dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"ix_volume"
|
|
]
|
|
],
|
|
"$ref": [
|
|
"normalize/ix_volume"
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "acl_enable",
|
|
"label": "Enable ACL",
|
|
"description": "Enable ACL for the storage.",
|
|
"schema": {
|
|
"type": "boolean",
|
|
"default": false
|
|
}
|
|
},
|
|
{
|
|
"variable": "dataset_name",
|
|
"label": "Dataset Name",
|
|
"description": "The name of the dataset to use for storage.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"default": "storage_entry"
|
|
}
|
|
},
|
|
{
|
|
"variable": "acl_entries",
|
|
"label": "ACL Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"acl_enable",
|
|
"=",
|
|
true
|
|
]
|
|
],
|
|
"attrs": [],
|
|
"$ref": [
|
|
"normalize/acl"
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "cifs_config",
|
|
"label": "SMB Configuration",
|
|
"description": "The configuration for the SMB dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"cifs"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "server",
|
|
"label": "Server",
|
|
"description": "The server to mount the SMB share.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "path",
|
|
"label": "Path",
|
|
"description": "The path to mount the SMB share.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "username",
|
|
"label": "Username",
|
|
"description": "The username to use for the SMB share.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "password",
|
|
"label": "Password",
|
|
"description": "The password to use for the SMB share.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"private": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "domain",
|
|
"label": "Domain",
|
|
"description": "The domain to use for the SMB share.",
|
|
"schema": {
|
|
"type": "string"
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "nfs_config",
|
|
"label": "NFS Configuration",
|
|
"description": "The configuration for the NFS dataset.",
|
|
"schema": {
|
|
"type": "dict",
|
|
"show_if": [
|
|
[
|
|
"type",
|
|
"=",
|
|
"nfs"
|
|
]
|
|
],
|
|
"attrs": [
|
|
{
|
|
"variable": "server",
|
|
"label": "Server",
|
|
"description": "The server to mount the NFS share.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "path",
|
|
"label": "Path",
|
|
"description": "The path to mount the NFS share.",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "labels",
|
|
"label": "",
|
|
"group": "Labels Configuration",
|
|
"schema": {
|
|
"type": "list",
|
|
"default": [],
|
|
"items": [
|
|
{
|
|
"variable": "label",
|
|
"label": "Label",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "key",
|
|
"label": "Key",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "value",
|
|
"label": "Value",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "containers",
|
|
"label": "Containers",
|
|
"description": "Containers where the label should be applied",
|
|
"schema": {
|
|
"type": "list",
|
|
"items": [
|
|
{
|
|
"variable": "container",
|
|
"label": "Container",
|
|
"schema": {
|
|
"type": "string",
|
|
"required": true,
|
|
"enum": [
|
|
{
|
|
"value": "frigate",
|
|
"description": "frigate"
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "resources",
|
|
"label": "",
|
|
"group": "Resources Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "limits",
|
|
"label": "Limits",
|
|
"schema": {
|
|
"type": "dict",
|
|
"attrs": [
|
|
{
|
|
"variable": "cpus",
|
|
"label": "CPUs",
|
|
"description": "CPUs limit for Frigate.",
|
|
"schema": {
|
|
"type": "int",
|
|
"default": 2,
|
|
"required": true
|
|
}
|
|
},
|
|
{
|
|
"variable": "memory",
|
|
"label": "Memory (in MB)",
|
|
"description": "Memory limit for Frigate.",
|
|
"schema": {
|
|
"type": "int",
|
|
"default": 4096,
|
|
"required": true
|
|
}
|
|
}
|
|
]
|
|
}
|
|
},
|
|
{
|
|
"variable": "gpus",
|
|
"group": "Resources Configuration",
|
|
"label": "GPU Configuration",
|
|
"schema": {
|
|
"type": "dict",
|
|
"$ref": [
|
|
"definitions/gpu_configuration"
|
|
],
|
|
"attrs": []
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
]
|
|
},
|
|
"readme": "<h1>Frigate</h1> <p><a href=\"https://github.com/blakeblackshear/frigate\">Frigate</a> is an NVR With Realtime Object Detection for IP Cameras</p> <blockquote> <p>Note: Coral <strong>m.2</strong> TPU devices is not supported.</p> </blockquote>",
|
|
"changelog": null,
|
|
"chart_metadata": {
|
|
"annotations": {
|
|
"min_scale_version": "24.10.2.2"
|
|
},
|
|
"app_version": "0.16.2",
|
|
"capabilities": [
|
|
{
|
|
"description": "Frigate is able to change file ownership arbitrarily",
|
|
"name": "CHOWN"
|
|
},
|
|
{
|
|
"description": "Frigate is able to bypass file permission checks",
|
|
"name": "DAC_OVERRIDE"
|
|
},
|
|
{
|
|
"description": "Frigate is able to bypass permission checks for file operations",
|
|
"name": "FOWNER"
|
|
},
|
|
{
|
|
"description": "Frigate is able to send signals to any process",
|
|
"name": "KILL"
|
|
},
|
|
{
|
|
"description": "Frigate is able to access performance monitoring interfaces",
|
|
"name": "PERFMON"
|
|
},
|
|
{
|
|
"description": "Frigate is able to change group ID of processes",
|
|
"name": "SETGID"
|
|
},
|
|
{
|
|
"description": "Frigate is able to change user ID of processes",
|
|
"name": "SETUID"
|
|
}
|
|
],
|
|
"categories": [
|
|
"security"
|
|
],
|
|
"changelog_url": "https://github.com/blakeblackshear/frigate/releases",
|
|
"date_added": "2024-09-12",
|
|
"description": "Frigate is an NVR With Realtime Object Detection for IP Cameras",
|
|
"home": "https://frigate.video/",
|
|
"host_mounts": [],
|
|
"icon": "https://media.sys.truenas.net/apps/frigate/icons/icon.svg",
|
|
"keywords": [
|
|
"camera",
|
|
"nvr"
|
|
],
|
|
"lib_version": "2.1.65",
|
|
"lib_version_hash": "f92a9ee78c78fc77f86e7d8b545bd4c605c31c599e2c5da59f1615aa516cb8b5",
|
|
"maintainers": [
|
|
{
|
|
"email": "dev@truenas.com",
|
|
"name": "truenas",
|
|
"url": "https://www.truenas.com/"
|
|
}
|
|
],
|
|
"name": "frigate",
|
|
"run_as_context": [
|
|
{
|
|
"description": "Frigate runs as root user.",
|
|
"gid": 0,
|
|
"group_name": "root",
|
|
"uid": 0,
|
|
"user_name": "root"
|
|
}
|
|
],
|
|
"screenshots": [
|
|
"https://media.sys.truenas.net/apps/frigate/screenshots/screenshot1.png",
|
|
"https://media.sys.truenas.net/apps/frigate/screenshots/screenshot2.png",
|
|
"https://media.sys.truenas.net/apps/frigate/screenshots/screenshot3.png"
|
|
],
|
|
"sources": [
|
|
"https://github.com/blakeblackshear/frigate"
|
|
],
|
|
"title": "Frigate",
|
|
"train": "community",
|
|
"version": "1.2.24"
|
|
}
|
|
}
|
|
} |