rename fact files
This commit is contained in:
parent
54c7d091fd
commit
5cd3869a51
108
Manual.org
108
Manual.org
@ -37,6 +37,7 @@ The ~yavdr07.yml~ playbook sets up a fully-featured yaVDR installation:
|
|||||||
- yavdr-xorg # graphical session
|
- yavdr-xorg # graphical session
|
||||||
- yavdr-remote # remote configuration files, services and scripts
|
- yavdr-remote # remote configuration files, services and scripts
|
||||||
- grub-config # configure grub
|
- grub-config # configure grub
|
||||||
|
- autoinstall-satip # install vdr-plugin-satip if a Sat>IP server has been found
|
||||||
|
|
||||||
|
|
||||||
handlers:
|
handlers:
|
||||||
@ -261,6 +262,7 @@ yavdr-common executes the following tasks:
|
|||||||
- biosdevname
|
- biosdevname
|
||||||
- linux-firmware
|
- linux-firmware
|
||||||
- psmisc
|
- psmisc
|
||||||
|
- python3-usb
|
||||||
- software-properties-common
|
- software-properties-common
|
||||||
- ssh
|
- ssh
|
||||||
- ubuntu-drivers-common
|
- ubuntu-drivers-common
|
||||||
@ -280,13 +282,13 @@ yavdr-common executes the following tasks:
|
|||||||
- name: copy facts script for USB- and PCI(e)-IDs
|
- name: copy facts script for USB- and PCI(e)-IDs
|
||||||
copy:
|
copy:
|
||||||
src: files/hardware.facts.py
|
src: files/hardware.facts.py
|
||||||
dest: /etc/ansible/facts.d/hardware.facts
|
dest: /etc/ansible/facts.d/hardware.fact
|
||||||
mode: '0775'
|
mode: '0775'
|
||||||
|
|
||||||
- name: copy facts script for Sat>IP server detection
|
- name: copy facts script for Sat>IP server detection
|
||||||
copy:
|
copy:
|
||||||
src: files/satip.facts.py
|
src: files/satip.facts.py
|
||||||
dest: /etc/ansible/facts.d/satip.facts
|
dest: /etc/ansible/facts.d/satip.fact
|
||||||
mode: '0775'
|
mode: '0775'
|
||||||
|
|
||||||
- name: reload ansible local facts
|
- name: reload ansible local facts
|
||||||
@ -294,8 +296,7 @@ yavdr-common executes the following tasks:
|
|||||||
#+END_SRC
|
#+END_SRC
|
||||||
|
|
||||||
*** files:
|
*** files:
|
||||||
#+BEGIN_SRC python :tangle roles/yavdr-common/files/hardware.facts.py :mkdirp yes
|
#+BEGIN_SRC python :tangle roles/yavdr-common/files/hardware.fact.py :mkdirp yes :shebang #!/usr/bin/env python3
|
||||||
#!/usr/bin/env python3
|
|
||||||
# This script returns a list of Vendor- and Product-IDs for all connected usb
|
# This script returns a list of Vendor- and Product-IDs for all connected usb
|
||||||
# and pci(e) devices in json format
|
# and pci(e) devices in json format
|
||||||
import glob
|
import glob
|
||||||
@ -325,50 +326,49 @@ if __name__ == '__main__':
|
|||||||
pci_devices = format_device_list(get_pci_devices())
|
pci_devices = format_device_list(get_pci_devices())
|
||||||
print(json.dumps({'usb': usb_devices, 'pci': pci_devices}))
|
print(json.dumps({'usb': usb_devices, 'pci': pci_devices}))
|
||||||
#+END_SRC
|
#+END_SRC
|
||||||
#+BEGIN_SRC python :tangle roles/yavdr-common/files/satip.facts.py :mkdirp yes
|
#+BEGIN_SRC python :tangle roles/yavdr-common/files/satip.fact.py :mkdirp yes :shebang #!/usr/bin/env python3
|
||||||
#!/usr/bin/env python3
|
# This script sends a multicast message and awaits responses by Sat>IP servers.
|
||||||
# This script sends a multicast message and awaits responses by Sat>IP servers.
|
# returns the boolean variable 'satip_detected' as json
|
||||||
# returns the boolean variable 'satip_detected' as json
|
import json
|
||||||
import json
|
import socket
|
||||||
import socket
|
import sys
|
||||||
import sys
|
import time
|
||||||
import time
|
|
||||||
|
|
||||||
SSDP_ADDR = "239.255.255.250"
|
SSDP_ADDR = "239.255.255.250"
|
||||||
SSDP_PORT = 1900
|
SSDP_PORT = 1900
|
||||||
# SSDP_MX = max delay for server response
|
# SSDP_MX = max delay for server response
|
||||||
# a value of 2s is recommended by the SAT>IP specification 1.2.2
|
# a value of 2s is recommended by the SAT>IP specification 1.2.2
|
||||||
SSDP_MX = 2
|
SSDP_MX = 2
|
||||||
SSDP_ST = "urn:ses-com:device:SatIPServer:1"
|
SSDP_ST = "urn:ses-com:device:SatIPServer:1"
|
||||||
|
|
||||||
ssdpRequest = "\r\n".join((
|
ssdpRequest = "\r\n".join((
|
||||||
"M-SEARCH * HTTP/1.1",
|
"M-SEARCH * HTTP/1.1",
|
||||||
"HOST: %s:%d" % (SSDP_ADDR, SSDP_PORT),
|
"HOST: %s:%d" % (SSDP_ADDR, SSDP_PORT),
|
||||||
"MAN: \"ssdp:discover\"",
|
"MAN: \"ssdp:discover\"",
|
||||||
"MX: %d" % (SSDP_MX),
|
"MX: %d" % (SSDP_MX),
|
||||||
"ST: %s" % (SSDP_ST),
|
"ST: %s" % (SSDP_ST),
|
||||||
"\r\n"))
|
"\r\n"))
|
||||||
|
|
||||||
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
||||||
# according to Sat>IP Specification 1.2.2, p. 20
|
# according to Sat>IP Specification 1.2.2, p. 20
|
||||||
# a client should send three requests within 100 ms with a ttl of 2
|
# a client should send three requests within 100 ms with a ttl of 2
|
||||||
sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, 2)
|
sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, 2)
|
||||||
sock.settimeout(SSDP_MX + 0.5)
|
sock.settimeout(SSDP_MX + 0.5)
|
||||||
for _ in range(3):
|
for _ in range(3):
|
||||||
sock.sendto(ssdpRequest.encode('ascii'), (SSDP_ADDR, SSDP_PORT))
|
sock.sendto(ssdpRequest.encode('ascii'), (SSDP_ADDR, SSDP_PORT))
|
||||||
time.sleep(0.03)
|
time.sleep(0.03)
|
||||||
try:
|
try:
|
||||||
response = sock.recv(1000).decode()
|
response = sock.recv(1000).decode()
|
||||||
if response and "SERVER:" in response:
|
if response and "SERVER:" in response:
|
||||||
got_response = True
|
got_response = True
|
||||||
else:
|
else:
|
||||||
raise ValueError('No satip server detected')
|
raise ValueError('No satip server detected')
|
||||||
except (socket.timeout, ValueError):
|
except (socket.timeout, ValueError):
|
||||||
got_response = False
|
got_response = False
|
||||||
finally:
|
finally:
|
||||||
print(json.dumps(
|
print(json.dumps(
|
||||||
{'satip_detected': got_response}
|
{'satip_detected': got_response}
|
||||||
))
|
))
|
||||||
#+END_SRC
|
#+END_SRC
|
||||||
*** templates
|
*** templates
|
||||||
#+BEGIN_SRC shell :tangle roles/yavdr-common/templates/90-norecommends.j2 :mkdirp yes
|
#+BEGIN_SRC shell :tangle roles/yavdr-common/templates/90-norecommends.j2 :mkdirp yes
|
||||||
@ -811,7 +811,23 @@ fi
|
|||||||
#+END_SRC
|
#+END_SRC
|
||||||
** TODO autoinstall-drivers
|
** TODO autoinstall-drivers
|
||||||
*** sundtek
|
*** sundtek
|
||||||
***
|
|
||||||
|
** autoinstall-satip
|
||||||
|
*** tasks
|
||||||
|
#+BEGIN_SRC yaml :tangle roles/autoinstall-satip/tasks/main.yml
|
||||||
|
---
|
||||||
|
# file roles/autoinstall-satip/tasks/main.yml
|
||||||
|
|
||||||
|
- name: Display all variables/facts known for a host
|
||||||
|
debug:
|
||||||
|
var: '{{ ansible_local }}'
|
||||||
|
verbosity: 1
|
||||||
|
|
||||||
|
- name: apt install vdr-plugin-satip if a Sat>IP server has been detected
|
||||||
|
apt:
|
||||||
|
name: vdr-plugin-satip
|
||||||
|
when: ansible_local.satip.satip_detected
|
||||||
|
#+END_SRC
|
||||||
** TODO autoinstall-plugins
|
** TODO autoinstall-plugins
|
||||||
*** imonlcd
|
*** imonlcd
|
||||||
*** targavfd
|
*** targavfd
|
||||||
|
0
roles/yavdr-common/files/hardware.facts.py → roles/yavdr-common/files/hardware.fact.py
Normal file → Executable file
0
roles/yavdr-common/files/hardware.facts.py → roles/yavdr-common/files/hardware.fact.py
Normal file → Executable file
43
roles/yavdr-common/files/satip.fact.py
Executable file
43
roles/yavdr-common/files/satip.fact.py
Executable file
@ -0,0 +1,43 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
# This script sends a multicast message and awaits responses by Sat>IP servers.
|
||||||
|
# returns the boolean variable 'satip_detected' as json
|
||||||
|
import json
|
||||||
|
import socket
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
|
||||||
|
SSDP_ADDR = "239.255.255.250"
|
||||||
|
SSDP_PORT = 1900
|
||||||
|
# SSDP_MX = max delay for server response
|
||||||
|
# a value of 2s is recommended by the SAT>IP specification 1.2.2
|
||||||
|
SSDP_MX = 2
|
||||||
|
SSDP_ST = "urn:ses-com:device:SatIPServer:1"
|
||||||
|
|
||||||
|
ssdpRequest = "\r\n".join((
|
||||||
|
"M-SEARCH * HTTP/1.1",
|
||||||
|
"HOST: %s:%d" % (SSDP_ADDR, SSDP_PORT),
|
||||||
|
"MAN: \"ssdp:discover\"",
|
||||||
|
"MX: %d" % (SSDP_MX),
|
||||||
|
"ST: %s" % (SSDP_ST),
|
||||||
|
"\r\n"))
|
||||||
|
|
||||||
|
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
||||||
|
# according to Sat>IP Specification 1.2.2, p. 20
|
||||||
|
# a client should send three requests within 100 ms with a ttl of 2
|
||||||
|
sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, 2)
|
||||||
|
sock.settimeout(SSDP_MX + 0.5)
|
||||||
|
for _ in range(3):
|
||||||
|
sock.sendto(ssdpRequest.encode('ascii'), (SSDP_ADDR, SSDP_PORT))
|
||||||
|
time.sleep(0.03)
|
||||||
|
try:
|
||||||
|
response = sock.recv(1000).decode()
|
||||||
|
if response and "SERVER:" in response:
|
||||||
|
got_response = True
|
||||||
|
else:
|
||||||
|
raise ValueError('No satip server detected')
|
||||||
|
except (socket.timeout, ValueError):
|
||||||
|
got_response = False
|
||||||
|
finally:
|
||||||
|
print(json.dumps(
|
||||||
|
{'satip_detected': got_response}
|
||||||
|
))
|
@ -1,43 +0,0 @@
|
|||||||
#!/usr/bin/env python3
|
|
||||||
# This script sends a multicast message and awaits responses by Sat>IP servers.
|
|
||||||
# returns the boolean variable 'satip_detected' as json
|
|
||||||
import json
|
|
||||||
import socket
|
|
||||||
import sys
|
|
||||||
import time
|
|
||||||
|
|
||||||
SSDP_ADDR = "239.255.255.250"
|
|
||||||
SSDP_PORT = 1900
|
|
||||||
# SSDP_MX = max delay for server response
|
|
||||||
# a value of 2s is recommended by the SAT>IP specification 1.2.2
|
|
||||||
SSDP_MX = 2
|
|
||||||
SSDP_ST = "urn:ses-com:device:SatIPServer:1"
|
|
||||||
|
|
||||||
ssdpRequest = "\r\n".join((
|
|
||||||
"M-SEARCH * HTTP/1.1",
|
|
||||||
"HOST: %s:%d" % (SSDP_ADDR, SSDP_PORT),
|
|
||||||
"MAN: \"ssdp:discover\"",
|
|
||||||
"MX: %d" % (SSDP_MX),
|
|
||||||
"ST: %s" % (SSDP_ST),
|
|
||||||
"\r\n"))
|
|
||||||
|
|
||||||
sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
|
|
||||||
# according to Sat>IP Specification 1.2.2, p. 20
|
|
||||||
# a client should send three requests within 100 ms with a ttl of 2
|
|
||||||
sock.setsockopt(socket.IPPROTO_IP, socket.IP_MULTICAST_TTL, 2)
|
|
||||||
sock.settimeout(SSDP_MX + 0.5)
|
|
||||||
for _ in range(3):
|
|
||||||
sock.sendto(ssdpRequest.encode('ascii'), (SSDP_ADDR, SSDP_PORT))
|
|
||||||
time.sleep(0.03)
|
|
||||||
try:
|
|
||||||
response = sock.recv(1000).decode()
|
|
||||||
if response and "SERVER:" in response:
|
|
||||||
got_response = True
|
|
||||||
else:
|
|
||||||
raise ValueError('No satip server detected')
|
|
||||||
except (socket.timeout, ValueError):
|
|
||||||
got_response = False
|
|
||||||
finally:
|
|
||||||
print(json.dumps(
|
|
||||||
{'satip_detected': got_response}
|
|
||||||
))
|
|
@ -32,6 +32,7 @@
|
|||||||
- biosdevname
|
- biosdevname
|
||||||
- linux-firmware
|
- linux-firmware
|
||||||
- psmisc
|
- psmisc
|
||||||
|
- python3-usb
|
||||||
- software-properties-common
|
- software-properties-common
|
||||||
- ssh
|
- ssh
|
||||||
- ubuntu-drivers-common
|
- ubuntu-drivers-common
|
||||||
@ -48,13 +49,13 @@
|
|||||||
- name: copy facts script for USB- and PCI(e)-IDs
|
- name: copy facts script for USB- and PCI(e)-IDs
|
||||||
copy:
|
copy:
|
||||||
src: files/hardware.facts.py
|
src: files/hardware.facts.py
|
||||||
dest: /etc/ansible/facts.d/hardware.facts
|
dest: /etc/ansible/facts.d/hardware.fact
|
||||||
mode: '0775'
|
mode: '0775'
|
||||||
|
|
||||||
- name: copy facts script for Sat>IP server detection
|
- name: copy facts script for Sat>IP server detection
|
||||||
copy:
|
copy:
|
||||||
src: files/satip.facts.py
|
src: files/satip.facts.py
|
||||||
dest: /etc/ansible/facts.d/satip.facts
|
dest: /etc/ansible/facts.d/satip.fact
|
||||||
mode: '0775'
|
mode: '0775'
|
||||||
|
|
||||||
- name: reload ansible local facts
|
- name: reload ansible local facts
|
||||||
|
Loading…
x
Reference in New Issue
Block a user