nixpkgs/nixos/modules/services/system/dbus.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

192 lines
5.0 KiB
Nix
Raw Normal View History

# D-Bus configuration and system bus daemon.
{ config, lib, pkgs, ... }:
let
cfg = config.services.dbus;
homeDir = "/run/dbus";
2017-02-16 11:56:45 +00:00
configDir = pkgs.makeDBusConf {
2020-11-02 21:42:55 +00:00
inherit (cfg) apparmor;
2017-02-16 11:56:45 +00:00
suidHelper = "${config.security.wrapperDir}/dbus-daemon-launch-helper";
serviceDirectories = cfg.packages;
};
2021-02-12 09:36:23 +00:00
inherit (lib) mkOption mkIf mkMerge types;
in
{
options = {
services.dbus = {
enable = mkOption {
type = types.bool;
default = false;
internal = true;
description = lib.mdDoc ''
Whether to start the D-Bus message bus daemon, which is
required by many other system services and applications.
'';
};
2021-02-12 09:36:23 +00:00
implementation = mkOption {
type = types.enum [ "dbus" "broker" ];
default = "dbus";
description = lib.mdDoc ''
The implementation to use for the message bus defined by the D-Bus specification.
Can be either the classic dbus daemon or dbus-broker, which aims to provide high
performance and reliability, while keeping compatibility to the D-Bus
reference implementation.
'';
};
packages = mkOption {
2013-10-30 16:37:45 +00:00
type = types.listOf types.path;
default = [ ];
description = lib.mdDoc ''
Packages whose D-Bus configuration files should be included in
the configuration of the D-Bus system-wide or session-wide
message bus. Specifically, files in the following directories
will be included into their respective DBus configuration paths:
{file}`«pkg»/etc/dbus-1/system.d`
{file}`«pkg»/share/dbus-1/system.d`
{file}`«pkg»/share/dbus-1/system-services`
{file}`«pkg»/etc/dbus-1/session.d`
{file}`«pkg»/share/dbus-1/session.d`
{file}`«pkg»/share/dbus-1/services`
'';
};
2020-11-02 21:42:55 +00:00
apparmor = mkOption {
type = types.enum [ "enabled" "disabled" "required" ];
description = lib.mdDoc ''
2020-11-02 21:42:55 +00:00
AppArmor mode for dbus.
`enabled` enables mediation when it's
supported in the kernel, `disabled`
2020-11-02 21:42:55 +00:00
always disables AppArmor even with kernel support, and
`required` fails when AppArmor was not found
2020-11-02 21:42:55 +00:00
in the kernel.
'';
default = "disabled";
};
};
};
2021-02-12 09:36:23 +00:00
config = mkIf cfg.enable (mkMerge [
{
environment.etc."dbus-1".source = configDir;
2021-02-12 09:36:23 +00:00
environment.pathsToLink = [
"/etc/dbus-1"
"/share/dbus-1"
];
2021-02-12 09:36:23 +00:00
users.users.messagebus = {
uid = config.ids.uids.messagebus;
description = "D-Bus system message bus daemon user";
home = homeDir;
group = "messagebus";
};
2021-02-12 09:36:23 +00:00
users.groups.messagebus.gid = config.ids.gids.messagebus;
2021-02-12 09:36:23 +00:00
# You still need the dbus reference implementation installed to use dbus-broker
systemd.packages = [
pkgs.dbus
];
2021-02-12 09:36:23 +00:00
services.dbus.packages = [
pkgs.dbus
config.system.path
];
2021-02-12 09:36:23 +00:00
systemd.user.sockets.dbus.wantedBy = [
"sockets.target"
];
}
2021-02-12 09:36:23 +00:00
(mkIf (cfg.implementation == "dbus") {
environment.systemPackages = [
pkgs.dbus
];
2021-02-12 09:36:23 +00:00
security.wrappers.dbus-daemon-launch-helper = {
source = "${pkgs.dbus}/libexec/dbus-daemon-launch-helper";
owner = "root";
group = "messagebus";
setuid = true;
setgid = false;
permissions = "u+rx,g+rx,o-rx";
};
systemd.services.dbus = {
# Don't restart dbus-daemon. Bad things tend to happen if we do.
reloadIfChanged = true;
restartTriggers = [
configDir
];
environment = {
LD_LIBRARY_PATH = config.system.nssModules.path;
};
};
2021-02-12 09:36:23 +00:00
systemd.user.services.dbus = {
# Don't restart dbus-daemon. Bad things tend to happen if we do.
reloadIfChanged = true;
restartTriggers = [
configDir
];
};
})
(mkIf (cfg.implementation == "broker") {
environment.systemPackages = [
pkgs.dbus-broker
];
2021-02-12 09:36:23 +00:00
systemd.packages = [
pkgs.dbus-broker
];
2021-02-12 09:36:23 +00:00
# Just to be sure we don't restart through the unit alias
systemd.services.dbus.reloadIfChanged = true;
systemd.user.services.dbus.reloadIfChanged = true;
# NixOS Systemd Module doesn't respect 'Install'
# https://github.com/NixOS/nixpkgs/issues/108643
systemd.services.dbus-broker = {
aliases = [
"dbus.service"
];
# Don't restart dbus. Bad things tend to happen if we do.
reloadIfChanged = true;
restartTriggers = [
configDir
];
environment = {
LD_LIBRARY_PATH = config.system.nssModules.path;
};
};
systemd.user.services.dbus-broker = {
aliases = [
"dbus.service"
];
# Don't restart dbus. Bad things tend to happen if we do.
reloadIfChanged = true;
restartTriggers = [
configDir
];
};
})
]);
}