mirror of
https://github.com/libretro/Lakka-LibreELEC.git
synced 2025-01-19 14:12:08 +00:00
178 lines
5.1 KiB
Bash
Executable File
178 lines
5.1 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
# Copyright (C) 2016-present Team LibreELEC (https://libreelec.tv)
|
|
|
|
. /etc/profile
|
|
|
|
oe_setup_addon service.tvheadend42
|
|
|
|
ADDON_SETTINGS="$ADDON_HOME/settings.xml"
|
|
|
|
COMSKIP_DIR="$ADDON_HOME/comskip"
|
|
COMSKIP_SETTINGS_FILE="$COMSKIP_DIR/comskip.ini"
|
|
|
|
DVR_SETTINGS_DIR="$ADDON_HOME/dvr/config"
|
|
DVR_SETTINGS_FILE="$DVR_SETTINGS_DIR/8d0f5b7ae354d956d7fe5db25f5d0d24"
|
|
|
|
EPGGRAB_SETTINGS_DIR="$ADDON_HOME/epggrab"
|
|
EPGGRAB_SETTINGS_FILE="$EPGGRAB_SETTINGS_DIR/config"
|
|
|
|
TIMESHIFT_SETTINGS_DIR="$ADDON_HOME/timeshift"
|
|
TIMESHIFT_SETTINGS_FILE="$TIMESHIFT_SETTINGS_DIR/config"
|
|
|
|
TVH_SETTINGS_DIR="$ADDON_HOME"
|
|
TVH_SETTINGS_FILE="$TVH_SETTINGS_DIR/config"
|
|
|
|
XMLTV_SETTINGS_DIR="$ADDON_HOME/xmltv"
|
|
XMLTV_SETTINGS_FILE="$XMLTV_SETTINGS_DIR/config"
|
|
|
|
TIMESHIFT_DIR="$ADDON_HOME/cache/timeshift"
|
|
XMLTV_FILE="$ADDON_DIR/bin/tv_grab_file"
|
|
|
|
chmod a+x $ADDON_DIR/bin/*
|
|
|
|
# workaround to support old 4.1.x version upgrade for Tvh after 4.1.2369
|
|
if [ -f "$ADDON_HOME/dvr/config/dvr-config" ]; then
|
|
rm $ADDON_HOME/dvr/config/dvr-config
|
|
fi
|
|
|
|
# workaround to create default Tvh directories without entering samba share
|
|
if [ ! -d "/storage/recordings" ]; then
|
|
mkdir -p /storage/recordings /storage/picons/tvh /storage/picons/vdr
|
|
fi
|
|
|
|
if [ -f "$ADDON_HOME/channel/config/config.tmp" ]; then
|
|
rm $ADDON_HOME/channel/config/config.tmp
|
|
fi
|
|
|
|
if [ -f "$ADDON_HOME/channel/config/tag.tmp" ]; then
|
|
rm $ADDON_HOME/channel/config/tag.tmp
|
|
fi
|
|
|
|
# copy config files to userdata
|
|
if [ ! -f "$COMSKIP_SETTINGS_FILE" ]; then
|
|
mkdir -p $COMSKIP_DIR
|
|
cp $ADDON_DIR/defaults/comskip/comskip.ini $COMSKIP_SETTINGS_FILE
|
|
fi
|
|
|
|
if [ ! -f "$DVR_SETTINGS_FILE" ]; then
|
|
mkdir -p $DVR_SETTINGS_DIR
|
|
cp $ADDON_DIR/defaults/dvr/config/8d0f5b7ae354d956d7fe5db25f5d0d24 $DVR_SETTINGS_FILE
|
|
fi
|
|
|
|
if [ ! -f "$EPGGRAB_SETTINGS_FILE" ]; then
|
|
mkdir -p $EPGGRAB_SETTINGS_DIR
|
|
cp $ADDON_DIR/defaults/epggrab/config $EPGGRAB_SETTINGS_FILE
|
|
fi
|
|
|
|
if [ ! -f "$TIMESHIFT_SETTINGS_FILE" ]; then
|
|
mkdir -p $TIMESHIFT_DIR
|
|
mkdir -p $TIMESHIFT_SETTINGS_DIR
|
|
cp $ADDON_DIR/defaults/timeshift/config $TIMESHIFT_SETTINGS_FILE
|
|
fi
|
|
|
|
if [ ! -f "$TVH_SETTINGS_FILE" ]; then
|
|
mkdir -p $TVH_SETTINGS_DIR
|
|
cp $ADDON_DIR/defaults/config $TVH_SETTINGS_FILE
|
|
fi
|
|
|
|
if [ ! -f "$XMLTV_SETTINGS_FILE" ]; then
|
|
mkdir -p $XMLTV_SETTINGS_DIR
|
|
cp $ADDON_DIR/defaults/xmltv/config $XMLTV_SETTINGS_FILE
|
|
fi
|
|
|
|
# delayed Tvh startup
|
|
if [ "$WORKAROUND_SLEEP" == "true" ]; then
|
|
sleep $WORKAROUND_SLEEP_TIME
|
|
fi
|
|
|
|
# support FritzBox Sat>IP Server detection workaround for AVM-Repeater and AVM-6490
|
|
if [ "$AVM_SATIP_SERVER" == "true" ]; then
|
|
if [ "$AVM_DEVICE" == "AVM_Repeater" ]; then
|
|
AVM_SATIP="--satip_xml http://${AVM_ROUTER_IP}:49000/satipdesc.xml"
|
|
fi
|
|
if [ "$AVM_DEVICE" == "AVM_6490" ]; then
|
|
AVM_SATIP="--satip_xml http://${AVM_ROUTER_FAKE_IP}:49000/satipdesc.xml"
|
|
AVM_NUM="4"
|
|
fi
|
|
|
|
# add virtual ip as workaround for AVM limitation of one stream per ip
|
|
# AVM-Repeater (2 tuners)
|
|
ip address add ${AVM_IP1}/24 dev $AVM_ETH
|
|
ip address add ${AVM_IP2}/24 dev $AVM_ETH
|
|
|
|
# AVM-6490 (4 tuners)
|
|
if [ "$AVM_NUM" = "4" ]; then
|
|
ip address add ${AVM_IP3}/24 dev $AVM_ETH
|
|
ip address add ${AVM_IP4}/24 dev $AVM_ETH
|
|
fi
|
|
fi
|
|
|
|
# custom startup parameters
|
|
if [ "$CUSTOM_START" != "true" ]; then
|
|
CUSTOM_ARGS=""
|
|
fi
|
|
|
|
# debug value generation
|
|
if [ "$DEBUG_LOG_TRACE_1" != "NONE" ]; then
|
|
DEBUG_LOG_ARG="$DEBUG_LOG_TRACE_1"
|
|
fi
|
|
|
|
if [ "$DEBUG_LOG_TRACE_2" != "NONE" ]; then
|
|
DEBUG_LOG_ARG="$DEBUG_LOG_ARG,$DEBUG_LOG_TRACE_2"
|
|
fi
|
|
|
|
if [ "$DEBUG_LOG_TRACE_3" != "NONE" ]; then
|
|
DEBUG_LOG_ARG="$DEBUG_LOG_ARG,$DEBUG_LOG_TRACE_3"
|
|
fi
|
|
|
|
if [ "$DEBUG_LOG_TRACE_4" != "NONE" ]; then
|
|
DEBUG_LOG_ARG="$DEBUG_LOG_ARG,$DEBUG_LOG_TRACE_4"
|
|
fi
|
|
|
|
if [ "$DEBUG_LOG_TRACE_5" != "NONE" ]; then
|
|
DEBUG_LOG_ARG="$DEBUG_LOG_ARG,$DEBUG_LOG_TRACE_5"
|
|
fi
|
|
|
|
# if debuglog is activated and nothing selected to trace
|
|
if [ -z "$DEBUG_LOG_ARG" ];then
|
|
DEBUG_LOG_ARG="all"
|
|
fi
|
|
|
|
# rename debuglog if already exist to prevent overwriting after crash
|
|
if [ -f "${DEBUG_LOG_PATH}" ]; then
|
|
cp ${DEBUG_LOG_PATH} ${DEBUG_LOG_PATH}_$(date '+%Y-%m-%d_%H.%M.%S').txt
|
|
fi
|
|
|
|
# debug commandline
|
|
if [ "$DEBUG_LOG" = "true" ]; then
|
|
TVHEADEND_ARG="-B -C -u root -g video -c $ADDON_HOME $AVM_SATIP $CUSTOM_ARGS -l ${DEBUG_LOG_PATH} --trace $DEBUG_LOG_ARG"
|
|
else
|
|
TVHEADEND_ARG="-B -C -u root -g video -c $ADDON_HOME $AVM_SATIP $CUSTOM_ARGS"
|
|
fi
|
|
|
|
# start userspace DVB driver/addon
|
|
for driver_dvb in $(find /storage/.kodi/addons/driver.dvb.*/bin/userspace-driver.sh -type f 2>/dev/null); do
|
|
driver_dvb_name=$(echo $driver_dvb | awk 'BEGIN {FS="/"} {printf("%s", $5)}')
|
|
logger -t Tvheadend "### Loading userspace DVB driver: $driver_dvb_name ###"
|
|
# use ". " because of variable export
|
|
. $driver_dvb
|
|
done
|
|
|
|
if [ "$WAIT_FOR_FEINIT" == "true" ] ; then
|
|
while [ true ] ; do
|
|
if [ -e /dev/dvb/adapter$((NUM_ADAPTERS-1))/frontend0 ] ; then
|
|
break
|
|
fi
|
|
sleep 1
|
|
done
|
|
fi
|
|
|
|
if [ "$PRELOAD_CAPMT_CA" == "true" ] ; then
|
|
logger -t Tvheadend "### Preloading capmt_ca.so library ###"
|
|
LD_PRELOAD="$ADDON_DIR/bin/capmt_ca.so $LD_PRELOAD" exec $ADDON_DIR/bin/tvheadend $TVHEADEND_ARG &>$ADDON_LOG_FILE
|
|
else
|
|
exec $ADDON_DIR/bin/tvheadend $TVHEADEND_ARG &>$ADDON_LOG_FILE
|
|
fi
|