#!/usr/bin/env python3 # -*- coding: utf-8 -*- # # === This file is part of Calamares - === # # Copyright 2014, Philip Müller # Copyright 2014, Teo Mrnjavac # Copyright 2017, Alf Gaida # Copyright 2018-2019, Adriaan de Groot # # Calamares is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # Calamares is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with Calamares. If not, see . import libcalamares import gettext _ = gettext.translation("calamares-python", localedir=libcalamares.utils.gettext_path(), languages=libcalamares.utils.gettext_languages(), fallback=True).gettext def pretty_name(): return _("Configure systemd services") def systemctl(targets, command, suffix): """ For each entry in @p targets, run "systemctl ", where is the entry's name plus the given @p suffix. (No dot is added between name and suffix; suffix may be empty) Returns a failure message, or None if this was successful. Services that are not mandatory have their failures suppressed silently. """ for svc in targets: if isinstance(svc, str): name = svc mandatory = False else: name = svc["name"] mandatory = svc.get("mandatory", False) ec = libcalamares.utils.target_env_call( ['systemctl', command, "{}{}".format(name, suffix)] ) if ec != 0: libcalamares.utils.warning( "Cannot {} systemd {} {}".format(command, suffix, name) ) libcalamares.utils.warning( "systemctl {} call in chroot returned error code {}".format(command, ec) ) if mandatory: title = _("Cannot modify service") diagnostic = _("systemctl {arg!s} call in chroot returned error code {num!s}.").format(arg=command, num=ec) if command == "enable" and suffix == ".service": description = _("Cannot enable systemd service {name!s}.") elif command == "enable" and suffix == ".target": description = _("Cannot enable systemd target {name!s}.") elif command == "disable" and suffix == ".service": description = _("Cannot enable systemd service {name!s}.") elif command == "disable" and suffix == ".target": description = _("Cannot disable systemd target {name!s}.") elif command == "mask": description = _("Cannot mask systemd unit {name!s}.") else: description = _("Unknown systemd commands {command!s} and {suffix!s} for unit {name!s}.") return (title, description.format(name=name, command=command, suffix=suffix) + " " + diagnostic ) return None def run(): """ Setup systemd services """ cfg = libcalamares.job.configuration # note that the "systemctl enable" and "systemctl disable" commands used # here will work in a chroot; in fact, they are the only systemctl commands # that support that, see: # http://0pointer.de/blog/projects/changing-roots.html r = systemctl(cfg.get("services", []), "enable", ".service") if r is not None: return r r = systemctl(cfg.get("targets", []), "enable", ".target") if r is not None: return r r = systemctl(cfg.get("disable", []), "disable", ".service") if r is not None: return r r = systemctl(cfg.get("disable-targets", []), "disable", ".target") if r is not None: return r r = systemctl(cfg.get("mask", []), "mask", "") if r is not None: return r return None