improve install/uninstall routines
This commit is contained in:
@@ -14,15 +14,96 @@
|
|||||||
# along with pyinotifyd. If not, see <http://www.gnu.org/licenses/>.
|
# along with pyinotifyd. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
|
import filecmp
|
||||||
import logging
|
import logging
|
||||||
import os
|
import os
|
||||||
import shutil
|
import shutil
|
||||||
import sys
|
import sys
|
||||||
|
|
||||||
|
|
||||||
SYSTEMD_PATH = "/lib/systemd/system"
|
SYSTEMD_PATH = "/lib/systemd/system"
|
||||||
OPENRC = "/sbin/openrc"
|
OPENRC = "/sbin/openrc"
|
||||||
|
|
||||||
|
|
||||||
|
def _systemd_files(pkg_dir, name):
|
||||||
|
return [
|
||||||
|
(f"{pkg_dir}/misc/systemd/{name}.service",
|
||||||
|
f"{SYSTEMD_PATH}/{name}.service", True)]
|
||||||
|
|
||||||
|
|
||||||
|
def _openrc_files(pkg_dir, name):
|
||||||
|
return [
|
||||||
|
(f"{pkg_dir}/misc/openrc/{name}.initd", f"/etc/init.d/{name}", True),
|
||||||
|
(f"{pkg_dir}/misc/openrc/{name}.confd", f"/etc/conf.d/{name}", False)]
|
||||||
|
|
||||||
|
|
||||||
|
def _config_files(pkg_dir, name):
|
||||||
|
return [
|
||||||
|
(f"{pkg_dir}/misc/config.py.default", f"/etc/{name}/config.py", False)]
|
||||||
|
|
||||||
|
|
||||||
|
def _install_files(files):
|
||||||
|
for src, dst, force in files:
|
||||||
|
if os.path.exists(dst):
|
||||||
|
if os.path.isdir(dst):
|
||||||
|
logging.error(
|
||||||
|
" => unable to copy file, destination path is a directory")
|
||||||
|
continue
|
||||||
|
elif not force:
|
||||||
|
logging.info(f" => file {dst} already exists")
|
||||||
|
continue
|
||||||
|
|
||||||
|
try:
|
||||||
|
logging.info(f" => install file {dst}")
|
||||||
|
shutil.copy2(src, dst)
|
||||||
|
except Exception as e:
|
||||||
|
logging.error(f" => unable to install file {dst}: {e}")
|
||||||
|
|
||||||
|
|
||||||
|
def _uninstall_files(files):
|
||||||
|
for src, dst, force in files:
|
||||||
|
if not os.path.isfile(dst):
|
||||||
|
continue
|
||||||
|
|
||||||
|
if not force and not filecmp.cmp(src, dst, shallow=True):
|
||||||
|
logging.warning(
|
||||||
|
f" => keep modified file {dst}, "
|
||||||
|
f"you have to remove it manually")
|
||||||
|
continue
|
||||||
|
|
||||||
|
try:
|
||||||
|
logging.info(f" => uninstall file {dst}")
|
||||||
|
os.remove(dst)
|
||||||
|
except Exception as e:
|
||||||
|
logging.error(f" => unable to uninstall file {dst}: {e}")
|
||||||
|
|
||||||
|
|
||||||
|
def _create_dir(path):
|
||||||
|
if os.path.isdir(path):
|
||||||
|
logging.info(f" => directory {path} already exists")
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
logging.info(f" => create directory {path}")
|
||||||
|
os.mkdir(path)
|
||||||
|
except Exception as e:
|
||||||
|
logging.error(f" => unable to create directory {path}: {e}")
|
||||||
|
return False
|
||||||
|
|
||||||
|
return True
|
||||||
|
|
||||||
|
|
||||||
|
def _delete_dir(path):
|
||||||
|
if os.path.isdir(path):
|
||||||
|
if not os.listdir(path):
|
||||||
|
try:
|
||||||
|
logging.info(f" => delete directory {path}")
|
||||||
|
os.rmdir(path)
|
||||||
|
except Exception as e:
|
||||||
|
logging.error(f" => unable to delete directory {path}: {e}")
|
||||||
|
else:
|
||||||
|
logging.warning(f" => keep non-empty directory {path}")
|
||||||
|
|
||||||
|
|
||||||
def _check_root():
|
def _check_root():
|
||||||
if os.getuid() != 0:
|
if os.getuid() != 0:
|
||||||
logging.error("you need to have root privileges, please try again")
|
logging.error("you need to have root privileges, please try again")
|
||||||
@@ -47,37 +128,6 @@ def _check_openrc():
|
|||||||
return openrc
|
return openrc
|
||||||
|
|
||||||
|
|
||||||
def _copy_missing_file(src, dst):
|
|
||||||
if os.path.exists(dst):
|
|
||||||
logging.info(f" => file {dst} already installed")
|
|
||||||
else:
|
|
||||||
try:
|
|
||||||
logging.info(f" => install file {dst}")
|
|
||||||
shutil.copy2(src, dst)
|
|
||||||
except Exception as e:
|
|
||||||
logging.error(f" => unable to install file {dst}: {e}")
|
|
||||||
|
|
||||||
|
|
||||||
def _delete_present_file(f):
|
|
||||||
if os.path.isfile(f):
|
|
||||||
try:
|
|
||||||
logging.info(f" => uninstall file {f}")
|
|
||||||
os.remove(f)
|
|
||||||
except Exception as e:
|
|
||||||
logging.error(f" => unable to uninstall file {f}: {e}")
|
|
||||||
|
|
||||||
|
|
||||||
def _warn_exists(path):
|
|
||||||
if os.path.isdir(path):
|
|
||||||
logging.warning(
|
|
||||||
f" => directory {path} is still present, "
|
|
||||||
f"you have to remove it manually")
|
|
||||||
else:
|
|
||||||
logging.warning(
|
|
||||||
f" => file {path} is still present, "
|
|
||||||
f"you have to remove it manually")
|
|
||||||
|
|
||||||
|
|
||||||
def install(name):
|
def install(name):
|
||||||
if not _check_root():
|
if not _check_root():
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
@@ -85,33 +135,16 @@ def install(name):
|
|||||||
pkg_dir = os.path.dirname(__file__)
|
pkg_dir = os.path.dirname(__file__)
|
||||||
|
|
||||||
if _check_systemd():
|
if _check_systemd():
|
||||||
dst = f"{SYSTEMD_PATH}/{name}.service"
|
_install_files(_systemd_files(pkg_dir, name))
|
||||||
src = f"{pkg_dir}/misc/systemd/{name}.service"
|
|
||||||
_copy_missing_file(src, dst)
|
|
||||||
|
|
||||||
if _check_openrc():
|
if _check_openrc():
|
||||||
files = [
|
_install_files(_openrc_files(pkg_dir, name))
|
||||||
(f"{pkg_dir}/misc/openrc/{name}.initd", f"/etc/init.d/{name}"),
|
|
||||||
(f"{pkg_dir}/misc/openrc/{name}.confd", f"/etc/conf.d/{name}")]
|
|
||||||
for src, dst in files:
|
|
||||||
_copy_missing_file(src, dst)
|
|
||||||
|
|
||||||
logging.info("install configuration file")
|
if not _create_dir(f"/etc/{name}"):
|
||||||
config_dir = f"/etc/{name}"
|
logging.error(" => unable to create config dir, giving up ...")
|
||||||
if os.path.isdir(config_dir):
|
|
||||||
logging.info(f" => directory {config_dir} already exists")
|
|
||||||
else:
|
|
||||||
try:
|
|
||||||
logging.info(f" => create directory {config_dir}")
|
|
||||||
os.mkdir(config_dir)
|
|
||||||
except Exception as e:
|
|
||||||
logging.error(f" => unable to create directory {config_dir}: {e}")
|
|
||||||
sys.exit(3)
|
sys.exit(3)
|
||||||
|
|
||||||
files = [
|
_install_files(_config_files(pkg_dir, name))
|
||||||
(f"{pkg_dir}/misc/config.py.default", f"{config_dir}/config.py")]
|
|
||||||
for src, dst in files:
|
|
||||||
_copy_missing_file(src, dst)
|
|
||||||
|
|
||||||
logging.info(f"{name} successfully installed")
|
logging.info(f"{name} successfully installed")
|
||||||
|
|
||||||
@@ -120,13 +153,16 @@ def uninstall(name):
|
|||||||
if not _check_root():
|
if not _check_root():
|
||||||
sys.exit(2)
|
sys.exit(2)
|
||||||
|
|
||||||
|
pkg_dir = os.path.dirname(__file__)
|
||||||
|
|
||||||
if _check_systemd():
|
if _check_systemd():
|
||||||
_delete_present_file(f"{SYSTEMD_PATH}/{name}.service")
|
_uninstall_files(_systemd_files(pkg_dir, name))
|
||||||
|
|
||||||
if _check_openrc():
|
if _check_openrc():
|
||||||
_delete_present_file(f"/etc/init.d/{name}")
|
_uninstall_files(_openrc_files(pkg_dir, name))
|
||||||
_warn_exists(f"/etc/conf.d/{name}")
|
|
||||||
|
|
||||||
_warn_exists(f"/etc/{name}")
|
_uninstall_files(_config_files(pkg_dir, name))
|
||||||
|
|
||||||
|
_delete_dir(f"/etc/{name}")
|
||||||
|
|
||||||
logging.info(f"{name} successfully uninstalled")
|
logging.info(f"{name} successfully uninstalled")
|
||||||
|
|||||||
Reference in New Issue
Block a user