{ config, lib, pkgs, sloth, ... }: let envSuffix = envKey: suffix: sloth.concat' (sloth.env envKey) suffix; in { config = { dbus.policies = { "${config.flatpak.appId}" = "own"; "${config.flatpak.appId}.*" = "own"; "org.freedesktop.DBus" = "talk"; "org.gtk.vfs.*" = "talk"; "org.gtk.vfs" = "talk"; "ca.desrt.dconf" = "talk"; "org.freedesktop.portal.*" = "talk"; "org.a11y.Bus" = "talk"; }; gpu.enable = lib.mkDefault true; gpu.provider = "bundle"; fonts.enable = true; locale.enable = true; bubblewrap = { network = lib.mkDefault false; bind.rw = [ (sloth.concat' sloth.xdgCacheHome "/fontconfig") (sloth.concat' sloth.xdgCacheHome "/mesa_shader_cache") (sloth.concat [ (sloth.env "XDG_RUNTIME_DIR") "/" (sloth.env "WAYLAND_DISPLAY") ]) (envSuffix "XDG_RUNTIME_DIR" "/at-spi/bus") (envSuffix "XDG_RUNTIME_DIR" "/gvfsd") (envSuffix "XDG_RUNTIME_DIR" "/pulse") (envSuffix "XDG_RUNTIME_DIR" "/doc") (envSuffix "XDG_RUNTIME_DIR" "/dconf") ]; bind.ro = [ (sloth.concat' sloth.xdgConfigHome "/gtk-2.0") (sloth.concat' sloth.xdgConfigHome "/gtk-3.0") (sloth.concat' sloth.xdgConfigHome "/gtk-4.0") (sloth.concat' sloth.xdgConfigHome "/dconf") "/etc/localtime" ]; env = { XDG_DATA_DIRS = lib.makeSearchPath "share" [ pkgs.gnome.adwaita-icon-theme pkgs.gnome-themes-extra pkgs.shared-mime-info ]; XCURSOR_PATH = lib.concatStringsSep ":" [ "${pkgs.gnome.adwaita-icon-theme}/share/icons" "${pkgs.gnome.adwaita-icon-theme}/share/pixmaps" ]; }; }; }; }