0
0
Fork 0
mirror of https://github.com/boltgolt/howdy.git synced 2024-09-19 09:51:19 +02:00
howdy/debian/postinst

203 lines
5.2 KiB
Text
Raw Normal View History

2018-11-09 12:43:10 +01:00
#!/usr/bin/python3
# Installation script to install howdy
2018-04-05 21:12:36 +02:00
# Executed after primary apt install
def col(id):
"""Add color escape sequences"""
if id == 1: return "\033[32m"
if id == 2: return "\033[33m"
if id == 3: return "\033[31m"
return "\033[0m"
# Import required modules
import fileinput
2018-02-05 23:43:32 +01:00
import subprocess
import sys
import os
import re
import tarfile
from shutil import rmtree, which
2018-02-05 23:43:32 +01:00
# Don't run unless we need to configure the install
# Will also happen on upgrade but we will catch that later on
if "configure" not in sys.argv:
sys.exit(0)
2018-02-05 23:43:32 +01:00
def log(text):
"""Print a nicely formatted line to stdout"""
2018-04-13 01:00:36 +02:00
print("\n>>> " + col(1) + text + col(0) + "\n")
2018-02-05 23:43:32 +01:00
2018-02-05 23:43:32 +01:00
def handleStatus(status):
"""Abort if a command fails"""
2018-02-08 01:11:47 +01:00
if (status != 0):
print(col(3) + "Error while running last command" + col(0))
2018-04-05 21:12:36 +02:00
sys.exit(1)
2018-02-05 23:43:32 +01:00
2018-04-05 21:46:11 +02:00
sc = subprocess.call
2018-04-05 21:46:11 +02:00
# We're not in fresh configuration mode so don't continue the setup
if not os.path.exists("/tmp/howdy_picked_device"):
# Check if we have an older config we can restore
if len(sys.argv) > 2:
if os.path.exists("/tmp/howdy_config_backup_v" + sys.argv[2] + ".ini"):
# Get the config parser
import configparser
# Load th old and new config files
oldConf = configparser.ConfigParser()
oldConf.read("/tmp/howdy_config_backup_v" + sys.argv[2] + ".ini")
newConf = configparser.ConfigParser()
newConf.read("/lib/security/howdy/config.ini")
# Go through every setting in the old config and apply it to the new file
for section in oldConf.sections():
for (key, value) in oldConf.items(section):
2018-12-09 12:47:29 +01:00
# MIGRATION 2.3.1 -> 2.4.0
# If config is still using the old device_id parameter, convert it to a path
2018-11-09 20:02:30 +01:00
if key == "device_id":
key = "device_path"
value = "/dev/video" + value
2018-12-09 12:47:29 +01:00
# MIGRATION 2.4.0 -> 2.5.0
# Finally correct typo in "timout" config value
if key == "timout":
key = "timeout"
try:
newConf.set(section, key, value)
# Add a new section where needed
except configparser.NoSectionError as e:
newConf.add_section(section)
newConf.set(section, key, value)
# Write it all to file
with open("/lib/security/howdy/config.ini", "w") as configfile:
newConf.write(configfile)
sys.exit(0)
2018-04-05 21:12:36 +02:00
# Open the temporary file containing the device ID
in_file = open("/tmp/howdy_picked_device", "r")
# Load it in, it should be a string
2018-04-12 23:45:52 +02:00
picked = in_file.read()
in_file.close()
2018-04-05 21:12:36 +02:00
# Remove the temporary file
os.unlink("/tmp/howdy_picked_device")
2018-04-05 21:12:36 +02:00
2018-04-12 23:45:52 +02:00
log("Upgrading pip to the latest version")
# Update pip
handleStatus(sc(["pip3", "install", "--upgrade", "pip"]))
dlib_archive = '/tmp/dlib_latest.tar.gz'
log('Downloading dlib')
loader = which('curl')
LOADER_CMD = None
if loader:
LOADER_CMD = [loader, '--silent', '--retry', '5', '--location', '--output']
else:
loader = which('wget')
LOADER_CMD = [loader, '--quiet', '--tries', '5', '--output-document']
2018-02-05 23:43:32 +01:00
cmd = LOADER_CMD + [dlib_archive, 'https://api.github.com/repos/davisking/dlib/tarball/latest']
handleStatus(sc(cmd))
DLIB_DIR = None
2018-02-05 23:43:32 +01:00
excludes = re.compile(
'davisking-dlib-\w+/(dlib/(http_client|java|matlab|test/)|'
'(docs|examples|python_examples)|'
'tools/(archive|convert_dlib_nets_to_caffe|htmlify|imglab|python/test|visual_studio_natvis))'
)
with tarfile.open(dlib_archive) as tf:
for item in tf:
# tarball contains directory davisking-dlib-<commit id>, so peek into archive for the name
if not DLIB_DIR:
DLIB_DIR = item.name
# extract only files sufficent for building
if not excludes.match(item.name):
tf.extract(item, '/tmp')
os.unlink(dlib_archive)
log("Building dlib")
# Start the build
cmd = ["python3", "setup.py", "install"]
flags = ''
with open('/proc/cpuinfo') as info:
for line in info:
if 'flags' in line:
flags = line
break
if 'avx' in flags:
cmd += ["--yes", "USE_AVX_INSTRUCTIONS"]
elif 'sse4' in flags:
cmd += ["--yes", "USE_SSE4_INSTRUCTIONS"]
elif 'sse3' in flags:
cmd += ["--yes", "USE_SSE3_INSTRUCTIONS"]
elif 'sse2' in flags:
cmd += ["--yes", "USE_SSE2_INSTRUCTIONS"]
sp = subprocess.run(cmd, cwd=DLIB_DIR, stderr=subprocess.STDOUT)
handleStatus(sp.returncode)
# simple check for CUDA
cuda_used = 'DLIB WILL USE CUDA' in sp.stdout
2018-04-12 23:45:52 +02:00
log("Cleaning up dlib")
2018-04-12 23:45:52 +02:00
# Remove the no longer needed git clone
del sp
rmtree(DLIB_DIR)
2018-02-05 23:43:32 +01:00
log("Temporary dlib files removed")
2018-02-05 23:43:32 +01:00
2018-04-07 19:15:00 +02:00
log("Configuring howdy")
2018-02-05 23:43:32 +01:00
# Manually change the camera id to the one picked
for line in fileinput.input(["/lib/security/howdy/config.ini"], inplace=1):
print(
line
.replace("device_path = none", "device_path = " + picked)
.replace("use_cnn = false", "use_cnn = " + str(cuda_used).lower()),
end=""
)
2018-11-09 16:33:19 +01:00
print("Camera ID saved")
2018-02-05 23:43:32 +01:00
2018-02-10 17:03:42 +01:00
# Secure the howdy folder
handleStatus(sc(["chmod 744 -R /lib/security/howdy/"], shell=True))
2018-02-10 17:03:42 +01:00
# Allow anyone to execute the python CLI
os.chmod('/lib/security/howdy', 0o755)
os.chmod('/lib/security/howdy/cli.py', 0o755)
handleStatus(sc(["chmod 755 -R /lib/security/howdy/cli"], shell=True))
2018-04-07 19:15:00 +02:00
print("Permissions set")
# Make the CLI executable as howdy
os.symlink("/lib/security/howdy/cli.py", "/usr/local/bin/howdy")
os.chmod("/usr/local/bin/howdy", 0o755)
print("Howdy command installed")
2018-02-10 17:03:42 +01:00
2018-02-05 23:43:32 +01:00
log("Adding howdy as PAM module")
# Activate the pam-config file
handleStatus(subprocess.call(["pam-auth-update --package"], shell=True))
2018-02-05 23:43:32 +01:00
# Sign off
2018-02-05 23:43:32 +01:00
print("Installation complete.")