diff options
author | Udo Richter <udo_richter@gmx.de> | 2008-03-02 00:00:00 +0100 |
---|---|---|
committer | Manuel Reimer <manuel.reimer@gmx.de> | 2013-10-01 17:18:45 +0200 |
commit | 207697bc97e1ac8905c14baac311769e02834330 (patch) | |
tree | 458ffeb0ecb1da1ff2a9afd446ca200449498453 | |
parent | 6d08550184e9d6d801d67882a827da46fadcdb66 (diff) | |
download | runvdr-extreme-0.3.0.tar.gz runvdr-extreme-0.3.0.tar.bz2 |
Version 0.3.0v0.3.0
* New: Support for the new VDR parameters --localedir and --userdump (LOCALEDIR="..." and USERDUMP="1")
* New: Wildcard loading with INCLUDE, allows for example to INCLUDE /etc/runvdr/conf.d/* to load several one-file-per-plugin config files.
* New: runvdr-conf.d, a plugin enable/disable service
* New: osdserver frontend for runvdr-conf.d
* New: Sample init.d script, Debian style
* Fix: Clean up mess with USER= and VDRUSER=. VDRUSER still works, but is deprecated.
-rw-r--r-- | HISTORY | 12 | ||||
-rw-r--r-- | README | 63 | ||||
-rw-r--r-- | README.de | 65 | ||||
-rwxr-xr-x | init.d.runvdr.Debian | 83 | ||||
-rwxr-xr-x | runvdr | 158 | ||||
-rwxr-xr-x | runvdr-conf.d | 425 | ||||
-rw-r--r-- | runvdr.conf.example | 17 | ||||
-rw-r--r-- | skeleton.example | 7 |
8 files changed, 759 insertions, 71 deletions
@@ -1,6 +1,18 @@ runvdr extreme Revision History ------------------------------- + +2008-03-02: Version 0.3.0 +- New: Support for the new VDR parameters --localedir and --userdump + (LOCALEDIR="..." and USERDUMP="1") +- New: Wildcard loading with INCLUDE, allows for example to INCLUDE + /etc/runvdr/conf.d/* to load several one-file-per-plugin config files. +- New: runvdr-conf.d, a plugin enable/disable service +- New: osdserver frontend for runvdr-conf.d +- New: Sample init.d script, Debian style +- Fix: Clean up mess with USER= and VDRUSER=. VDRUSER still works, + but is deprecated. + 2007-02-18: Version 0.2.0 - New: Pass DVBLOAD and DVBUNLOAD to eval, allows to execute more than one @@ -32,6 +32,14 @@ Some of the features of runvdr extreme: - Can set locale for VDR daemon - Optionally supports pluginsetup-plugin +Additional features of runvdr-conf.d: + +- Loads configuration files in alphabetical order from a + directory, comparable to init.d directories. +- Command line tool to activate/deactivate plugins +- Control the load order of plugins +- Optional: Menu configuration using osdserver plugin + Quick-start @@ -44,6 +52,17 @@ Quick-start The runvdr.conf is pretty much self-explaining. All runvdr.conf options are also available on command line, see --help. +For the init-script (Debian): +- Copy init.d.runvdr.Debian to /etc/init.d/runvdr +- Use update-rc.d to set up startup runlevel + +For runvdr-conf.d: +- Copy runvdr-conf.d to /usr/local/bin/ +- Create /etc/runvdr/ and fill it with files like skeleton.example +- Add INCLUDE /etc/runvdr/conf.d/* to runvdr.conf +- Use runvdr-conf.d show|enable|disable to configure the plugins +- (Optional) Add "runvdr-conf.d osdserver" to commands.conf. + Details @@ -63,6 +82,11 @@ file from a runvdr.conf by using the INCLUDE directive. For example, you can load /etc/runvdr.conf from within ~/.runvdr.conf to just override some of the settings for the current user. +The INCLUDE directive also supports multiple files per line. By that, you can +use INCLUDE /etc/runvdr/conf.d/* to load a whole directory full of config +files at once. For example, you can put files (or symlinks) for each plugin +to load into that directory, containing a single line "AddPlugin xxx". + Plugins added by the AddPlugin directive in the conf file and the --plugin and -P command line option can be removed again from the list of plugins by specifying "AddPlugin -name", --plugin="-name" or -P-name. @@ -77,6 +101,45 @@ All parameters after -- will be directly passed to VDR. For erxample, +runvdr-conf.d +-------------------------------------------------------------------------- + +The runvdr-conf.d is an (optional) tool to manage plugins. It works simillar +to the init.d concept, where a whole directory of symbolic links is loaded +in alphabetical order. + +In case of runvdr-conf.d, one file similar to the skeleton.example file +is placed in /etc/runvdr/ for each plugin that is available. Only plugins +that have a symbolic link in /etc/runvdr/conf.d/ to their config file will +be loaded. For this, the corresponding INCLUDE line must be enabled in +runvdr.conf. + +The following commands are available to manage the plugins: + +runvdr-conf.d show [name] + Shows all plugins (resp. only the 'name' plugin), including the full name + and the load priority. 'name' is the file name in the /etc/runvdr/ + directory. + +runvdr-conf.d enable name [--prio XX] + Activates a plugin for next restart. Uses default priority or the specified + priority. For that, a symbolic link to /etc/runvdr/name will be created + under /etc/runvdr/conf.d/XXname. + +runvdr-conf.d disable name + Deactivates a plugin from next restart on, by deleting the symbolic link + under /etc/runvdr/conf.d/XXname. + +runvdr-conf.d osdserver [--debug] + Connects to the osdserver plugin and allows interactive plugin configuration + using the VDR OSD. From there, plugins can be activated and deactivated, + and the load priority can be changed. + Without --debug, runvdr-conf.d returns immediately, disconnection standard + input/output, so it can be started from commands.conf. With --debug, the + osdserver communication will be shown. + + + Dependencies -------------------------------------------------------------------------- Unix commands, that runvdr uses: @@ -32,6 +32,14 @@ Einige der Features von runvdr extreme: - Kann Landessprache für VDR setzen - Unterstützt Pluginsetup-Plugin optional +Dazu kommt runvdr-conf.d: + +- Lädt Konfigurationsdateien alphabetisch aus einem Verzeichnis, + vergleichbar mit init.d-Verzeichnissen. +- Kommandozeilentool zum Aktivieren/Deaktivieren von Plugins +- Festlegen der Ladereihenfolge +- Optional: Menüsteuerung per osdserver-Plugin + Schnellstart @@ -45,6 +53,18 @@ Schnellstart Die runvdr.conf ist größtenteils selbsterklärend. Alle Optionen sind auch per Kommandozeile verfügbar, siehe runvdr --help. +Für das init-Skript (Debian): +- Kopiere init.d.runvdr.Debian nach /etc/init.d/runvdr +- Benutze update-rc.d um die Start-Runlevel zu konfigurieren. + +Für runvdr-conf.d: +- Kopiere runvdr-conf.d nach /usr/local/bin/ +- /etc/runvdr/ anlegen und mit Dateien nach Vorbild der skeleton.example + füllen +- INCLUDE /etc/runvdr/conf.d/* in runvdr.conf aufnehmen +- runvdr-conf.d show|enable|disable zum Konfigurieren der Plugins verwenden +- (Optional) "runvdr-conf.d osdserver" in commands.conf hinzufügen. + Details @@ -65,6 +85,12 @@ runvdr.conf laden, wenn man die INCLUDE-Direktive verwendet. Man kann zum Beispiel /etc/runvdr.conf aus der Datei ~/.runvdr.conf heraus laden, um für den aktuellen Benutzer einige Einstellungen zu überschreiben. +Die INCLUDE-Direktive kann auch mehrere Konfigurationsdateien laden. So kann +man z.B. mit INCLUDE /etc/runvdr/conf.d/* ein ganzes Verzeichnis von +Konfigurationsdateien laden. Beispielsweise könnten in so einem Verzeichnis +für jedes zu ladende Plugin eine Datei (oder Symlink) mit dem Einzeiler +"AddPlugin xxx" liegen. + Plugins, die durch die AddPlugin-Direktive in der conf-Datei oder die --plugin oder -P Option geladen werden, können von der Plugin-Liste wieder entfernt werden, wenn man "AddPlugin -name", --plugin="-name" oder -P-name @@ -80,6 +106,45 @@ die Hilfestellung von VDR aus, und nicht die Hilfestellung von runvdr. +runvdr-conf.d +-------------------------------------------------------------------------- + +Mit runvdr-conf.d steht ein (optionales) Tool zur Verfügung, das das +Verwalten der Plugins erleichtern soll. Es funktioniert nach dem init.d +Prinzip, bei dem in einem Verzeichnis mehrere symbolische Links auf Dateien +abgelegt werden, die in alphabetischer Reihenfolge abgearbeitet werden. + +Im Falle von runvdr-conf.d legt man pro zu ladendem Plugin eine eigene +Konfigurationsdatei nach Vorbild der skeleton.example in /etc/runvdr/ ab. +Geladen werden Plugins, deren symbolischer Link unter /etc/runvdr/conf.d +liegt. Dazu muss in der runvdr.conf die passende INCLUDE-Zeile aktiviert +werden. + +Folgende Befehle stehen zur Verfügung, um die aktiven Plugins zu verwalten: + +runvdr-conf.d show [name] + Zeigt alle Plugins bzw. ein Plugin an, inklusive Name und Ladepriorität. + 'name' ist der Dateiname im Verzeichnis /etc/runvdr/. + +runvdr-conf.d enable name [--prio XX] + Aktiviere Plugin für nächsten Neustart. Verwendet Default-Priorität oder + die angegebene Priorität. Dazu wird ein symbolischer Link auf die Datei + /etc/runvdr/name unter /etc/runvdr/conf.d/XXname abgelegt. + +runvdr-conf.d disable name + Deaktiviert ein Plugin ab dem nächsten Neustart, d.h. löscht den Link + unter /etc/runvdr/conf.d/XXname. + +runvdr-conf.d osdserver [--debug] + Verbindet mit OSD-Server Plugin und erlaubt das Konfigurieren der Plugins + per VDR OSD. Von dort können Plugins aktiviert und deaktivert werden, und + die Ladepriorität gesetzt werden. + Ohne --debug kehrt runvdr-conf.d sofort zurück und trennt sich von der + Standard-Ein/Ausgabe, kann also von der commands.conf direkt aufgerufen + werden. Mit --debug wird die OSD-Server Kommunikation ausgegeben. + + + Voraussetzungen -------------------------------------------------------------------------- Unix-Kommandos, die runvdr benutzt: diff --git a/init.d.runvdr.Debian b/init.d.runvdr.Debian new file mode 100755 index 0000000..6734249 --- /dev/null +++ b/init.d.runvdr.Debian @@ -0,0 +1,83 @@ +#! /bin/sh +# +# runvdr init.d script for Debain and compatible distributions +# +# by Udo Richter <udo_richter(a)gmx.de> +# http://www.richter-udo.de/vdr/scripts.html#runvdr +# + +set -e + +PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin +DESC="Runvdr Extreme" +NAME=runvdr +DAEMON=/usr/local/bin/runvdr +PIDFILE=/var/run/runvdr.pid +SCRIPTNAME=/etc/init.d/runvdr + +# Gracefully exit if the package has been removed. +test -x $DAEMON || exit 0 + +# +# Function that starts runvdr. +# +d_start() { + start-stop-daemon --start --background --quiet --pidfile $PIDFILE \ + --exec $DAEMON -- +} + +# +# Function that stops runvdr. +# +d_stop() { + $DAEMON --terminate --wait=30 +} + +# +# Function that sends a restart to runvdr. +# +d_reload() { + $DAEMON --restart +} + +# +# Function that sends a dvb-reload to runvdr. +# +d_dvb_reload() { + $DAEMON --dvb-restart +} + +case "$1" in + start) + echo -n "Starting $DESC: $NAME" + d_start + echo "." + ;; + stop) + echo "Stopping $DESC: $NAME". + d_stop + ;; + reload) + echo -n "Reloading $DESC configuration" + d_reload + echo "." + ;; + dvb-reload) + echo -n "Reloading $DESC configuration" + d_dvb_reload + echo "." + ;; + restart|force-reload) + echo -n "Restarting $DESC: $NAME" + d_stop + sleep 1 + d_start + echo "." + ;; + *) + echo "Usage: $SCRIPTNAME {start|stop|restart|dvb-restart|reload|force-reload}" >&2 + exit 1 + ;; +esac + +exit 0 @@ -45,37 +45,39 @@ SETTERM="setterm" # # Supported options of VDR # -# -a # --audio # AUDIO send Dolby Digital audio to stdin of command # -# -c # --config # CONFIGDIR read config files from DIR -# -d --daemon DAEMON run in daemon mode -# -D # --device # DVBDEVICE use only the given DVB device (NUM = 0, 1, 2...) -# -E # --epgfile # EPGFILE write the EPG data into the given FILE. - to disable. -# -g # --grab # GRAB write images from the SVDRP command GRAB into the given DIR; -# -L # --lib # LIBDIR search for plugins in DIR (default is %s) -# --lirc #? LIRC use a LIRC remote control device, attached to PATH -# -l # --log # LOGLEVEL set log level (default: 3) -# -m --mute MUTE mute audio of the primary DVB device at startup -# --no-kbd NOKBD don't use the keyboard as an input device -# -P # --plugin # PLUGINS load a plugin defined by the given options -# -p # --port # SVDRPPORT use PORT for SVDRP -# --rcu #? RCU use a remote control device, attached to PATH -# -r # --record # RECORDCMD call CMD before and after a recording -# -s # --shutdown # SHUTDOWN call CMD to shutdown the computer -# -t # --terminal # TERMINAL controlling tty -# -u # --user # USER run as user USER; only applicable if started as root -# --vfat VFAT encode special characters in recording names -# -v # --video # VIDEODIR use DIR as video directory -# -w # --watchdog # WATCHDOG activate the watchdog timer with a timeout of SEC - - -which $PGREP >/dev/null || { echo missing $PGREP... >2 ; exit 1 ; } -which $PS >/dev/null || { echo missing $PS... >2 ; exit 1 ; } -which $GETOPT >/dev/null || { echo missing $GETOPT... >2 ; exit 1 ; } -which $KILL >/dev/null || { echo missing $KILL... >2 ; exit 1 ; } -which $SLEEP >/dev/null || { echo missing $SLEEP... >2 ; exit 1 ; } -which $CHVT >/dev/null || { echo missing $CHVT... >2 ; exit 1 ; } -which $DATE >/dev/null || { echo missing $DATE... >2 ; exit 1 ; } -which $SETTERM >/dev/null || { echo missing $SETTERM... >2 ; exit 1 ; } +# -a # --audio # AUDIO send Dolby Digital audio to stdin of command # +# -c # --config # CONFIGDIR read config files from DIR +# -d --daemon DAEMON run in daemon mode +# -D # --device # DVBDEVICE use only the given DVB device (NUM = 0, 1, 2...) +# -E # --epgfile # EPGFILE write the EPG data into the given FILE. - to disable. +# -g # --grab # GRAB write images from the SVDRP command GRAB into the given DIR; +# -L # --lib # LIBDIR search for plugins in DIR (default is %s) +# --lirc #? LIRC use a LIRC remote control device, attached to PATH +# --localedir # LOCALEDIR search for locale files in DIR +# -l # --log # LOGLEVEL set log level (default: 3) +# -m --mute MUTE mute audio of the primary DVB device at startup +# --no-kbd NOKBD don't use the keyboard as an input device +# -P # --plugin # PLUGINS load a plugin defined by the given options +# -p # --port # SVDRPPORT use PORT for SVDRP +# --rcu #? RCU use a remote control device, attached to PATH +# -r # --record # RECORDCMD call CMD before and after a recording +# -s # --shutdown # SHUTDOWN call CMD to shutdown the computer +# -t # --terminal # TERMINAL controlling tty +# -u # --user # USER run as user USER; only applicable if started as root +# --userdump USERDUMP allow coredumps if -u is given (debugging) +# --vfat VFAT encode special characters in recording names +# -v # --video # VIDEODIR use DIR as video directory +# -w # --watchdog # WATCHDOG activate the watchdog timer with a timeout of SEC + + +which $PGREP >/dev/null || { echo missing $PGREP... >&2 ; exit 1 ; } +which $PS >/dev/null || { echo missing $PS... >&2 ; exit 1 ; } +which $GETOPT >/dev/null || { echo missing $GETOPT... >&2 ; exit 1 ; } +which $KILL >/dev/null || { echo missing $KILL... >&2 ; exit 1 ; } +which $SLEEP >/dev/null || { echo missing $SLEEP... >&2 ; exit 1 ; } +which $CHVT >/dev/null || { echo missing $CHVT... >&2 ; exit 1 ; } +which $DATE >/dev/null || { echo missing $DATE... >&2 ; exit 1 ; } +which $SETTERM >/dev/null || { echo missing $SETTERM... >&2 ; exit 1 ; } @@ -89,8 +91,8 @@ function ParseCommandLine_Step1() { runvdr-pid:,dvb-load:,dvb-unload:,language:,wrapper:,\ term-timeout:,kill-timeout:,terminate::,restart::,dvb-restart::,\ wait::,audio:,config:,daemon,device:,epgfile:,grab:,help,lib:,lirc::,\ - log:,mute,no-kbd,plugin:,port:,rcu::,record:,shutdown:,\ - terminal:,user:,version,vfat,video:,watchdog:" + log:,localedir:,mute,no-kbd,plugin:,port:,rcu::,record:,shutdown:,\ + terminal:,user:,userdump,version,vfat,video:,watchdog:" # prepare all optios for later processing @@ -111,7 +113,7 @@ function ParseCommandLine_Step1() { break ;; *) - echo "Internal error!" >2 + echo "Internal error!" >&2 exit 1 ;; esac ; done @@ -146,6 +148,7 @@ function Clean() { LIBDIR= LIRC= LOGLEVEL= + LOCALEDIR= MUTE= NOKBD= PLUGINS=() @@ -154,7 +157,8 @@ function Clean() { RCU= SHUTDOWN= TERMINAL= - VDRUSER= + USER= + USERDUMP= VFAT= VIDEODIR= WATCHDOG= @@ -221,20 +225,24 @@ function AddDevice() { function INCLUDE() { - # include different conf file - if [ -n "$1" ] ; then - if [ -r "$1" ] ; then - . "$1" || exit 1 + # include different conf file(s) + + for file ; do + if [ -r "$file" ] ; then + . "$file" || exit 1 else - echo "runvdr: $1 not found." >&2 + echo "runvdr: $file not found." >&2 fi - fi + done } function LoadConfFile() { # Load configuration file + VDRUSER="" + # Old option, supported for compatibility only + if [ -z "$RUNVDRCONF" -a -r ~/.runvdr.conf ] ; then RUNVDRCONF=~/.runvdr.conf fi @@ -248,6 +256,11 @@ function LoadConfFile() { echo "runvdr: $RUNVDRCONF not found." >&2 fi fi + + if [ -n "$VDRUSER" ] ; then + echo "runvdr: VDRUSER is deprecated. Use USER= instead." + [ -n "$USER" ] && USER="$VDRUSER" + fi # Transform some defaults, so empty parameters can have a # non-default meaning @@ -297,6 +310,7 @@ function ParseCommandLine_Step2() { -l|--log) LOGLEVEL="$2"; shift 2;; -L|--lib) LIBDIR="$2"; shift 2;; --lirc) LIRC="$2"; shift 2;; + --localedir) LOCALEDIR="$2"; shift 2;; -m|--mute) MUTE=1; shift ;; --no-kbd) NOKBD=1; shift ;; -p|--port) SVDRPPORT="$2"; shift 2;; @@ -306,6 +320,7 @@ function ParseCommandLine_Step2() { -s|--shutdown) SHUTDOWN="$2"; shift 2;; -t|--terminal) TERMINAL="$2"; shift 2;; -u|--user) USER="$2"; shift 2;; + --userdump) USERDUMP="$2"; shift ;; -v|--video) VIDEODIR="$2"; shift 2;; --vfat) VFAT=1; shift ;; -w|--watchdog) WATCHDOG="$2"; shift 2;; @@ -316,7 +331,7 @@ function ParseCommandLine_Step2() { break ;; *) - echo "Internal error!" >2 + echo "Internal error!" >&2 exit 1 ;; esac ; done @@ -358,31 +373,33 @@ runvdr Options: -h, --help print this help and exit Parsed VDR options: --a # --audio=# send Dolby Digital audio to stdin of command CMD --c # --config=# read config files from DIR --d --daemon run in daemon mode --D # --device=# use only the given DVB device (NUM = 0, 1, 2...) - Use '-' to override devices from config file - Use '-x' to ignore device x from config file --E # --epgfile=# write the EPG data into the given FILE. - to disable. --g # --grab=# write images from the SVDRP command GRAB into the given DIR --L # --lib=# search for plugins in DIR - --lirc[=#] use a LIRC remote control device, attached to PATH --l # --log=# set log level --m --mute mute audio of the primary DVB device at startup - --no-kbd don't use the keyboard as an input device --P # --plugin=# load a plugin defined by the given options - Use '-' to ignore all plugins from config file - Use '-xx' to ignore plugin xx from config file --p # --port=# use PORT for SVDRP - --rcu[=#] use a remote control device, attached to PATH --r # --record=# call CMD before and after a recording --s # --shutdown=# call CMD to shutdown the computer --t # --terminal=# controlling tty --u # --user=# run as user USER; only applicable if started as root - --vfat encode special characters in recording names --v # --video=# use DIR as video directory --w # --watchdog=# activate the watchdog timer with a timeout of SEC +-a # --audio=# send Dolby Digital audio to stdin of command CMD +-c # --config=# read config files from DIR +-d --daemon run in daemon mode +-D # --device=# use only the given DVB device (NUM = 0, 1, 2...) + Use '-' to override devices from config file + Use '-x' to ignore device x from config file +-E # --epgfile=# write the EPG data into the given FILE. - to disable. +-g # --grab=# write images from the SVDRP command GRAB into the given DIR +-L # --lib=# search for plugins in DIR + --lirc[=#] use a LIRC remote control device, attached to PATH + --localedir=# search for locale files in DIR +-l # --log=# set log level +-m --mute mute audio of the primary DVB device at startup + --no-kbd don't use the keyboard as an input device +-P # --plugin=# load a plugin defined by the given options + Use '-' to ignore all plugins from config file + Use '-xx' to ignore plugin xx from config file +-p # --port=# use PORT for SVDRP + --rcu[=#] use a remote control device, attached to PATH +-r # --record=# call CMD before and after a recording +-s # --shutdown=# call CMD to shutdown the computer +-t # --terminal=# controlling tty +-u # --user=# run as user USER; only applicable if started as root + --userdump allow coredumps if -u is given (debugging) + --vfat encode special characters in recording names +-v # --video=# use DIR as video directory +-w # --watchdog=# activate the watchdog timer with a timeout of SEC All runvdr parameters after '--' will be passed to VDR without modification END-OF-HELP @@ -420,6 +437,7 @@ function BuildCommand() { 0) ;; *) VDRCMD="$VDRCMD --lirc=\"$LIRC\"";; esac + [ -n "$LOCALEDIR" ] && VDRCMD="$VDRCMD --localedir \"$LOCALEDIR\"" [ -n "$MUTE" ] && VDRCMD="$VDRCMD -m" [ -n "$NOKBD" ] && VDRCMD="$VDRCMD --no-kbd" [ -n "$SVDRPPORT" ] && VDRCMD="$VDRCMD -p $SVDRPPORT" @@ -447,9 +465,11 @@ function BuildCommand() { 0) ;; *) VDRCMD="$VDRCMD --rcu=\"$RCU\"";; esac + [ -n "$SHUTDOWN" ] && VDRCMD="$VDRCMD -s \"$SHUTDOWN\"" [ -n "$TERMINAL" ] && VDRCMD="$VDRCMD -t \"$TERMINAL\"" - [ -n "$VDRUSER" ] && VDRCMD="$VDRCMD -u \"$VDRUSER\"" + [ -n "$USER" ] && VDRCMD="$VDRCMD -u \"$USER\"" + [ -n "$USERDUMP" ] && VDRCMD="$VDRCMD --userdump" [ -n "$VFAT" ] && VDRCMD="$VDRCMD --vfat" [ -n "$VIDEODIR" ] && VDRCMD="$VDRCMD -v \"$VIDEODIR\"" [ -n "$WATCHDOG" ] && VDRCMD="$VDRCMD -w $WATCHDOG" @@ -532,7 +552,7 @@ if [ -n "$HELP" ] ; then fi if [ -n "$VERSION" ] ; then - echo "runvdr version 0.2.0" + echo "runvdr extreme version 0.3.0" exit 0 fi diff --git a/runvdr-conf.d b/runvdr-conf.d new file mode 100755 index 0000000..e1a4103 --- /dev/null +++ b/runvdr-conf.d @@ -0,0 +1,425 @@ +#!/bin/bash + +ALLSCRIPTS="/etc/runvdr" +ACTIVESCRIPTS="/etc/runvdr/conf.d" +LINKREL="../" + +##################### +# OSDServer helpers # +##################### + +# convenient return values +true=0 +false=1 + +function error() { + # Fatal error. Send quit command, close FIFO and terminate netcat + [ "${reply2xx[0]}" != 202 ] && SendCmd Quit + + exec 3>&- + exec 4>&- + + kill $pid + + exit 1 +} + +function ConnectServer() { + # Connect to the OSDServer + + # Set up temporary fifo and open as file descriptor 3 and 4 + mkfifo --mode=700 /tmp/pipe-in$$ /tmp/pipe-out$$ + exec 3<> /tmp/pipe-in$$ + exec 4<> /tmp/pipe-out$$ + rm /tmp/pipe-in$$ /tmp/pipe-out$$ + + # Connect to server using the fifo + { + netcat $1 $2 + + # In case of connection loss: + echo 499 disconnected + echo 202 Good Bye. + } <&3 >&4 & + pid=$! + + # Sending to the server: use >&3 + # Receive from the server: use <&4 +} + + +function ReadReply() { + # Read a complete server reply until 2xx return code, + # and store replies in each category by number + reply2xx=() + reply3xx=() + reply4xx=() + reply5xx=() + reply6xx=() + + while read -r code line <&4 ; do + if [ "$OSDSERVER_DEBUG" ] ; then echo "< $code $line" ; fi + # screen echo + + case $code in + 2*) IFS=$' \t\n\r' reply2xx=($code "$line") + ;; + 3*) IFS=$' \t\n\r' reply3xx=($code $line) + ;; + 4*) IFS=$' \t\n\r' reply4xx=($code "$line") + ;; + 5*) IFS=$' \t\n\r' reply5xx=($code "$line") + ;; + 6*) IFS=$' \t\n\r' reply6xx=($code "$line") + ;; + esac + [ -n "${reply2xx[0]}" ] && break + done + + [ -n "${reply4xx[0]}" ] && return $false + return $true +} + +function SendCmd() { + # Send a command and read the reply + + if [ "$OSDSERVER_DEBUG" ] ; then echo "> $*" ; fi + # screen echo + + echo "$*" >&3 + # network send + + ReadReply +} + +function IsEvent() { + # Helper to check reply for a certain event + + [ "${reply3xx[0]}" != 300 ] && return $false + [ "${reply3xx[1]}" != "$1" ] && return $false + [ "${reply3xx[2]}" != "$2" ] && return $false + + return $true +} + + +function QuoteString() { + # Quote arbitrary string for use in '' and "" + local str="${!1}" + + str="${str//'\'/\\\\}" + str="${str//'\\'/\\\\}" + # work around bash bug: double quoted '\' + + str="${str//\'/$'\\\''}" + # This is bogus, anyone knows something better to replace ' by \' ? + + str="${str//\"/\\\"}" + str="${str//$'\r'/\\r}" + str="${str//$'\n'/\\n}" + str="${str//$'\t'/\\t}" + + eval "$1=\$str" +} + +function UnquoteString() { + # Unquote string + local str="${!1}" + + str="${str//\\r/$'\r'}" + str="${str//\\n/$'\n'}" + str="${str//\\t/$'\t'}" + str="${str//\\\"/\"}" + str="${str//\\\'/\'}" + str="${str//\\\\/\\}" + + eval "$1=\$str" +} + +######################### +# runvdr-conf.d helpers # +######################### + +function GetConfInfo() { + name="" + defaultprio=50 + loaded="" + local tmp + + if [ ! -f "$ALLSCRIPTS/$1" ] ; then + return 1 + fi + while read -r line ; do + tmp="${line#\# Plugin name:}" + if [ "$tmp" != "$line" ] ; then + name="${tmp# }" + fi + tmp="${line#\# Default priority:}" + if [ "$tmp" != "$line" ] ; then + tmp="${tmp#\# Default priority:}" + while [ "${tmp# }" != "$tmp" ] ; do tmp="${tmp# }" ; done + while [ "${tmp% }" != "$tmp" ] ; do tmp="${tmp% }" ; done + if [ -z "${tmp#[0-9]}" ] ; then tmp="0$tmp" ; fi + if [ -z "${tmp#[0-9][0-9]}" ] ; then + defaultprio="$tmp" + fi + fi + done < "$ALLSCRIPTS/$1" + if [ -z "$name" ] ; then + return 1 + fi + + tmp=("$ACTIVESCRIPTS"/[0-9][0-9]"$1") + tmp="${tmp[0]}" + if [ -f "$tmp" ] ; then + tmp="${tmp:${#ACTIVESCRIPTS}+1}" + loaded="${tmp:0:2}" + fi + + return 0 +} + +function GetAllConfInfo() { + local glob="*" + if [ "$1" ] ; then glob="$1" ; fi + confs=0 + confs_short=() + confs_name=() + confs_defaultprio=() + confs_loaded=() + local i + for i in "$ALLSCRIPTS"/$glob ; do + i="${i:${#ALLSCRIPTS}+1}" + if [ -f "$ALLSCRIPTS/$i" ] && GetConfInfo "$i" ; then + confs_short[$confs]="$i" + confs_name[$confs]="$name" + confs_defaultprio[$confs]="$defaultprio" + confs_loaded[$confs]="$loaded" + let confs++ + fi + done +} + + +function Command_Show() { + GetAllConfInfo "$1" + + local i; + for ((i=0;i<confs;i++)) ; do + if [ $i -ne 0 ] ; then + echo + fi + echo "Plugin short name: ${confs_short[i]}" + echo "Plugin long name : ${confs_name[i]}" + echo "Default priority : ${confs_defaultprio[i]}" + echo "Loaded priority : ${confs_loaded[i]:---}" + done +} + +function Command_Enable() { + short="$1" + if [ -z "$short" ] ; then + echo "Usage: $0 enable conf-name [--prio #]" + exit 1 + fi + GetConfInfo "$short" || { echo "Unknown Plugin $short" >&2 ; exit 1 ; } + newloaded="$loaded" + if [ -z "$newloaded" ] ; then + newloaded="$defaultprio" + fi + + if [ "$2" == "--prio" ] ; then + newloaded="$3" + while [ "${newloaded# }" != "$newloaded" ] ; do newloaded="${newloaded# }" ; done + while [ "${newloaded% }" != "$newloaded" ] ; do newloaded="${newloaded% }" ; done + if [ -z "${newloaded#[0-9]}" ] ; then newloaded="0$newloaded" ; fi + if [ "${newloaded#[0-9][0-9]}" ] ; then + echo "Not a valid priority: $3" >&2 + exit 1 + fi + fi + echo -n "Enabling $name" + mkdir -p "$ACTIVESCRIPTS" + if [ "$loaded" ] ; then + rm -f "$ACTIVESCRIPTS"/[0-9][0-9]"$short" + fi + ln -s "$LINKREL$short" "$ACTIVESCRIPTS/$newloaded$short" + echo "." +} + +function Command_Disable() { + short="$1" + if [ -z "$short" ] ; then + echo "Usage: $0 disable conf-name" + exit 1 + fi + GetConfInfo "$short" || { echo "Unknown Plugin $short" >&2 ; exit 1 ; } + if [ -z "$loaded" ] ; then + echo "$short is not loaded." >&2 + exit 1 + fi + echo -n "Disabling $name" + rm -f "$ACTIVESCRIPTS"/[0-9][0-9]"$short" + echo "." +} + +function Osdserver_edit() { + local short="${confs_short[$1]}" + QuoteString short + local name="${confs_name[$1]}" + QuoteString name + local defaultprio="${confs_defaultprio[$1]}" + local loaded="${confs_loaded[$1]}" + local enable="Yes" + if [ -z "$loaded" ] ; then + enable="No" + loaded="$defaultprio" + fi + + SendCmd "enterlocal" || return $false + # Preserve global variable space, so we can re-use 'menu' + + SendCmd "menu=New Menu 'Edit $name'" || return $false + SendCmd "menu.SetColumns 15" || return $false + SendCmd "menu.EnableEvent keyOk close" || return $false + + SendCmd "menu.AddNew OsdItem -unselectable 'Short name:\\t$short'" || return $false + + SendCmd "menu.AddNew OsdItem -unselectable 'Long name:\\t$name'" || return $false + + SendCmd "menu.AddNew OsdItem -unselectable 'Default priority:\\t$defaultprio'" || return $false + + SendCmd "enable=menu.AddNew EditListItem Enabled No Yes -SelectName '$enable'" || return $false + SendCmd "enable.SetCurrent" || return $false + + SendCmd "prio=menu.AddNew EditIntItem -min 0 -max 99 'Current priority:' '$loaded'" || return $false + + SendCmd "_focus.addsubmenu menu" || return $false + SendCmd "menu.show" || return $false + + while true; do + SendCmd "menu.SleepEvent" || return $false + + if IsEvent menu keyOk ; then + SendCmd "enable.GetValue -name" || return $false + [ "${reply6xx[0]}" != 600 ] && return $false + enable="${reply6xx[1]}" + + SendCmd "prio.GetValue" || return $false + [ "${reply6xx[0]}" != 600 ] && return $false + prio="${reply6xx[1]}" + + if [ "$enable" == "Yes" ] ; then + Command_Enable "$short" --prio "$prio" + confs_loaded[$1]="$prio" + elif [ -n "${confs_loaded[$1]}" ] ; then + Command_Disable "$short" + confs_loaded[$1]="" + fi + + SendCmd "menu.SendState osBack" || return $false + SendCmd "delete menu" || return $false + SendCmd "leavelocal" || return $false + + return $true + fi + if IsEvent menu close ; then + SendCmd "delete menu" || return $false + SendCmd "leavelocal" || return $false + return $true + fi + done +} + +function Osdserver_main() { + SendCmd "menu=New Menu 'Runvdr config'" || return $false + SendCmd "menu.SetColumns 5" || return $false + SendCmd "menu.EnableEvent close" || return $false + + local i; + local min=0 + local prio + until [ "$min" -ge 100 ] ; do + local nextmin=100 + for ((i=0;i<confs;i++)) ; do + prio="${confs_defaultprio[i]}" + if [ -n "${confs_loaded[i]}" ] ; then prio=${confs_loaded[i]} ; fi + + if [ "$prio" -eq "$min" ] ; then + SendCmd "conf$i=menu.AddNew OsdItem '${confs_loaded[i]:---}\t${confs_name[i]}'" || return $false + SendCmd "conf$i.EnableEvent keyOk" || return $false + fi + if [ "$prio" -gt "$min" -a "$prio" -lt "$nextmin" ] ; then + nextmin="$prio" + fi + done + min="$nextmin" + done + + SendCmd "menu.Show" || return $false + + while true ; do + SendCmd "menu.SleepEvent" || return $false + + if IsEvent menu close ; then + return $true + fi + + if [ "${reply3xx[1]:0:4}" == "conf" -a "${reply3xx[2]}" == "keyOk" ] ; then + i="${reply3xx[1]:4}" + Osdserver_edit "$i" || return $false + SendCmd "conf$i.SetText '${confs_loaded[i]:---}\t${confs_name[i]}'" || return $false + SendCmd "menu.Show" || return $false + fi + done +} + +function Osdserver_connect() { + GetAllConfInfo + + ConnectServer localhost 2010 + # Connect to the server process + + ReadReply || error + # Read server welcome + + SendCmd "Version 0.1" || error + # Identify to server with protocol version + + Osdserver_main || error + # Main menu + + SendCmd Quit + # ... and good bye + + exec 3>&- + exec 4>&- + # close FIFOs +} + +function Command_Osdserver() { + if [ "$1" == "--debug" ] ; then + OSDSERVER_DEBUG=1 + Osdserver_connect + else + Osdserver_connect </dev/null >/dev/null & + fi +} + +if [ "$1" == "show" ] ; then + shift + Command_Show "$@" +elif [ "$1" == "enable" ] ; then + shift + Command_Enable "$@" +elif [ "$1" == "disable" ] ; then + shift + Command_Disable "$@" +elif [ "$1" == "osdserver" ] ; then + shift + Command_Osdserver "$@" +else + test + echo "Unknown command: $1" >&2 +fi + diff --git a/runvdr.conf.example b/runvdr.conf.example index 85dc41b..8e31eaf 100644 --- a/runvdr.conf.example +++ b/runvdr.conf.example @@ -9,11 +9,17 @@ # Include other configuration file for defaults -# Must be first, or will override all previous settings +# Must be first, or will override all previous settings. +# You can also use wildcards to load several files in lexicographic order: +# INCLUDE /etc/runvdr/plugins.d/* # You may want to use this in ~/.runvdr.conf if you also want to load # /etc/runvdr.conf. DO NOT create infinite loops with this! # # INCLUDE /etc/runvdr.conf +# +# For use with runvdr-conf.d, un-comment this line: +# INCLUDE /etc/runvdr/conf.d/* + ##### ------------------------- @@ -39,6 +45,10 @@ VIDEODIR="/video" # from the video directory). CONFIGDIR="/video" +# Location of locale files for VDR 1.5.14 and newer. Default is to use +# the builtin "./locale" or whatever was compiled as LOCDIR into VDR. +# +# LOCALEDIR="/usr/src/vdr/locale" ##### ----------- ##### Plugins @@ -81,7 +91,7 @@ LIBDIR= # 'root' is necessary if the system time shall be set from the transponder # data, but for security reasons vdr can switch to a lesser privileged user # id during normal operation. -VDRUSER="" +USER="" # Write the EPG data into EPGFILE. Default is /video/epg.data. # Use EPGFILE=- to disable this. If EPGFILE is a directory, the file @@ -145,6 +155,9 @@ RCU= # with VFAT file systems VFAT= +# Allow coredumps if USER= is given (debugging) +# USERDUMP="1" + # Store PID of runvdr into a file? # RUNVDRPID=~/.runvdr.pid RUNVDRPID=/var/run/runvdr.pid diff --git a/skeleton.example b/skeleton.example new file mode 100644 index 0000000..e663850 --- /dev/null +++ b/skeleton.example @@ -0,0 +1,7 @@ +# Skeleton config file for placing in /etc/runvdr/ + +# The next two lines must be present: +# Plugin name: Skeleton plugin +# Default priority: 50 + +AddPlugin skeleton |