diff --git a/Manual.html b/Manual.html index 4c5d7bf..e971c28 100644 --- a/Manual.html +++ b/Manual.html @@ -3,7 +3,7 @@ "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> - + Ansible Playbooks for yaVDR 0.7 @@ -253,283 +253,279 @@ for the JavaScript code in this tag.

Inhaltsverzeichnis

-
-

1 User Stories

+
+

1 User Stories

-
-

1.1 yavdr-full

+
+

1.1 yavdr-full

A User wants to install yaVDR without customization and relies on full automation. @@ -561,25 +557,20 @@ Several roles are used to tie everything together:

grub-config
update grub configuration based on executed roles
- -
-

1.1.1 Using vdr, pulseaudio and xorg together

-
-
-
-
-

2 Introduction

+ +
+

2 Introduction

One of the major problems we faced with customized Ubuntu ISO files as installation media for prior yaVDR versions has been the limited hardware support and the time consuming process to create and update them. An interesting alternative to this approach is to enable the user to choose the installation medium by himself, so point releases, kernel versions and additional drivers can be chosen deliberately. After the basic setup is complete (and a working internet connection is available), a fully customizable install script completes the yaVDR installation.

-
-

3 Installing and configuring yaVDR with Ansible

+
+

3 Installing and configuring yaVDR with Ansible

This is an experimental feature which allows to set up a yaVDR installation based on a normal Ubuntu Server 16.04.x installation using Ansible. @@ -614,8 +605,8 @@ We use a callback to generate tags for all roles autmatically:

-
-

3.1 Install scripts for local usage

+
+

3.1 Install scripts for local usage

set -e
@@ -659,12 +650,12 @@ ansible-playbook yavdr07-headless.yml -b -i 'localhost_
 
-
-

4 Playbooks

+
+

4 Playbooks

-
-

4.1 yavdr07.yml

+
+

4.1 yavdr07.yml

The yavdr07.yml playbook sets up a fully-featured yaVDR installation: @@ -718,8 +709,8 @@ The yavdr07.yml playbook sets up a fully-featured yaVDR installatio

-
-

4.2 yavdr07-headless.yml

+
+

4.2 yavdr07-headless.yml

For a headless server installation yavdr07-headless.yml is a good choice @@ -758,8 +749,8 @@ For a headless server installation yavdr07-headless.yml is a good c

-
-

5 Hosts

+
+

5 Hosts

This playbook can either be used to run the installation on the localhost or any other PC in the network that can be accessed via ssh. Simply add the host names or IP addresses to the hosts file in the respective section: @@ -773,12 +764,12 @@ This playbook can either be used to run the installation on the localhost or any

-
-

6 Group Variables

+
+

6 Group Variables

-
-

6.1 PPAs

+
+

6.1 PPAs

---
@@ -796,8 +787,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.2 VDR user, directories, special configuration and plugins

+
+

6.2 VDR user, directories, special configuration and plugins

# properties of the user vdr and vdr-related options
@@ -823,8 +814,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.3 Media directories

+
+

6.3 Media directories

# dictionary of directories for (shared) files. Automatically exported via NFS and Samba if those roles are enabled
@@ -839,8 +830,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.4 NFS

+
+

6.4 NFS

nfs:
@@ -849,8 +840,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.5 Samba

+
+

6.5 Samba

samba:
@@ -860,8 +851,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.6 Additional packages

+
+

6.6 Additional packages

# additional packages you want to install
@@ -880,8 +871,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.7 System pre-configuration

+
+

6.7 System pre-configuration

frontend: vdr
@@ -895,8 +886,8 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

6.8 Serial IR

+
+

6.8 Serial IR

# Serial device to configure for a homebrew receiver.
@@ -908,20 +899,20 @@ This playbook can either be used to run the installation on the localhost or any
 
-
-

7 Roles

+
+

7 Roles

-
-

7.1 install-dependencies

+
+

7.1 install-dependencies

-
-

7.1.1 tasks

+
+

7.1.1 tasks

    -
  1. main.yml
    +
  2. main.yml
    ---
    @@ -939,19 +930,19 @@ This playbook can either be used to run the installation on the localhost or any
     
-
-

7.2 nvidia experimental drivers

+
+

7.2 nvidia experimental drivers

install nvidia-396 from ppa:graphics-drivers/ppa

-
-

7.2.1 tasks

+
+

7.2.1 tasks

    -
  1. main.yml
    +
  2. main.yml
    ---
    @@ -980,15 +971,15 @@ install nvidia-396 from ppa:graphics-drivers/ppa
     
-
-

7.3 yavdr-common

+
+

7.3 yavdr-common

This role is used to set up a basic yaVDR installation. It creates the directories, installs the vdr and other useful packages.

-
-

7.3.1 default variables

+
+

7.3.1 default variables

This section is for reference only, please use the files in global_vars for customizations. @@ -1001,7 +992,7 @@ This section is for reference only, please use the files in global_vars

    -
  1. Repositories
    +
  2. Repositories

    You can set a list of package repositories which provide the necessary packages. Feel free to use own PPAs if you need special customization to the VDR and it’s plugins. @@ -1018,7 +1009,7 @@ You can set a list of package repositories which provide the necessary packages.

