473 lines
20 KiB
YAML
473 lines
20 KiB
YAML
image:
|
|
repository: tccr.io/truecharts/frigate
|
|
pullPolicy: IfNotPresent
|
|
tag: 0.11.1@sha256:8dd7273eebf396563d7bbc14778fd3d58c624e5063ffcf74b5b0afe63e7cdd7f
|
|
|
|
securityContext:
|
|
readOnlyRootFilesystem: false
|
|
runAsNonRoot: false
|
|
|
|
podSecurityContext:
|
|
runAsUser: 0
|
|
runAsGroup: 0
|
|
|
|
global:
|
|
isSCALE: true
|
|
|
|
# -- In most cases the "enabled" key is only used internally to "render" or not the configuration
|
|
# - Some parts of the config bellow are slightly modified so they can be added on SCALE UI. Mainly lists.
|
|
# - Do not blindly copy paste configuration from upstream.
|
|
frigate:
|
|
mqtt:
|
|
host: mqtt.server.com
|
|
port: 1883
|
|
# -- NOTE: Must be unique if you are running multiple instances
|
|
topic_prefix: frigate
|
|
# -- NOTE: Must be unique if you are running multiple instances
|
|
client_id: frigate
|
|
user: mqtt_user
|
|
password: password
|
|
stats_interval: 60
|
|
|
|
detectors:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
config:
|
|
[]
|
|
# -- Required: Name of the detector
|
|
# - name: coral
|
|
# # -- Valid values are 'edgetpu' (requires device property below) and 'cpu'.
|
|
# type: edgetpu
|
|
# # -- Device name as defined here: https://coral.ai/docs/edgetpu/multiple-edgetpu/#using-the-tensorflow-lite-python-api
|
|
# device: usb
|
|
# # -- This value is only used for CPU types
|
|
# num_threads: 3
|
|
|
|
model:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Path to the model
|
|
path: /edgetpu_model.tflite
|
|
# -- Optional: Path to the labelmap
|
|
labelmap_path: /labelmap.txt
|
|
# -- Required: Object detection model input width
|
|
width: 320
|
|
# -- Required: Object detection model input height
|
|
height: 320
|
|
# -- Optional: Label name modifications.
|
|
labelmap:
|
|
[]
|
|
# - model: "2"
|
|
# name: vehicle
|
|
# - model: 3
|
|
# name: vehicle
|
|
|
|
logger:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Default log verbosity (default: shown below)
|
|
default: info
|
|
# -- Optional: Component specific logger overrides
|
|
logs:
|
|
- component: frigate.event
|
|
verbosity: debug
|
|
|
|
birdseye:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Enables birdseye
|
|
enabled: true
|
|
# -- Optional: Width of the output resolution
|
|
width: 1280
|
|
# -- Optional: Height of the output resolution
|
|
height: 720
|
|
# -- Optional: Encoding quality of the mpeg1 feed
|
|
# - 1 is the highest quality, and 31 is the lowest. Lower quality feeds utilize less CPU resources.
|
|
quality: 8
|
|
# -- Optional: Mode of the view. Available options are: objects, motion, and continuous
|
|
# - objects - cameras are included if they have had a tracked object within the last 30 seconds
|
|
# - motion - cameras are included if motion was detected in the last 30 seconds
|
|
# - continuous - all cameras are included always
|
|
mode: objects
|
|
|
|
ffmpeg:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: global ffmpeg args
|
|
global_args: -hide_banner -loglevel warning
|
|
# -- Optional: global input args
|
|
input_args: -avoid_negative_ts make_zero -fflags +genpts+discardcorrupt -rtsp_transport tcp -timeout 5000000 -use_wallclock_as_timestamps 1
|
|
# -- Optional: global hwaccel args
|
|
# - NOTE: See hardware acceleration docs for your specific device
|
|
hwaccel_args: ""
|
|
# -- Optional: global output args
|
|
output_args:
|
|
# -- Optional: output args for detect streams
|
|
detect: -f rawvideo -pix_fmt yuv420p
|
|
# -- Optional: output args for record streams
|
|
record: -f segment -segment_time 10 -segment_format mp4 -reset_timestamps 1 -strftime 1 -c copy -an
|
|
# -- Optional: output args for rtmp streams
|
|
rtmp: -c copy -f flv
|
|
|
|
detect:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Enables detection for the camera.
|
|
# - This value can be set via MQTT and will be updated in startup based on retained value
|
|
enabled: true
|
|
# -- Optional: width of the frame for the input with the detect role
|
|
width: 1280
|
|
# -- Optional: height of the frame for the input with the detect role
|
|
height: 720
|
|
# -- Optional: desired fps for your camera for the input with the detect role
|
|
# - NOTE: Recommended value of 5. Ideally, try and reduce your FPS on the camera.
|
|
fps: 5
|
|
# -- Optional: Number of frames without a detection before frigate considers an object to be gone. (default: 5x the frame rate)
|
|
max_disappeared: 25
|
|
# -- Optional: Configuration for stationary object tracking
|
|
stationary:
|
|
# -- Optional: Frequency for confirming stationary objects
|
|
# - When set to 0, object detection will not confirm stationary objects until movement is detected.
|
|
# - If set to 10, object detection will run to confirm the object still exists on every 10th frame.
|
|
interval: 0
|
|
# -- Optional: Number of frames without a position change for an object to be considered stationary (default: 10x the frame rate or 10s)
|
|
threshold: 50
|
|
# -- Optional: Define a maximum number of frames for tracking a stationary object (default: not set, track forever)
|
|
# - This can help with false positives for objects that should only be stationary for a limited amount of time.
|
|
# - It can also be used to disable stationary object tracking. For example, you may want to set a value for person, but leave
|
|
# - car at the default.
|
|
# - WARNING: Setting these values overrides default behavior and disables stationary object tracking.
|
|
# - There are very few situations where you would want it disabled. It is NOT recommended to
|
|
# - copy these values from the example config into your config unless you know they are needed.
|
|
# max_frames:
|
|
# # -- Optional: Default for all object types (default: not set, track forever)
|
|
# default:
|
|
# # -- Optional: Object specific values
|
|
# objects:
|
|
# - object: person
|
|
# frames: 1000
|
|
|
|
objects:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: list of objects to track from labelmap.txt
|
|
track:
|
|
- person
|
|
# -- Optional: mask to prevent all object types from being detected in certain areas (default: no mask)
|
|
# - Checks based on the bottom center of the bounding box of the object.
|
|
# - NOTE: This mask is COMBINED with the object type specific mask below
|
|
mask: 0,0,1000,0,1000,200,0,200
|
|
# - Optional: filters to reduce false positives for specific object types
|
|
filters:
|
|
[]
|
|
# - object: person
|
|
# # -- Optional: Minimum width*height of the bounding box for the detected object
|
|
# min_area: 5000
|
|
# # -- Optional: Maximum width*height of the bounding box for the detected object
|
|
# max_area: 100000
|
|
# # -- Optional: Minimum width/height of the bounding box for the detected object
|
|
# min_ratio: 0.5
|
|
# # -- Optional: Maximum width/height of the bounding box for the detected object
|
|
# max_ratio: 2.0
|
|
# # -- Optional: Minimum score for the object to initiate tracking
|
|
# min_score: 0.5
|
|
# # -- Optional: Minimum decimal percentage for tracked object's computed score to be considered a true positive
|
|
# threshold: 0.7
|
|
# # -- Optional: Mask to prevent this object type from being detected in certain areas
|
|
# # - Checks based on the bottom center of the bounding box of the object
|
|
# mask: 0,0,1000,0,1000,200,0,200
|
|
|
|
motion:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: The threshold passed to cv2.threshold to determine if a pixel is different enough to be counted as motion.
|
|
# - Increasing this value will make motion detection less sensitive and decreasing it will make motion detection more sensitive.
|
|
# - The value should be between 1 and 255.
|
|
threshold: 25
|
|
# -- Optional: Minimum size in pixels in the resized motion image that counts as motion
|
|
# - Increasing this value will prevent smaller areas of motion from being detected. Decreasing will
|
|
# - make motion detection more sensitive to smaller moving objects.
|
|
# - As a rule of thumb:
|
|
# - 15 - high sensitivity
|
|
# - 30 - medium sensitivity
|
|
# - 50 - low sensitivity
|
|
contour_area: 30
|
|
# -- Optional: Alpha value passed to cv2.accumulateWeighted when averaging the motion delta across multiple frames
|
|
# - Higher values mean the current frame impacts the delta a lot, and a single raindrop may register as motion.
|
|
# - Too low and a fast moving person wont be detected as motion.
|
|
delta_alpha: 0.2
|
|
# -- Optional: Alpha value passed to cv2.accumulateWeighted when averaging frames to determine the background
|
|
# - Higher values mean the current frame impacts the average a lot, and a new object will be averaged into the background faster.
|
|
# - Low values will cause things like moving shadows to be detected as motion for longer.
|
|
# - https://www.geeksforgeeks.org/background-subtraction-in-an-image-using-concept-of-running-average/
|
|
frame_alpha: 0.2
|
|
# -- Optional: Height of the resized motion frame (default: 50)
|
|
# - This operates as an efficient blur alternative. Higher values will result in more granular motion detection at the expense
|
|
# - of higher CPU usage. Lower values result in less CPU, but small changes may not register as motion.
|
|
frame_height: 50
|
|
# -- Optional: motion mask
|
|
# - NOTE: see docs for more detailed info on creating masks
|
|
mask: 0,900,1080,900,1080,1920,0,1920
|
|
# -- Optional: improve contrast
|
|
# - Enables dynamic contrast improvement. This should help improve night detections at the cost of making motion detection more sensitive
|
|
# - for daytime.
|
|
improve_contrast: false
|
|
# -- Optional: Delay when updating camera motion through MQTT from ON -> OFF
|
|
mqtt_off_delay: 30
|
|
|
|
record:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Enable recording
|
|
# - WARNING: If recording is disabled in the config, turning it on via
|
|
# - the UI or MQTT later will have no effect.
|
|
# - WARNING: Frigate does not currently support limiting recordings based
|
|
# - on available disk space automatically. If using recordings,
|
|
# - you must specify retention settings for a number of days that
|
|
# - will fit within the available disk space of your drive or Frigate will crash.
|
|
enabled: false
|
|
# -- Optional: Number of minutes to wait between cleanup runs
|
|
# - This can be used to reduce the frequency of deleting recording segments from disk if you want to minimize i/o
|
|
expire_interval: 60
|
|
# -- Optional: Retention settings for recording
|
|
retain:
|
|
# -- Render retain config
|
|
render_config: false
|
|
# -- Optional: Number of days to retain recordings regardless of events
|
|
# - NOTE: This should be set to 0 and retention should be defined in events section below
|
|
# - if you only want to retain recordings of events.
|
|
days: 0
|
|
# -- Optional: Mode for retention. Available options are: all, motion, and active_objects
|
|
# - all - save all recording segments regardless of activity
|
|
# - motion - save all recordings segments with any detected motion
|
|
# - active_objects - save all recording segments with active/moving objects
|
|
# - NOTE: this mode only applies when the days setting above is greater than 0
|
|
mode: all
|
|
# -- Optional: Event recording settings
|
|
events:
|
|
# -- Optional: Number of seconds before the event to include
|
|
pre_capture: 5
|
|
# -- Optional: Number of seconds after the event to include
|
|
post_capture: 5
|
|
# -- Optional: Objects to save recordings for. Defaults to all
|
|
objects:
|
|
[]
|
|
# - person
|
|
# -- Optional: Restrict recordings to objects that entered any of the listed zones
|
|
required_zones: []
|
|
# -- Optional: Retention settings for recordings of events
|
|
retain:
|
|
# -- Render retain config
|
|
render_config: false
|
|
# -- Required: Default retention days
|
|
default: 10
|
|
# -- Optional: Mode for retention.
|
|
# - all - save all recording segments for events regardless of activity
|
|
# - motion - save all recordings segments for events with any detected motion
|
|
# - active_objects - save all recording segments for event with active/moving objects
|
|
mode: motion
|
|
# -- Optional: Per object retention days
|
|
objects:
|
|
- object: person
|
|
days: 15
|
|
|
|
snapshots:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Enable writing jpg snapshot to /media/frigate/clips
|
|
# - This value can be set via MQTT and will be updated in startup based on retained value
|
|
enabled: false
|
|
# -- Optional: Save a clean PNG copy of the snapshot image
|
|
clean_copy: true
|
|
# -- Optional: print a timestamp on the snapshots
|
|
timestamp: false
|
|
# -- Optional: draw bounding box on the snapshots
|
|
bounding_box: false
|
|
# -- Optional: crop the snapshot
|
|
crop: false
|
|
# -- Optional: height to resize the snapshot to (default: original size)
|
|
height:
|
|
# -- Optional: Restrict snapshots to objects that entered any of the listed zones (default: no required zones)
|
|
required_zones: []
|
|
# -- Optional: Camera override for retention settings (default: global values)
|
|
retain:
|
|
# -- Render retain config
|
|
render_config: false
|
|
# -- Required: Default retention days (default: shown below)
|
|
default: 10
|
|
# -- Optional: Per object retention days
|
|
objects:
|
|
- object: person
|
|
days: 15
|
|
|
|
rtmp:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# - Optional: Enable the RTMP stream
|
|
enabled: true
|
|
|
|
live:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Set the height of the live stream. (default: 720)
|
|
# - This must be less than or equal to the height of the detect stream. Lower resolutions
|
|
# - reduce bandwidth required for viewing the live stream. Width is computed to match known aspect ratio.
|
|
height: 720
|
|
# -- Optional: Set the encode quality of the live stream (default: shown below)
|
|
# - 1 is the highest quality, and 31 is the lowest. Lower quality feeds utilize less CPU resources.
|
|
quality: 8
|
|
|
|
timestamp_style:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Position of the timestamp
|
|
# - "tl" (top left), "tr" (top right), "bl" (bottom left), "br" (bottom right)
|
|
position: "tl"
|
|
# -- Optional: Format specifier conform to the Python package "datetime"
|
|
# - Additional Examples:
|
|
# - german: "%d.%m.%Y %H:%M:%S"
|
|
format: "%m/%d/%Y %H:%M:%S"
|
|
# -- Optional: Color of font
|
|
color:
|
|
# -- All Required when color is specified (default: shown below)
|
|
red: 255
|
|
green: 255
|
|
blue: 255
|
|
# -- Optional: Line thickness of font (default: shown below)
|
|
thickness: 2
|
|
# -- Optional: Effect of lettering (default: shown below)
|
|
# - None (No effect),
|
|
# - "solid" (solid background in inverse color of font)
|
|
# - "shadow" (shadow for font)
|
|
effect: None
|
|
|
|
cameras:
|
|
# -- Required: name of the camera
|
|
- camera_name: back
|
|
# -- Required: ffmpeg settings for the camera
|
|
ffmpeg:
|
|
# -- Required: A list of input streams for the camera. See documentation for more information.
|
|
inputs:
|
|
# -- Required: the path to the stream
|
|
- path: rtsp://viewer:password@10.0.10.10:554/cam/realmonitor?channel=1&subtype=2
|
|
# -- Required: list of roles for this stream. valid values are: detect,record,rtmp
|
|
# - NOTICE: In addition to assigning the record, and rtmp roles,
|
|
# - they must also be enabled in the camera config.
|
|
roles:
|
|
- detect
|
|
- rtmp
|
|
# -- Optional: stream specific global args
|
|
global_args:
|
|
# - Optional: stream specific hwaccel args
|
|
hwaccel_args:
|
|
# - Optional: stream specific input args
|
|
input_args:
|
|
# -- Optional: camera specific global args
|
|
global_args:
|
|
# -- Optional: camera specific hwaccel args
|
|
hwaccel_args:
|
|
# -- Optional: camera specific input args
|
|
input_args:
|
|
# -- Optional: camera specific output args
|
|
output_args:
|
|
# -- Optional: timeout for highest scoring image before allowing it
|
|
# - to be replaced by a newer image.
|
|
best_image_timeout: 60
|
|
# -- Optional: zones for this camera
|
|
zones:
|
|
# -- Required: name of the zone
|
|
# - NOTE: This must be different than any camera names, but can match with another zone on another camera
|
|
- name: front_steps
|
|
# -- Required: List of x,y coordinates to define the polygon of the zone.
|
|
# - NOTE: Presence in a zone is evaluated only based on the bottom center of the objects bounding box.
|
|
coordinates: 545,1077,747,939,788,805
|
|
# -- Optional: List of objects that can trigger this zone (default: all tracked objects)
|
|
objects:
|
|
- person
|
|
# -- Optional: Zone level object filters.
|
|
# -NOTE: The global and camera filters are applied upstream.
|
|
filters:
|
|
- object: person
|
|
min_area: 5000
|
|
max_area: 100000
|
|
threshold: 0.7
|
|
# -- Optional: Configuration for the jpg snapshots published via MQTT
|
|
mqtt:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Enable publishing snapshot via mqtt for camera
|
|
# - NOTE: Only applies to publishing image data to MQTT via 'frigate/<camera_name>/<object_name>/snapshot'.
|
|
# - All other messages will still be published.
|
|
enabled: true
|
|
# -- Optional: print a timestamp on the snapshots
|
|
timestamp: true
|
|
# -- Optional: draw bounding box on the snapshots
|
|
bounding_box: true
|
|
# -- Optional: crop the snapshot
|
|
crop: true
|
|
# -- Optional: height to resize the snapshot to
|
|
height: 270
|
|
# -- Optional: jpeg encode quality
|
|
quality: 70
|
|
# -- Optional: Restrict mqtt messages to objects that entered any of the listed zones
|
|
required_zones: []
|
|
# -- Optional: Configuration for how camera is handled in the GUI.
|
|
ui:
|
|
# -- Enable it to add the configuration in the config file
|
|
render_config: false
|
|
# -- Optional: Adjust sort order of cameras in the UI. Larger numbers come later
|
|
# - By default the cameras are sorted alphabetically.
|
|
order: 0
|
|
# -- Optional: Whether or not to show the camera in the Frigate UI
|
|
dashboard: true
|
|
|
|
ingress:
|
|
rtmp:
|
|
autoLink: true
|
|
|
|
service:
|
|
main:
|
|
ports:
|
|
main:
|
|
port: 10500
|
|
protocol: HTTP
|
|
targetPort: 5000
|
|
rtmp:
|
|
enabled: true
|
|
ports:
|
|
rtmp:
|
|
enabled: true
|
|
port: 1935
|
|
targetPort: 1935
|
|
|
|
persistence:
|
|
media:
|
|
enabled: true
|
|
mountPath: /media
|
|
size: 256Gi
|
|
db:
|
|
enabled: true
|
|
mountPath: /db
|
|
size: 256Gi
|
|
type: emptyDir
|
|
cache:
|
|
enabled: true
|
|
mountPath: /tmp/cache
|
|
type: emptyDir
|
|
shm:
|
|
enabled: true
|
|
mountPath: /dev/shm
|
|
type: emptyDir
|
|
medium: Memory
|
|
frigate-config:
|
|
enabled: true
|
|
mountPath: /config
|
|
type: configMap
|
|
objectName: '{{ template "tc.common.names.fullname" . }}-frigate-config'
|
|
items:
|
|
- key: config.yml
|
|
path: config.yml
|
|
|
|
portal:
|
|
enabled: true
|