mirror of
https://github.com/blakeblackshear/frigate.git
synced 2026-02-03 17:55:21 +03:00
Integrate with newest changes
This commit is contained in:
parent
21cd553fda
commit
fc43109f3a
@ -4,44 +4,39 @@
|
|||||||
|
|
||||||
set -o errexit -o nounset -o pipefail
|
set -o errexit -o nounset -o pipefail
|
||||||
|
|
||||||
if [[ -z "${SUPERVISOR_TOKEN:-}" ]]; then
|
if [[ -n "${SUPERVISOR_TOKEN:-}" ]]; then
|
||||||
# Not running as a Home Assistant add-on, don't do anything
|
# Running as a Home Assistant add-on, infer the IP address and port
|
||||||
exit 0
|
|
||||||
|
# Example: 192.168.1.10/24
|
||||||
|
ip_regex='^([0-9]{1,3}\.{3}[0-9]{1,3})/[0-9]{1,2}$'
|
||||||
|
if ip_address=$(
|
||||||
|
curl -fsSL \
|
||||||
|
-H "Authorization: Bearer ${SUPERVISOR_TOKEN}" \
|
||||||
|
-H "Content-Type: application/json" \
|
||||||
|
http://supervisor/network/interface/default/info |
|
||||||
|
jq --exit-status --raw-output '.data.ipv4.address[0]'
|
||||||
|
) && [[ "${ip_address}" =~ ${ip_regex} ]]; then
|
||||||
|
ip_address="${BASH_REMATCH[1]}"
|
||||||
|
echo "Got IP address from supervisor: ${ip_address}" >&2
|
||||||
|
else
|
||||||
|
echo "Failed to get IP address from supervisor" >&2
|
||||||
|
fi
|
||||||
|
|
||||||
|
port_regex='^([0-9]{1,5})$'
|
||||||
|
if webrtc_port=$(
|
||||||
|
curl -fsSL \
|
||||||
|
-H "Authorization: Bearer ${SUPERVISOR_TOKEN}" \
|
||||||
|
-H "Content-Type: application/json" \
|
||||||
|
http://supervisor/addons/self/info |
|
||||||
|
jq --exit-status --raw-output '.data.network["22/tcp"]'
|
||||||
|
) && [[ "${webrtc_port}" =~ ${port_regex} ]]; then
|
||||||
|
webrtc_port="${BASH_REMATCH[1]}"
|
||||||
|
echo "Got WebRTC port from supervisor: ${ip_address}" >&2
|
||||||
|
else
|
||||||
|
echo "Failed to get WebRTC port from supervisor" >&2
|
||||||
|
fi
|
||||||
|
|
||||||
|
export FRIGATE_GO2RTC_WEBRTC_CANDIDATE_INTERNAL="${ip_address}:${webrtc_port}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Example: 192.168.1.10/24
|
python3 /usr/local/go2rtc/create_config.py > /dev/shm/go2rtc.yaml
|
||||||
ip_regex='^([0-9]{1,3}\.{3}[0-9]{1,3})/[0-9]{1,2}$'
|
|
||||||
if ip_address=$(
|
|
||||||
curl -fsSL \
|
|
||||||
-H "Authorization: Bearer ${SUPERVISOR_TOKEN}" \
|
|
||||||
-H "Content-Type: application/json" \
|
|
||||||
http://supervisor/network/interface/default/info |
|
|
||||||
jq --exit-status --raw-output '.data.ipv4.address[0]'
|
|
||||||
) && [[ "${ip_address}" =~ ${ip_regex} ]]; then
|
|
||||||
ip_address="${BASH_REMATCH[1]}"
|
|
||||||
echo "Got IP address from supervisor: ${ip_address}" >&2
|
|
||||||
else
|
|
||||||
echo "Failed to get IP address from supervisor" >&2
|
|
||||||
# Exit with success so that the container can still start
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
port_regex='^([0-9]{1,5})$'
|
|
||||||
if webrtc_port=$(
|
|
||||||
curl -fsSL \
|
|
||||||
-H "Authorization: Bearer ${SUPERVISOR_TOKEN}" \
|
|
||||||
-H "Content-Type: application/json" \
|
|
||||||
http://supervisor/addons/self/info |
|
|
||||||
jq --exit-status --raw-output '.data.network["8555/tcp"]'
|
|
||||||
) && [[ "${webrtc_port}" =~ ${port_regex} ]]; then
|
|
||||||
webrtc_port="${BASH_REMATCH[1]}"
|
|
||||||
echo "Got WebRTC port from supervisor: ${ip_address}" >&2
|
|
||||||
else
|
|
||||||
echo "Failed to get WebRTC port from supervisor" >&2
|
|
||||||
# Exit with success so that the container can still start
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Replace the IP address in the config
|
|
||||||
candidate="${ip_address}:${webrtc_port}"
|
|
||||||
sed --in-place "s/# - %%CANDIDATE%%/- ${candidate}/" /usr/local/go2rtc/go2rtc.yaml
|
|
||||||
|
|||||||
@ -2,10 +2,6 @@
|
|||||||
# shellcheck shell=bash
|
# shellcheck shell=bash
|
||||||
# Start the go2rtc service
|
# Start the go2rtc service
|
||||||
|
|
||||||
set -o errexit -o nounset -o pipefail
|
|
||||||
|
|
||||||
raw_config=$(python3 /usr/local/go2rtc/create_config.py)
|
|
||||||
|
|
||||||
# Replace the bash process with the go2rtc process, redirecting stderr to stdout
|
# Replace the bash process with the go2rtc process, redirecting stderr to stdout
|
||||||
exec 2>&1
|
exec 2>&1
|
||||||
exec go2rtc -config="${raw_config}"
|
exec go2rtc -config=/dev/shm/go2rtc.yaml
|
||||||
|
|||||||
@ -25,7 +25,15 @@ go2rtc_config: dict[str, any] = config["go2rtc"]
|
|||||||
if not go2rtc_config.get("log", {}).get("format"):
|
if not go2rtc_config.get("log", {}).get("format"):
|
||||||
go2rtc_config["log"] = {"format": "text"}
|
go2rtc_config["log"] = {"format": "text"}
|
||||||
|
|
||||||
|
default_candidates = []
|
||||||
|
# Use FRIGATE_GO2RTC_WEBRTC_CANDIDATE_INTERNAL as candidate if set
|
||||||
|
if os.environ.get("FRIGATE_GO2RTC_WEBRTC_CANDIDATE_INTERNAL"):
|
||||||
|
default_candidates.append(
|
||||||
|
os.environ['FRIGATE_GO2RTC_WEBRTC_CANDIDATE_INTERNAL']
|
||||||
|
)55
|
||||||
|
default_candidates.append("stun:85")
|
||||||
|
|
||||||
if not go2rtc_config.get("webrtc", {}).get("candidates", []):
|
if not go2rtc_config.get("webrtc", {}).get("candidates", []):
|
||||||
go2rtc_config["webrtc"] = {"candidates": ["stun:8555"]}
|
go2rtc_config["webrtc"] = {"candidates": default_candidates}
|
||||||
|
|
||||||
print(json.dumps(go2rtc_config))
|
print(json.dumps(go2rtc_config))
|
||||||
Loading…
Reference in New Issue
Block a user