-
  • Drivers
    +
  • Drivers

    Automatically installed drivers can be very useful, but if you know you need a certain driver, you can simply set it’s value to true. If you don’t want a driver to be installed, set it’s value to false. @@ -1031,7 +1022,7 @@ Automatically installed drivers can be very useful, but if you know you need a c

  • -
  • Additional Packages
    +
  • Additional Packages

    Add additional packages you would like to have on your installation to this list @@ -1045,7 +1036,7 @@ Add additional packages you would like to have on your installation to this list

  • -
  • VDR
    +
  • VDR

    This section allows you to set the recording directory, the user and group that runs the vdr and it’s home directory. @@ -1078,15 +1069,15 @@ This section allows you to set the recording directory, the user and group that

  • -
    -

    7.3.2 tasks

    +
    +

    7.3.2 tasks

    yavdr-common executes the following tasks:

      -
    1. main.yml
      +
    2. main.yml
      ---
      @@ -1104,7 +1095,7 @@ yavdr-common executes the following tasks:
       
        -
      1. Disable default installation of recommended packages
        +
      2. Disable default installation of recommended packages

        This task prevents apt to automatically install all recommended dependencies for packages: @@ -1121,7 +1112,7 @@ This task prevents apt to automatically install all recommended dependencies for

    -
  • Set up package repositories
    +
  • Set up package repositories
    - name: add PPAs
    @@ -1141,7 +1132,7 @@ This task prevents apt to automatically install all recommended dependencies for
     
  • -
  • Use bash instead of dash
    +
  • Use bash instead of dash
    - name: use bash instead of dash
    @@ -1153,15 +1144,15 @@ This task prevents apt to automatically install all recommended dependencies for
     
  • -
  • create user vdr
    +
  • create user vdr
  • -
  • Disable release-upgrade notifications
    +
  • Disable release-upgrade notifications
      -
    1. SOMEDAY move from lineinfile to template
      +
    2. SOMEDAY move from lineinfile to template
      - name: disable release-upgrade notifications
      @@ -1183,7 +1174,7 @@ This task prevents apt to automatically install all recommended dependencies for
       
  • -
  • Install essential packages
    +
  • Install essential packages
    - name: apt | install basic packages
    @@ -1215,7 +1206,7 @@ This task prevents apt to automatically install all recommended dependencies for
     
  • -
  • Install additional packages (user defined)
    +
  • Install additional packages (user defined)
    - name: apt | install extra packages
    @@ -1228,15 +1219,15 @@ This task prevents apt to automatically install all recommended dependencies for
     
  • -
  • create directories
    +
  • create directories
  • -
  • create sudoers drop-in for vdr
    +
  • create sudoers drop-in for vdr
  • -
  • basic scripts for standby support
    +
  • basic scripts for standby support

    Stop vdr before entering suspend and unload dvb modules, reverse this operation on resume @@ -1247,8 +1238,8 @@ Stop vdr before entering suspend and unload dvb modules, reverse this operation

  • -
    -

    7.3.3 templates

    +
    +

    7.3.3 templates

    {{ ansible_managed | comment('c') }}
    @@ -1259,7 +1250,7 @@ APT::Install-Suggests "0";
     
      -
    1. yavdr sudoers drop-in
      +
    2. yavdr sudoers drop-in

      Allow the vdr user to restart vdr.service and reboot the system @@ -1271,7 +1262,7 @@ Allow the vdr user to restart vdr.service and reboot the system

    -
  • suspend hooks
    +
  • suspend hooks
    #!/bin/bash
    @@ -1300,7 +1291,7 @@ Allow the vdr user to restart vdr.service and reboot the system
     
  • -
  • module-helper
    +
  • module-helper
    #!/usr/bin/env python3
    @@ -1387,12 +1378,12 @@ Allow the vdr user to restart vdr.service and reboot the system
     
     
    -
    -

    7.4 collect facts about the system with custom modules

    +
    +

    7.4 collect facts about the system with custom modules

    -
    -

    7.4.1 variables

    +
    +

    7.4.1 variables

    first_run: False
    @@ -1400,12 +1391,12 @@ Allow the vdr user to restart vdr.service and reboot the system
     
    -
    -

    7.4.2 tasks

    +
    +

    7.4.2 tasks

      -
    1. main.yml
      +
    2. main.yml
      - name: get information about usb and pci hardware and loaded kernel modules
      @@ -1454,16 +1445,16 @@ Allow the vdr user to restart vdr.service and reboot the system
       
    -
    -

    7.5 vdr

    +
    +

    7.5 vdr

    -
    -

    7.5.1 tasks

    +
    +

    7.5.1 tasks

      -
    1. install the basic vdr packages
      +
    2. install the basic vdr packages
      ---
      @@ -1481,7 +1472,7 @@ Allow the vdr user to restart vdr.service and reboot the system
       
    3. -
    4. Add svdrp/svdrp-disc to /etc/services
      +
    5. Add svdrp/svdrp-disc to /etc/services
      - name: add svdrp and svdrp-disc to /etc/services
      @@ -1496,7 +1487,7 @@ Allow the vdr user to restart vdr.service and reboot the system
       
    6. -
    7. Set up the recording directory for the vdr user
      +
    8. Set up the recording directory for the vdr user
      - name: create vdr recdir
      @@ -1531,7 +1522,7 @@ Allow the vdr user to restart vdr.service and reboot the system
       
    9. -
    10. Install additional vdr plugins
      +
    11. Install additional vdr plugins

      The additional plugins to install can be set in the variable {{vdr_plugins}} in the group variables @@ -1547,7 +1538,7 @@ The additional plugins to install can be set in the variable {{vdr_plugins

  • -
  • copy vdr configuration files (if they don’t exist yet)
    +
  • copy vdr configuration files (if they don’t exist yet)
    - name: ensure vdr is stopped
    @@ -1573,12 +1564,40 @@ The additional plugins to install can be set in the variable {{vdr_plugins
         group: '{{ vdr.group }}'
         mode: 0644
         force: no
    +
    +- name: "vdr configuration | copy channels.conf if it doesn't exist yet"
    +  copy:
    +    src: '{{ vdr_channels_conf }}'
    +    dest: '{{ vdr.confdir }}/channels.conf'
    +    owner: '{{ vdr.user }}'
    +    group: '{{ vdr.group }}'
    +    mode: 0644
    +    force: no
    +  when: vdr_channels_conf is defined
    +
    +- name: "vdr configuration | download channels.conf if it doesn't exist yet"
    +  get_url:
    +    url: '{{ vdr_channels_conf_url }}'
    +    dest: '{{ vdr.confdir }}/channels.conf'
    +    owner: '{{ vdr.user }}'
    +    group: '{{ vdr.group }}'
    +    mode: 0644
    +    force: no
    +  when: vdr_channels_conf is not defined and vdr_channels_conf_url is defined
    +
    +- name: "vdr configuration | svdrphosts.conf"
    +  template:
    +    src: templates/svdrphosts.conf.j2
    +    dest: '{{ vdr.confdir }}/svdrphosts.conf'
    +    owner: '{{ vdr.user }}'
    +    group: '{{ vdr.group }}'
    +    mode: 0644
     
  • -
  • start vdr after network-online.target
    +
  • start vdr after network-online.target
    - name: create directory for vdr.service systemd drop-in files
    @@ -1599,25 +1618,58 @@ The additional plugins to install can be set in the variable {{vdr_plugins
     
     
    -
    -

    7.5.2 templates

    +
    +

    7.5.2 templates

    -

    -Start after network-online.target -

    +
    +
      +
    1. Start vdr.service after network-online.target
      +
      -
      [Unit]
      +
      {{ansible_managed | comment }}
      +[Unit]
       After=network-online.target
       
      +
    2. + +
    3. svdrphosts.conf
      +
      +
      +
      {{ ansible_managed | comment }}
      +#
      +# svdrphosts    This file describes a number of host addresses that
      +#               are allowed to connect to the SVDRP port of the Video
      +#               Disk Recorder (VDR) running on this system.
      +# Syntax:
      +#
      +# IP-Address[/Netmask]
      +#
      +
      +127.0.0.1             # always accept localhost
      +#192.168.100.0/24     # any host on the local net
      +#204.152.189.113      # a specific host
      +#0.0.0.0/0            # any host on any net (USE THIS WITH CARE!)
      +
      +{% if vdr_svdrphosts is defined %}
      +{% for host_or_subnet in vdr_svdrphosts %}
      +{{ host_or_subnet }}
      +{% endfor %}
      +{% endif %}
      +
      +
      -
      -

      7.5.3 files

      +
      +
    4. +
    +
    +
    +

    7.5.3 files

      -
    1. remote.conf
      +
    2. remote.conf
      LIRC.Up KEY_UP
      @@ -1752,7 +1804,7 @@ XKeySym.Next       XF86AudioNext
       
    3. -
    4. keymacros.conf
      +
    5. keymacros.conf
      # Remote control key macros for VDR
      @@ -1778,12 +1830,12 @@ User0     @osdteletext
       
    -
    -

    7.6 STARTED yavdr-network

    +
    +

    7.6 STARTED yavdr-network

    -
    -

    7.6.1 default variables

    +
    +

    7.6.1 default variables

    install_avahi: true
    @@ -1791,8 +1843,8 @@ User0     @osdteletext
     
    -
    -

    7.6.2 tasks

    +
    +

    7.6.2 tasks

    ---
    @@ -1860,12 +1912,12 @@ User0     @osdteletext
     
    -
    -

    7.7 vdr-plugin-menuorg

    +
    +

    7.7 vdr-plugin-menuorg

    -
    -

    7.7.1 tasks

    +
    +

    7.7.1 tasks

    ---
    @@ -1887,8 +1939,8 @@ User0     @osdteletext
     
    -
    -

    7.7.2 templates

    +
    +

    7.7.2 templates

    <?xml version="1.0" encoding="UTF-8"?>                                                                                                                      
    @@ -1947,17 +1999,17 @@ User0     @osdteletext
     
    -
    -

    7.8 nfs-server

    +
    +

    7.8 nfs-server

    -
    -

    7.8.1 TODO avahi-services für NFS beim Stoppen des nfs-kernel-servers depublizieren, beim Start wieder announcen

    +
    +

    7.8.1 TODO avahi-services für NFS beim Stoppen des nfs-kernel-servers depublizieren, beim Start wieder announcen

    -
    -

    7.8.2 tasks

    +
    +

    7.8.2 tasks

    ---
    @@ -1985,12 +2037,12 @@ User0     @osdteletext
     
    -
    -

    7.8.3 templates

    +
    +

    7.8.3 templates

      -
    1. /etc/exports
      +
    2. /etc/exports
      /srv *(rw,fsid=0,sync,no_subtree_check,all_squash,anongid={{ vdr.gid }},anonuid={{ vdr.uid }})
      @@ -2001,7 +2053,7 @@ User0     @osdteletext
       
    3. -
    4. avahi services
      +
    5. avahi services
      <?xml version="1.0" standalone='no'?>
      @@ -2022,15 +2074,15 @@ User0     @osdteletext
       
    -
    -

    7.9 yavdr-remote

    +
    +

    7.9 yavdr-remote

    The role yavdr-remote sets up the foundation for using eventlircd, lircd2uinput and the pre-configuration for remote receivers which can be detected by udev.

    -
    -

    7.9.1 default variables

    +
    +

    7.9.1 default variables

    lircd0_socket: /var/run/lirc/lircd0
    @@ -2038,8 +2090,8 @@ The role yavdr-remote sets up the foundation for using eventlircd,
     
    -
    -

    7.9.2 tasks

    +
    +

    7.9.2 tasks

    ---
    @@ -2110,12 +2162,12 @@ The role yavdr-remote sets up the foundation for using eventlircd,
     
    -
    -

    7.9.3 templates

    +
    +

    7.9.3 templates

      -
    1. Systemd Drop-in to start vdr with lirc support
      +
    2. Systemd Drop-in to start vdr with lirc support
      {% if frontend != 'kodi' %}
      @@ -2126,7 +2178,7 @@ The role yavdr-remote sets up the foundation for using eventlircd,
       
    3. -
    4. Systemd Drop-in to start lircd2uinput with lircd
      +
    5. Systemd Drop-in to start lircd2uinput with lircd
      [Service]
      @@ -2136,7 +2188,7 @@ The role yavdr-remote sets up the foundation for using eventlircd,
       
    6. -
    7. create /etc/rc_maps.cfg
      +
    8. create /etc/rc_maps.cfg
      {{ ansible_managed | comment }}
      @@ -2328,12 +2380,12 @@ ati_remote    rc-medion-x10-digitainer   /lib/udev/rc_keymaps/rc-medion-x10-digi
       
    -
    -

    7.10 pulseaudio

    +
    +

    7.10 pulseaudio

    -
    -

    7.10.1 tasks

    +
    +

    7.10.1 tasks

    ---
    @@ -2355,8 +2407,8 @@ ati_remote    rc-medion-x10-digitainer   /lib/udev/rc_keymaps/rc-medion-x10-digi
     
    -
    -

    7.10.2 templates

    +
    +

    7.10.2 templates

    # Use PulseAudio by default
    @@ -2378,12 +2430,12 @@ ati_remote    rc-medion-x10-digitainer   /lib/udev/rc_keymaps/rc-medion-x10-digi
     
    -
    -

    7.11 yavdr-xorg

    +
    +

    7.11 yavdr-xorg

    -
    -

    7.11.1 About the GUI session

    +
    +

    7.11.1 About the GUI session

    The X-Server is started by using the two systemd units xlogin@.service and x@.service provided by the package xlogin. The former is enabled (and started) for the vdr user - which results (using the default settings for the user vdr with the uid 666) in the activation of xlogin@vdr.service when reaching the graphical.target. To simplify starting and stopping the X-server and the desktop session a yavdr-xorg.service is provided by the package yavdr-xorg, which depends on the two units mentioned before. @@ -2412,8 +2464,8 @@ In order to achive a clean shutdown of the session, x@t7.service is

    -
    -

    7.11.2 default variables

    +
    +

    7.11.2 default variables

    first_run: False
    @@ -2436,12 +2488,12 @@ In order to achive a clean shutdown of the session, x@t7.service is
     
    -
    -

    7.11.3 tasks

    +
    +

    7.11.3 tasks

      -
    1. main.yml
      +
    2. main.yml
      ---
      @@ -2454,7 +2506,7 @@ In order to achive a clean shutdown of the session, x@t7.service is
       
    3. -
    4. setup-xorg.yml
      +
    5. setup-xorg.yml
      ---
      @@ -2572,7 +2624,7 @@ In order to achive a clean shutdown of the session, x@t7.service is
       
    6. -
    7. detect-xorg.yml
      +
    8. detect-xorg.yml
      ---
      @@ -2760,7 +2812,7 @@ In order to achive a clean shutdown of the session, x@t7.service is
       
    9. -
    10. intel.yml
      +
    11. intel.yml

      KMS drivers (like for intel (i915) and amd (radeon)) require additional configuration besides a customized xorg.conf - for a „static“ output configuration (which works if the TV or AV receiver is not turned on) we need to force loading the display(s) EDID early during the boot process. @@ -2808,12 +2860,12 @@ Please note that rescanning the connected displays works only after removing the

    -
    -

    7.11.4 templates

    +
    +

    7.11.4 templates

      -
    1. grub
      +
    2. grub
      {{ ansible_managed | comment }}
      @@ -2823,11 +2875,11 @@ Please note that rescanning the connected displays works only after removing the
       
    3. -
    4. xorg
      +
    5. xorg
        -
      1. x-verbose@.service
        +
      2. x-verbose@.service
        # file: roles/yavdr-xorg/templates/systemd/system/x-verbose@.service.j2
        @@ -2843,7 +2895,7 @@ Please note that rescanning the connected displays works only after removing the
         
      3. -
      4. Drop-in snippet for x@.service
        +
      5. Drop-in snippet for x@.service
        [Unit]
        @@ -2869,7 +2921,7 @@ Please note that rescanning the connected displays works only after removing the
         
      6. -
      7. Drop-in snippet for vdr.service
        +
      8. Drop-in snippet for vdr.service
        {{ ansible_managed | comment }}
        @@ -2881,7 +2933,7 @@ Please note that rescanning the connected displays works only after removing the
         
      9. -
      10. xorg.conf snippets
        +
      11. xorg.conf snippets
        {{ ansible_managed | comment }}
        @@ -2896,7 +2948,7 @@ EndSection
         
      12. -
      13. intel graphics xorg.conf snippet
        +
      14. intel graphics xorg.conf snippet
        {{ ansible_managed | comment }}
        @@ -3004,7 +3056,7 @@ EndSection
         
      15. -
      16. xorg.conf
        +
      17. xorg.conf
        {{ ansible_managed | comment }}
        @@ -3330,7 +3382,7 @@ EndSection
         
      18. -
      19. snippet to disable screen blanking
        +
      20. snippet to disable screen blanking
        {{ ansible_managed | comment }}
        @@ -3347,7 +3399,7 @@ EndSection
         
    6. -
    7. vdr
      +
    8. vdr

      Set environment variables for system locale and user session on startup @@ -3363,12 +3415,12 @@ Set environment variables for system locale and user session on startup

    -
    -

    7.11.5 files

    +
    +

    7.11.5 files

      -
    1. initramfs EDID hook
      +
    2. initramfs EDID hook
      #!/bin/bash
      @@ -3393,16 +3445,16 @@ exit 0
       
    -
    -

    7.12 yavdr-desktop

    +
    +

    7.12 yavdr-desktop

    -
    -

    7.12.1 Tasks

    +
    +

    7.12.1 Tasks

      -
    1. main.yml
      +
    2. main.yml
      ---
      @@ -3569,16 +3621,16 @@ exit 0
       
    -
    -

    7.12.2 Templates

    +
    +

    7.12.2 Templates

      -
    1. xorg configuration
      +
    2. xorg configuration
        -
      1. .Xresources
        +
      2. .Xresources
        xterm*background: Black
        @@ -3601,7 +3653,7 @@ XTerm.vt100.font: 7x13
         
      3. -
      4. .xinitrc
        +
      5. .xinitrc
        #!/bin/bash
        @@ -3613,11 +3665,11 @@ XTerm.vt100.font: 7x13
         
    3. -
    4. openbox
      +
    5. openbox
        -
      1. autostart
        +
      2. autostart
        # forward environment variables to an environment file and the systemd user session
        @@ -3653,7 +3705,7 @@ systemctl --user isolate yavdr-desktop.target
         
      3. -
      4. rc.xml
        +
      5. rc.xml
        <?xml version="1.0" encoding="UTF-8"?>
        @@ -4500,7 +4552,7 @@ systemctl --user isolate yavdr-desktop.target
         
      6. -
      7. rc2.xml
        +
      8. rc2.xml
        <?xml version="1.0" encoding="UTF-8"?>
        @@ -5329,11 +5381,11 @@ systemctl --user isolate yavdr-desktop.target
         
    6. -
    7. Systemd User Session
      +
    8. Systemd User Session
        -
      1. yavdr-desktop.target
        +
      2. yavdr-desktop.target
        [Unit]
        @@ -5346,7 +5398,7 @@ systemctl --user isolate yavdr-desktop.target
         
      3. -
      4. detect-second-display
        +
      5. detect-second-display
        #!/bin/bash
        @@ -5375,7 +5427,7 @@ systemctl --user isolate yavdr-desktop.target
         
      6. -
      7. switch-displays
        +
      8. switch-displays

        This script exchanges the primary and secondary screen. It needs access to the systemd user session. @@ -5394,7 +5446,7 @@ frontend-dbus-send start

  • -
  • openbox-second.service
    +
  • openbox-second.service
    [Unit]
    @@ -5416,7 +5468,7 @@ frontend-dbus-send start
     
  • -
  • osd2web.service
    +
  • osd2web.service
    [Unit]
    @@ -5439,7 +5491,7 @@ frontend-dbus-send start
     
  • -
  • tmux.service
    +
  • tmux.service
    [Unit]
    @@ -5458,7 +5510,7 @@ frontend-dbus-send start
     
  • -
  • wm-exit.service
    +
  • wm-exit.service
    [Unit]
    @@ -5477,7 +5529,7 @@ frontend-dbus-send start
     
  • -
  • irexec
    +
  • irexec

    irexec.service starts irexec for the user session @@ -5510,12 +5562,12 @@ end

  • -
    -

    7.13 samba-install

    +
    +

    7.13 samba-install

    -
    -

    7.13.1 tasks

    +
    +

    7.13.1 tasks

    ---
    @@ -5536,12 +5588,12 @@ end
     
    -
    -

    7.14 samba-config

    +
    +

    7.14 samba-config

    -
    -

    7.14.1 tasks

    +
    +

    7.14.1 tasks

    ---
    @@ -5566,16 +5618,16 @@ end
     
    -
    -

    7.14.2 templates

    +
    +

    7.14.2 templates

      -
    1. smb.conf
      +
    2. smb.conf
        -
      1. global settings
        +
      2. global settings
        {{ ansible_managed | comment }}
        @@ -5662,7 +5714,7 @@ end
         
      3. -
      4. media directories
        +
      5. media directories
        {% for name, path in media_dirs.items() | list %}
        @@ -5684,7 +5736,7 @@ end
         
      6. -
      7. include custom samba exports
        +
      8. include custom samba exports
        include = /etc/samba/smb.conf.custom
        @@ -5697,15 +5749,15 @@ end
         
    -
    -

    7.15 STARTED autoinstall-drivers

    +
    +

    7.15 STARTED autoinstall-drivers

    It would be nice to be able to detect if it is suitable to install those drivers:

    -
    -

    7.15.1 TODO sundtek for Sundtek devices (local or network connection)

    +
    +

    7.15.1 TODO sundtek for Sundtek devices (local or network connection)

    For now we have the role install-sundtek, in the future we could do a little better: @@ -5725,7 +5777,7 @@ Vendor-IDs:

      -
    1. planned packages
      +
    2. planned packages
      • yavdr-hardware-sundtek (basic configuration files and scripts, sundtek-avahi-mounter)
      • @@ -5736,8 +5788,8 @@ Vendor-IDs:
    -
    -

    7.15.2 TODO drivers for TT S2-6400 FF

    +
    +

    7.15.2 TODO drivers for TT S2-6400 FF

    https://github.com/s-moch/linux-saa716x - kann man den relevanten Teil als dkms-Paket bauen? @@ -5745,15 +5797,15 @@ Vendor-IDs:

    -
    -

    7.16 autoinstall-ubuntu-drivers

    +
    +

    7.16 autoinstall-ubuntu-drivers

    The tool ubuntu-drivers is used to install the matching driver version for nvidia graphics cards, virtualbox guest additions and Intel and AMD microcode updates.

    -
    -

    7.16.1 tasks

    +
    +

    7.16.1 tasks

    ---
    @@ -5776,8 +5828,8 @@ The tool ubuntu-drivers is used to install the matching driver version for nvidi
     
    -
    -

    7.17 autoinstall-virtualbox-guest

    +
    +

    7.17 autoinstall-virtualbox-guest

    This role installs the guest additions for virtualbox guests on Ubuntu 18.04 @@ -5826,12 +5878,12 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04

    -
    -

    7.18 autoinstall-atric-usb

    +
    +

    7.18 autoinstall-atric-usb

    -
    -

    7.18.1 dependencies

    +
    +

    7.18.1 dependencies

    ---
    @@ -5843,8 +5895,8 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04
     
    -
    -

    7.18.2 tasks

    +
    +

    7.18.2 tasks

    ---
    @@ -5886,8 +5938,8 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04
     
    -
    -

    7.18.3 templates

    +
    +

    7.18.3 templates

    {{ ansible_managed | comment }}
    @@ -5916,12 +5968,12 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04
     
    -
    -

    7.19 autoinstall-yausbir

    +
    +

    7.19 autoinstall-yausbir

    -
    -

    7.19.1 dependencies

    +
    +

    7.19.1 dependencies

    ---
    @@ -5932,8 +5984,8 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04
     
    -
    -

    7.19.2 tasks

    +
    +

    7.19.2 tasks

    ---
    @@ -5975,8 +6027,8 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04
     
    -
    -

    7.19.3 templates

    +
    +

    7.19.3 templates

    {{ ansible_managed | comment }}
    @@ -6004,15 +6056,15 @@ This role installs the guest additions for virtualbox guests on Ubuntu 18.04
     
    -
    -

    7.20 autoinstall-satip

    +
    +

    7.20 autoinstall-satip

    If a Sat>IP Server responds to a discovery request, the package vdr-plugin-satip is installed.

    -
    -

    7.20.1 tasks

    +
    +

    7.20.1 tasks

    ---
    @@ -6036,12 +6088,12 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.21 autoinstall-targavfd

    +
    +

    7.21 autoinstall-targavfd

    -
    -

    7.21.1 tasks

    +
    +

    7.21.1 tasks

    ---
    @@ -6057,12 +6109,12 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.22 autoinstall-imonlcd

    +
    +

    7.22 autoinstall-imonlcd

    -
    -

    7.22.1 tasks

    +
    +

    7.22.1 tasks

    ---
    @@ -6078,12 +6130,12 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.23 autoinstall-libcecdaemon

    +
    +

    7.23 autoinstall-libcecdaemon

    -
    -

    7.23.1 tasks

    +
    +

    7.23.1 tasks

    ---
    @@ -6099,12 +6151,12 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.24 autoinstall-pvr350

    +
    +

    7.24 autoinstall-pvr350

    -
    -

    7.24.1 tasks

    +
    +

    7.24.1 tasks

    ---
    @@ -6120,8 +6172,8 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.25 autoinstall-hauppauge-pvr

    +
    +

    7.25 autoinstall-hauppauge-pvr

    ---
    @@ -6136,12 +6188,12 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.26 autoinstall-firmware

    +
    +

    7.26 autoinstall-firmware

    -
    -

    7.26.1 dependencies

    +
    +

    7.26.1 dependencies

    ---
    @@ -6152,8 +6204,8 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.26.2 tasks

    +
    +

    7.26.2 tasks

    ---
    @@ -6194,12 +6246,12 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.27 autoinstall-dvbsky-firmware

    +
    +

    7.27 autoinstall-dvbsky-firmware

    -
    -

    7.27.1 dependencies

    +
    +

    7.27.1 dependencies

    ---
    @@ -6210,8 +6262,8 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.27.2 defaults

    +
    +

    7.27.2 defaults

    ---
    @@ -6221,8 +6273,8 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.27.3 tasks

    +
    +

    7.27.3 tasks

    ---
    @@ -6272,15 +6324,15 @@ If a Sat>IP Server responds to a discovery request, the package vdr-plugin-sa
     
    -
    -

    7.28 TODO autoinstall-dvbhddevice

    +
    +

    7.28 TODO autoinstall-dvbhddevice

    How to get a driver for the TT-6400 FF card? Needed firmware files are in the yavdr-firmware package.

    -
    -

    7.28.1 dependencies

    +
    +

    7.28.1 dependencies

    ---
    @@ -6291,8 +6343,8 @@ How to get a driver for the TT-6400 FF card? Needed firmware files are in the 
     
    -
    -

    7.28.2 tasks

    +
    +

    7.28.2 tasks

    ---
    @@ -6310,12 +6362,12 @@ How to get a driver for the TT-6400 FF card? Needed firmware files are in the 
     
    -
    -

    7.29 TODO autoinstall-dvbsddevice

    +
    +

    7.29 TODO autoinstall-dvbsddevice

    -
    -

    7.29.1 dependencies

    +
    +

    7.29.1 dependencies

    ---
    @@ -6326,8 +6378,8 @@ How to get a driver for the TT-6400 FF card? Needed firmware files are in the 
     
    -
    -

    7.29.2 tasks

    +
    +

    7.29.2 tasks

    ---
    @@ -6347,12 +6399,12 @@ How to get a driver for the TT-6400 FF card? Needed firmware files are in the 
     
    -
    -

    7.30 autoinstall-hardware-irmp

    +
    +

    7.30 autoinstall-hardware-irmp

    -
    -

    7.30.1 dependencies

    +
    +

    7.30.1 dependencies

    ---
    @@ -6363,8 +6415,8 @@ How to get a driver for the TT-6400 FF card? Needed firmware files are in the 
     
    -
    -

    7.30.2 tasks

    +
    +

    7.30.2 tasks

    ---
    @@ -6380,19 +6432,19 @@ How to get a driver for the TT-6400 FF card? Needed firmware files are in the 
     
    -
    -

    7.31 Serial IR Receivers

    +
    +

    7.31 Serial IR Receivers

    This role preconfigures the system for serial „homebrew“ receivers. Newer kernel versions provide serial_ir which acts as a rc-core driver, so we don’t need lircd - eventlircd can use the device directly.

    -As configured in the role yavdr-remote (/etc/rc_maps.cfg) a keytable for a RC-6 MCE remote is loaded by default. You can choose a different keymap which may also use another ir-protocol. +As configured in the role yavdr-remote (/etc/rc_maps.cfg) a keytable for a RC-6 MCE remote is loaded by default. You can choose a different keymap which may also use another ir-protocol.

    -
    -

    7.31.1 defaults

    +
    +

    7.31.1 defaults

    --- 
    @@ -6403,8 +6455,8 @@ As configured in the role yavdr-remote (/etc/rc_maps.cfg
     
    -
    -

    7.31.2 tasks

    +
    +

    7.31.2 tasks

    -
    -

    7.31.3 templates

    +
    +

    7.31.3 templates

      -
    1. load serial_ir on startup
      +
    2. load serial_ir on startup
      {{ ansible_managed | comment }}
      @@ -6447,7 +6499,7 @@ serial_ir
       
    3. -
    4. serial_ir module options
      +
    5. serial_ir module options
      {{ ansible_managed | comment }}
      @@ -6466,7 +6518,7 @@ install serial_ir setserial /dev/{{setserial options
      +
    6. setserial options
      {{ ansible_managed | comment }}
      @@ -6485,21 +6537,21 @@ install serial_ir setserial /dev/{{
      -

      7.32 kodi

      +
      +

      7.32 kodi

      -
      -

      7.32.1 tasks

      +
      +

      7.32.1 tasks

        -
      1. Install KODI
        +
      2. Install KODI
          -
        • main.yml
          -
          +
        • main.yml
          +
          - import_tasks: install-kodi.yml
             tags:
          @@ -6515,7 +6567,7 @@ install serial_ir setserial /dev/{{install-kodi.yml
          +
        • install-kodi.yml
          ---
          @@ -6547,7 +6599,7 @@ install serial_ir setserial /dev/{{configure-kodi.yml
          +
        • configure-kodi.yml
          - name: create kodi.service for the user session
          @@ -6601,12 +6653,12 @@ install serial_ir setserial /dev/{{
          -

          7.32.2 templates

          +
          +

          7.32.2 templates

            -
          1. kodi.service
            +
          2. kodi.service

            This systemd unit for the user session starts (and stops) kodi. @@ -6628,7 +6680,7 @@ This systemd unit for the user session starts (and stops) kodi.

        • -
        • set-kodi-diplay
          +
        • set-kodi-diplay

          This is a version-dependent script to force KODI to use the display set by the environment variable DISPLAY. The following Version is intended for KODI 18. @@ -6757,15 +6809,15 @@ This is a version-dependent script to force KODI to use the display set by the e

      -
      -

      7.32.3 files

      +
      +

      7.32.3 files

      Those configuration files provide a preconfiguration for kodi which overrides the system wide configuration

        -
      1. Lircmap.xml
        +
      2. Lircmap.xml

        This file allows to map keys sent by remotes via eventlircd (which uses the name devinput) to kodi key names. @@ -6836,14 +6888,14 @@ This file allows to map keys sent by remotes via eventlircd (which uses the name

    7. -
    8. keymaps
      +
    9. keymaps

      This file maps the keys defined in Lircmap.xml to actions within kodi.

        -
      1. remote.xml
        +
      2. remote.xml
        <?xml version="1.0" encoding="UTF-8"?>
        @@ -7395,17 +7447,17 @@ This file maps the keys defined in Lircmap.xml to actions within kodi.
         
    10. -
      -

      7.33 dvd

      +
      +

      7.33 dvd

      -
      -

      7.33.1 tasks

      +
      +

      7.33.1 tasks

        -
      • install libdvd-pkg, allow programs to eject optical media
        -
        +
      • install libdvd-pkg, allow programs to eject optical media
        +
        ---
         # file: roles/dvd/tasks/main.yml
        @@ -7442,15 +7494,15 @@ This file maps the keys defined in Lircmap.xml to actions within kodi.
         
        -
        -

        7.34 vdr-epg-daemon

        +
        +

        7.34 vdr-epg-daemon

        This role installs the vdr-epg-daemon

        -
        -

        7.34.1 defaults

        +
        +

        7.34.1 defaults

        ---
        @@ -7498,8 +7550,8 @@ This role installs the vdr-epg-daemon
         
        -
        -

        7.34.2 tasks

        +
        +

        7.34.2 tasks

        ---
        @@ -7605,15 +7657,16 @@ This role installs the vdr-epg-daemon
         
        -
        -

        7.34.3 templates

        +
        +

        7.34.3 templates

          -
        1. Template to allow Database access from network
          +
        2. Template for /etc/mysql/mariadb.conf.d/99-epgd.cnf

          -roles/epgd/templates/etc_mysql_mariadb.conf.d_99-epgd.cnf.j2 +to allow Database access from all hosts on network +file: roles/epgd/templates/etc_mysql_mariadb.conf.d_99-epgd.cnf.j2

          {{ ansible_managed | comment }}
          @@ -7623,10 +7676,10 @@ bind-address            = 0.0.0.0
           
        3. -
        4. mysqlpasswd template so epgd-tool is happy
          +
        5. template for /root/.ssh/mysqlpasswd so epgd-tool is happy

          -roles/epgd/templates/root_.ssh_mysqlpasswd.j2 +file: roles/epgd/templates/root_.ssh_mysqlpasswd.j2

          {{ ansible_managed | comment }}
          @@ -7635,10 +7688,10 @@ PASSWORD=NONE
           
        6. -
        7. epgd.conf template
          +
        8. template for /etc/epgd/epgd.conf

          -roles/epgd/templates/etc_epgd_epgd.conf.j2 +file: roles/epgd/templates/etc_epgd_epgd.conf.j2

          {{ ansible_managed | comment }}
          @@ -7723,12 +7776,12 @@ epgdata.timeout = {{ 
          -

          7.35 install-sundtek

          +
          +

          7.35 install-sundtek

          -
          -

          7.35.1 dependencies

          +
          +

          7.35.1 dependencies

          ---
          @@ -7739,8 +7792,8 @@ epgdata.timeout = {{ 
          -

          7.35.2 defaults

          +
          +

          7.35.2 defaults

          --- 
          @@ -7755,8 +7808,8 @@ epgdata.timeout = {{ 
          -

          7.35.3 tasks

          +
          +

          7.35.3 tasks

          ---
          @@ -7834,12 +7887,12 @@ epgdata.timeout = {{ 
          -

          7.35.4 templates

          +
          +

          7.35.4 templates

            -
          1. LD_PRELOAD for vdr.service
            +
          2. LD_PRELOAD for vdr.service
            {{ ansible_managed | comment }}
            @@ -7853,7 +7906,7 @@ epgdata.timeout = {{ /etc/systemd/system/sundtek.service
            +
          3. /etc/systemd/system/sundtek.service
            {{ ansible_managed | comment }}
            @@ -7876,109 +7929,110 @@ epgdata.timeout = {{ /etc/sundtek.conf
            +
          4. /etc/sundtek.conf
            -
            # ----- GLOBAL SECTION -----
            -#Set loglevel for logging to /var/log/mediasrv.log
            -#autoupdate=[on|off]                    #enable automatic driver update, default off
            -autoupdate=off
            -#loglevel=[off|min|full]                #default: off
            -                                        #max .. little bit more
            -loglevel=off
            -#pluginpath=/path/to/drivers            #set path to drivers
            -#dvb_api_version=x.y                    #default API version will be parsed from
            -                                        #/usr/include/linux/dvb/version.h, if no such file is
            -                                        #available the latest internally supported API ::version will be 
            -                                        #used (which will be quite new)
            -#audio_skip_bytes=N                     #when changing analogTV channels, 
            -                                        #skip N bytes to suppress audio noise
            -#bulk_notification[on|off]              #default off, bulk_notification will only trigger device_attach once
            -                                        #after the the first device scan when the driver is started up
            -                                        #after this first scan, the notification will be triggered
            -                                        #normally again for each device.
            -                                        #
            -                                        #for example when 2 devices are attached to the system only one
            -                                        #notification will be triggered initially, any at a later time
            -                                        #attached device will generate another device_attach notification
            -                                        #by default each device will call the script which is set up with
            -                                        #device_attach
            -#use_tvvideo=[on|off]                   #use /dev/tvvideoN instead of /dev/video
            -                                        #this works around a new Adobe Flash bug in 2012, where flash crashes
            -                                        #if files (/dev/videoN) other than /dev/video0 are available
            +
            {{ ansible_managed | comment }}
            +# ----- GLOBAL SECTION -----
            +#Set loglevel for logging to /var/log/mediasrv.log
            +#autoupdate=[on|off]                    #enable automatic driver update, default off
            +autoupdate=off
            +#loglevel=[off|min|full]                #default: off
            +                                        #max .. little bit more
            +loglevel=off
            +#pluginpath=/path/to/drivers            #set path to drivers
            +#dvb_api_version=x.y                    #default API version will be parsed from
            +                                        #/usr/include/linux/dvb/version.h, if no such file is
            +                                        #available the latest internally supported API ::version will be 
            +                                        #used (which will be quite new)
            +#audio_skip_bytes=N                     #when changing analogTV channels, 
            +                                        #skip N bytes to suppress audio noise
            +#bulk_notification[on|off]              #default off, bulk_notification will only trigger device_attach once
            +                                        #after the the first device scan when the driver is started up
            +                                        #after this first scan, the notification will be triggered
            +                                        #normally again for each device.
            +                                        #
            +                                        #for example when 2 devices are attached to the system only one
            +                                        #notification will be triggered initially, any at a later time
            +                                        #attached device will generate another device_attach notification
            +                                        #by default each device will call the script which is set up with
            +                                        #device_attach
            +#use_tvvideo=[on|off]                   #use /dev/tvvideoN instead of /dev/video
            +                                        #this works around a new Adobe Flash bug in 2012, where flash crashes
            +                                        #if files (/dev/videoN) other than /dev/video0 are available
              
            -#use_hwpidfilter=[on|off]               #For DVB-C, DVB-T, DVB-S/S2
            -                                        #enable PID filter, please be careful with that, there are only 15 HW Pid filters available
            -                                        #when more than 15 pids are set up the pid filter will be disabled automatically
            +#use_hwpidfilter=[on|off]               #For DVB-C, DVB-T, DVB-S/S2
            +                                        #enable PID filter, please be careful with that, there are only 15 HW Pid filters available
            +                                        #when more than 15 pids are set up the pid filter will be disabled automatically
             
            -#dmhwpidfilter=[on|off]                 #default on, in some cases off might be useful to disable hw pid filter for settopboxes
            -                                        #if you get a black image when capturing a TV channel and watching another channel on the
            -                                        #same transponder - try this option and reboot
            +#dmhwpidfilter=[on|off]                 #default on, in some cases off might be useful to disable hw pid filter for settopboxes
            +                                        #if you get a black image when capturing a TV channel and watching another channel on the
            +                                        #same transponder - try this option and reboot
             
            -#usb_transaction_delay=[0-20]           #throttle the USB setup transactions, this can solve problems with weak USB stacks for
            -                                        #example for embedded boards, unit is milliseconds
            +#usb_transaction_delay=[0-20]           #throttle the USB setup transactions, this can solve problems with weak USB stacks for
            +                                        #example for embedded boards, unit is milliseconds
             
            -#usb_timeout=[0 - N]                    #USB timeout for each transaction in milliseconds, 0 default infinite
            -#voltage_tone_off=[1 or 0]              #0 .. default, normal behaviour
            -                                        #1 .. force DVB-S/S2 to not use any Voltage or Tone (ignore any user parameters)
            +#usb_timeout=[0 - N]                    #USB timeout for each transaction in milliseconds, 0 default infinite
            +#voltage_tone_off=[1 or 0]              #0 .. default, normal behaviour
            +                                        #1 .. force DVB-S/S2 to not use any Voltage or Tone (ignore any user parameters)
                                                     
            -#ir_disabled=[1 or 0]                   #0 .. enable remote control polling, the driver will permanently check for remote control keys
            -                                        #1 .. disable remote control polling, might fix bugs with weak USB stacks on embedded boards
            +#ir_disabled=[1 or 0]                   #0 .. enable remote control polling, the driver will permanently check for remote control keys
            +                                        #1 .. disable remote control polling, might fix bugs with weak USB stacks on embedded boards
             
            -#
            -#Enable listening on network
            -#enablenetwork=[on|off]                 #default: off
            +#
            +#Enable listening on network
            +#enablenetwork=[on|off]                 #default: off
             
            -#Lowest adapter number to start with, e.g. /dev/dvb/adapter5/frontend0
            -#first_adapter=5
            +#Lowest adapter number to start with, e.g. /dev/dvb/adapter5/frontend0
            +#first_adapter=5
             
            -#Call attach script when new device appears
            -#device_attach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            -device_attach=/usr/bin/sundtek_attach
            +#Call attach script when new device appears
            +#device_attach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            +device_attach=/usr/bin/sundtek_attach
             
            -#Call detach script when device disappears
            -#device_detach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            -device_detach=/usr/bin/sundtek_detach
            +#Call detach script when device disappears
            +#device_detach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            +device_detach=/usr/bin/sundtek_detach
             
             
            -{% if sundtek_devices is definded %}
            -{% for device in sundtek_devices.local %}
            -{% if device.serial is defined %}
            -[{{ device.serial }}]
            +{% if sundtek_devices is definded %}
            +{% for device in sundtek_devices.local %}
            +{% if device.serial is defined %}
            +[{{ device.serial }}]
             
            -#Infrared protocol to use
            -#ir_protocol=[RC5|NEC|RC6]                      #default: NEC
            -{% if device.ir_protocol|default("") %}
            -ir_protocol={{ device.ir_protocol }}
            -{% endif %}
            +#Infrared protocol to use
            +#ir_protocol=[RC5|NEC|RC6]                      #default: NEC
            +{% if device.ir_protocol|default("") %}
            +ir_protocol={{ device.ir_protocol }}
            +{% endif %}
             
            -#Keymap to use, e.g. "/lib/udev/rc_keymaps/vp702x"
            -#rcmap=[PATH_TO_KEYMAP]                 #default: keymap which comes with the device
            -{% if device.rcmap|default("") %}
            -rcmap={{ device.rcmap }}
            -{% endif %}
            +#Keymap to use, e.g. "/lib/udev/rc_keymaps/vp702x"
            +#rcmap=[PATH_TO_KEYMAP]                 #default: keymap which comes with the device
            +{% if device.rcmap|default("") %}
            +rcmap={{ device.rcmap }}
            +{% endif %}
             
            -#Choose initial DVB mode for hybrid DVB-T/DVB-C devices only
            -#initial_dvb_mode=[DVBC|DVBT]
            -{% if device.initial_dvb_mode|default("") %}
            -initial_dvb_mode={{ device.dvb_mode }}
            -{% endif %}
            +#Choose initial DVB mode for hybrid DVB-T/DVB-C devices only
            +#initial_dvb_mode=[DVBC|DVBT]
            +{% if device.initial_dvb_mode|default("") %}
            +initial_dvb_mode={{ device.dvb_mode }}
            +{% endif %}
             
            -#Call attach script when new device appears
            -#device_attach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            -device_attach=/usr/bin/sundtek_attach
            +#Call attach script when new device appears
            +#device_attach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            +device_attach=/usr/bin/sundtek_attach
             
            -#Call detach script when device disappears
            -#device_detach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            -device_detach=/usr/bin/sundtek_detach
            +#Call detach script when device disappears
            +#device_detach=[PATH_TO_SCRIPT] [PARAMETER|DEVID]       #"DEVID" will automatically be replaced with the device ID
            +device_detach=/usr/bin/sundtek_detach
             
            -{% if device.capabilites.analog_tv %}
            -disable_analogtv=1                                      #disable initialization of analogTV Frontend
            -{% endif %}
            +{% if device.capabilites.analog_tv %}
            +disable_analogtv=1                                      #disable initialization of analogTV Frontend
            +{% endif %}
             
            -{% endif %}
            -{% endfor %}
            -{% endif %}
            +{% endif %}
            +{% endfor %}
            +{% endif %}
             
            @@ -7986,8 +8040,8 @@ epgdata.timeout = {{ -

            7.36 template-test

            +
            +

            7.36 template-test

            ---
            @@ -8228,12 +8282,12 @@ EndSection
             
            -
            -

            7.37 wakeup

            +
            +

            7.37 wakeup

            -
            -

            7.37.1 defaults

            +
            +

            7.37.1 defaults

            ---
            @@ -8243,8 +8297,8 @@ EndSection
             
            -
            -

            7.37.2 tasks

            +
            +

            7.37.2 tasks

            ---
            @@ -8265,8 +8319,8 @@ EndSection
             
            -
            -

            7.37.3 templates

            +
            +

            7.37.3 templates

            {{ ansible_managed | comment }}
            @@ -8292,12 +8346,12 @@ ACPI_START_AHEAD=5
             
            -
            -

            7.38 grub-config

            +
            +

            7.38 grub-config

            -
            -

            7.38.1 default variables

            +
            +

            7.38.1 default variables

            system:
            @@ -8309,8 +8363,8 @@ ACPI_START_AHEAD=5
             
            -
            -

            7.38.2 tasks

            +
            +

            7.38.2 tasks

            ---
            @@ -8335,8 +8389,8 @@ ACPI_START_AHEAD=5
             
            -
            -

            7.38.3 templates

            +
            +

            7.38.3 templates

            #!/bin/sh
            @@ -8359,8 +8413,8 @@ fi
             
            -
            -

            7.38.4 handlers

            +
            +

            7.38.4 handlers

            ---
            @@ -8383,15 +8437,15 @@ fi
             
            -
            -

            8 Modules

            +
            +

            8 Modules

            This section contains custom modules for the yaVDR Playbooks. They are used to collect facts about the system and configure applications and daemons.

            -
            -

            8.1 hardware_facts.py

            +
            +

            8.1 hardware_facts.py

            # This Module collects the vendor- and device ids for USB- and PCI(e)-devices and currently loaded kernel modules.
            @@ -8569,8 +8623,8 @@ This section contains custom modules for the yaVDR Playbooks. They are used to c
             
            -
            -

            8.2 pci_facts.py

            +
            +

            8.2 pci_facts.py

            @@ -8646,8 +8700,8 @@ This section contains custom modules for the yaVDR Playbooks. They are used to c
             
            -
            -

            8.3 satip_facts.py

            +
            +

            8.3 satip_facts.py

            DOCUMENTATION = '''
            @@ -8771,8 +8825,8 @@ This section contains custom modules for the yaVDR Playbooks. They are used to c
             
            -
            -

            8.4 xrandr_facts.py

            +
            +

            8.4 xrandr_facts.py

            • [ ] support multiple screens (-d :0.0 .. :0.n)
            • @@ -9177,8 +9231,8 @@ This section contains custom modules for the yaVDR Playbooks. They are used to c
            -
            -

            9 Handlers

            +
            +

            9 Handlers

            - name: Reconfigure unattended upgrades with dpkg
            @@ -9271,7 +9325,7 @@ This section contains custom modules for the yaVDR Playbooks. They are used to c
             

            Autor: Alexander Grothe <seahawk1986@gmx.de>

            -

            Created: 2019-03-12 Di 09:37

            +

            Created: 2019-03-24 So 12:10

            Validate

            diff --git a/Manual.org b/Manual.org index e43698f..bd228d9 100644 --- a/Manual.org +++ b/Manual.org @@ -87,10 +87,6 @@ Several roles are used to tie everything together: - yavdr-xorg :: install and configure a systemd user session with a running X-server. A frontend script will manage VDR's frontend and other applications like KODI. Also choose the best possible output plugin. - grub-config :: update grub configuration based on executed roles -*** Using vdr, pulseaudio and xorg together -:PROPERTIES: -:ID: a107fd52-172c-4018-8374-8f2ce299f842 -:END: * Notes :noexport: :PROPERTIES: @@ -105,15 +101,18 @@ Several roles are used to tie everything together: :PROPERTIES: :ID: ca82eb6b-e491-4c61-b65f-a394b6b654de :END: -*** STARTED BusID für (nvidia) Grafikkarten aus lspci auslesen +*** DONE BusID für (nvidia) Grafikkarten aus lspci auslesen :PROPERTIES: :ID: e664458a-ad80-4b29-a794-bd433f8d2a22 :END: +:LOGBOOK: +- State "DONE" from "STARTED" [2019-03-20 Mi 19:35] +:END: Format: "%d:%d:%d" (lspci liefert es als "%04x:%02x:%02x.%x", domain, bus, device, function) - Wie mit mehreren GPUs umgehen? Priorität bzw. Reihenfolge? - Was ist mit NVidia Optimus/Bumblebee (AFAIK keine VDPAU-Funktionalität)? - Wie BusID der xrandr-Ausgabe zuordnen? -*** NVIDIA-Documentation about the BusID: +*** NOTE NVIDIA-Documentation about the BusID: :PROPERTIES: :ID: 4341f6bd-fdec-4dad-8d3b-83b95c20189d :END: @@ -175,9 +174,13 @@ either directly or using a configuration wizard or a web frontend :PROPERTIES: :ID: 324e03d0-7fe8-4382-be44-7372e14d0b82 :END: -- intel :: softhddevice-vpp +- intel :: softhddevice-vpp or vaapidevice - amd :: softhddevice-vpp - nvidia :: softhddevice-openglosd (if no HEVC channels are needed) +** TODO Document using vdr, pulseaudio and xorg together +:PROPERTIES: +:ID: a107fd52-172c-4018-8374-8f2ce299f842 +:END: * Introduction :PROPERTIES: @@ -1120,6 +1123,14 @@ The additional plugins to install can be set in the variable ~{{vdr_plugins}}~ i mode: 0644 force: no when: vdr_channels_conf is not defined and vdr_channels_conf_url is defined + +- name: "vdr configuration | svdrphosts.conf" + template: + src: templates/svdrphosts.conf.j2 + dest: '{{ vdr.confdir }}/svdrphosts.conf' + owner: '{{ vdr.user }}' + group: '{{ vdr.group }}' + mode: 0644 #+END_SRC **** start vdr after network-online.target @@ -1144,10 +1155,36 @@ The additional plugins to install can be set in the variable ~{{vdr_plugins}}~ i :PROPERTIES: :ID: 0c5c2e3b-57af-46a9-b69e-3499e25fce59 :END: -Start after network-online.target +**** Start vdr.service after network-online.target #+BEGIN_SRC conf :tangle roles/vdr/templates/systemd/network-online.j2 :mkdirp yes +{{ansible_managed | comment }} [Unit] After=network-online.target +#+END_SRC + +**** svdrphosts.conf +#+BEGIN_SRC jinja2 :tangle roles/vdr/templates/svdrphosts.conf.j2 :mkdirp yes +{{ ansible_managed | comment }} +# +# svdrphosts This file describes a number of host addresses that +# are allowed to connect to the SVDRP port of the Video +# Disk Recorder (VDR) running on this system. +# Syntax: +# +# IP-Address[/Netmask] +# + +127.0.0.1 # always accept localhost +#192.168.100.0/24 # any host on the local net +#204.152.189.113 # a specific host +#0.0.0.0/0 # any host on any net (USE THIS WITH CARE!) + +{% if vdr_svdrphosts is defined %} +{% for host_or_subnet in vdr_svdrphosts %} +{{ host_or_subnet }} +{% endfor %} +{% endif %} + #+END_SRC *** files :PROPERTIES: @@ -6079,14 +6116,15 @@ This role installs the vdr-epg-daemon #+include: roles/epgd/tasks/main.yml src yml *** templates -**** Template to allow Database access from network -~roles/epgd/templates/etc_mysql_mariadb.conf.d_99-epgd.cnf.j2~ +**** Template for /etc/mysql/mariadb.conf.d/99-epgd.cnf +to allow Database access from all hosts on network +~file: roles/epgd/templates/etc_mysql_mariadb.conf.d_99-epgd.cnf.j2~ #+include: roles/epgd/templates/etc_mysql_mariadb.conf.d_99-epgd.cnf.j2 src jinja2 -**** mysqlpasswd template so epgd-tool is happy -~roles/epgd/templates/root_.ssh_mysqlpasswd.j2~ +**** template for ~/root/.ssh/mysqlpasswd~ so epgd-tool is happy +~file: roles/epgd/templates/root_.ssh_mysqlpasswd.j2~ #+include: roles/epgd/templates/root_.ssh_mysqlpasswd.j2 src jinja2 -**** epgd.conf template -~roles/epgd/templates/etc_epgd_epgd.conf.j2~ +**** template for /etc/epgd/epgd.conf +~file: roles/epgd/templates/etc_epgd_epgd.conf.j2~ #+include: roles/epgd/templates/etc_epgd_epgd.conf.j2 src jinja2 ** install-sundtek diff --git a/roles/vdr/tasks/main.yml b/roles/vdr/tasks/main.yml index 65c4808..09d3c94 100644 --- a/roles/vdr/tasks/main.yml +++ b/roles/vdr/tasks/main.yml @@ -94,6 +94,14 @@ mode: 0644 force: no when: vdr_channels_conf is not defined and vdr_channels_conf_url is defined + +- name: "vdr configuration | svdrphosts.conf" + template: + src: templates/svdrphosts.conf.j2 + dest: '{{ vdr.confdir }}/svdrphosts.conf' + owner: '{{ vdr.user }}' + group: '{{ vdr.group }}' + mode: 0644 - name: create directory for vdr.service systemd drop-in files file: dest: '{{ item }}' diff --git a/roles/vdr/templates/svdrphosts.conf.j2 b/roles/vdr/templates/svdrphosts.conf.j2 new file mode 100644 index 0000000..144b056 --- /dev/null +++ b/roles/vdr/templates/svdrphosts.conf.j2 @@ -0,0 +1,20 @@ +{{ ansible_managed | comment }} +# +# svdrphosts This file describes a number of host addresses that +# are allowed to connect to the SVDRP port of the Video +# Disk Recorder (VDR) running on this system. +# Syntax: +# +# IP-Address[/Netmask] +# + +127.0.0.1 # always accept localhost +#192.168.100.0/24 # any host on the local net +#204.152.189.113 # a specific host +#0.0.0.0/0 # any host on any net (USE THIS WITH CARE!) + +{% if vdr_svdrphosts is defined %} +{% for host_or_subnet in vdr_svdrphosts %} +{{ host_or_subnet }} +{% endfor %} +{% endif %} diff --git a/roles/vdr/templates/systemd/network-online.j2 b/roles/vdr/templates/systemd/network-online.j2 index 758b827..efacf08 100644 --- a/roles/vdr/templates/systemd/network-online.j2 +++ b/roles/vdr/templates/systemd/network-online.j2 @@ -1,2 +1,3 @@ +{{ansible_managed | comment }} [Unit] After=network-online.target