feat(nixos): add machine module with virtualisation and usb options
This commit is contained in:
parent
e097d3e688
commit
3bffa8760e
5 changed files with 81 additions and 54 deletions
|
@ -1,16 +0,0 @@
|
|||
{ lib, ... }:
|
||||
let
|
||||
inherit (lib.options) mkEnableOption;
|
||||
in
|
||||
{
|
||||
flake.modules.nixos.default = {
|
||||
options.bluetooth.enable = mkEnableOption "";
|
||||
config = {
|
||||
persistDirs = [ "/var/lib/bluetooth" ];
|
||||
hardware.bluetooth = {
|
||||
enable = true;
|
||||
settings.General.Experimental = true;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
37
nix/modules/options/machine/default.nix
Normal file
37
nix/modules/options/machine/default.nix
Normal file
|
@ -0,0 +1,37 @@
|
|||
{ lib, ... }:
|
||||
let
|
||||
inherit (lib.options) mkEnableOption;
|
||||
inherit (lib.modules) mkIf mkMerge;
|
||||
in
|
||||
{
|
||||
flake.modules.nixos.default =
|
||||
{ config, ... }:
|
||||
let
|
||||
cfg = config.machine;
|
||||
in
|
||||
{
|
||||
options.machine.bluetooth.enable = mkEnableOption "";
|
||||
options.machine.usb.automount = mkEnableOption "";
|
||||
config = mkMerge [
|
||||
(mkIf cfg.usb.automount {
|
||||
services.udisks2.enable = true;
|
||||
home-manager.sharedModules = [
|
||||
{
|
||||
services.udiskie = {
|
||||
enable = true;
|
||||
automount = true;
|
||||
notify = true;
|
||||
};
|
||||
}
|
||||
];
|
||||
})
|
||||
(mkIf cfg.bluetooth.enable {
|
||||
persistDirs = [ "/var/lib/bluetooth" ];
|
||||
hardware.bluetooth = {
|
||||
enable = true;
|
||||
settings.General.Experimental = true;
|
||||
};
|
||||
})
|
||||
];
|
||||
};
|
||||
}
|
36
nix/modules/options/machine/virtualisation.nix
Normal file
36
nix/modules/options/machine/virtualisation.nix
Normal file
|
@ -0,0 +1,36 @@
|
|||
{ lib, config, ... }:
|
||||
let
|
||||
inherit (lib.modules) mkIf;
|
||||
inherit (lib.options) mkEnableOption;
|
||||
inherit (lib.lists) optional;
|
||||
inherit (config.flake.lib.modules) forAllUsers;
|
||||
in
|
||||
{
|
||||
flake.modules.nixos.default =
|
||||
{ pkgs, config, ... }:
|
||||
let
|
||||
cfg = config.machine.virtualisation;
|
||||
in
|
||||
{
|
||||
options.machine.virtualisation = {
|
||||
podman.enable = mkEnableOption "";
|
||||
podman.distrobox.enable = mkEnableOption "";
|
||||
};
|
||||
config = mkIf cfg.podman.enable {
|
||||
virtualisation.containers.enable = true;
|
||||
virtualisation.podman = {
|
||||
enable = true;
|
||||
dockerCompat = true;
|
||||
defaultNetwork.settings.dns_enabled = true;
|
||||
};
|
||||
users.users = forAllUsers {
|
||||
extraGroups = [ "podman" ];
|
||||
autoSubUidGidRange = cfg.podman.distrobox.enable;
|
||||
};
|
||||
home-manager.sharedModules = optional cfg.podman.distrobox.enable {
|
||||
home.packages = [ pkgs.distrobox ];
|
||||
persistDirs = [ ".local/share/containers" ];
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
|
@ -1,37 +0,0 @@
|
|||
{ lib, config, ... }:
|
||||
let
|
||||
inherit (lib.modules) mkIf;
|
||||
inherit (lib.options) mkEnableOption;
|
||||
inherit (cfg.lib.modules) forAllUsers;
|
||||
cfg = config.flake;
|
||||
in
|
||||
{
|
||||
flake.modules.nixos.default =
|
||||
{ pkgs, config, ... }:
|
||||
{
|
||||
options = {
|
||||
podman.enable = mkEnableOption "";
|
||||
podman.distrobox.enable = mkEnableOption "";
|
||||
};
|
||||
config = mkIf config.podman.enable {
|
||||
virtualisation = {
|
||||
containers.enable = true;
|
||||
podman = {
|
||||
enable = true;
|
||||
dockerCompat = true;
|
||||
defaultNetwork.settings.dns_enabled = true;
|
||||
};
|
||||
};
|
||||
users.users = forAllUsers {
|
||||
extraGroups = [ "podman" ];
|
||||
autoSubUidGidRange = true;
|
||||
};
|
||||
home-manager.sharedModules = [
|
||||
{
|
||||
home.packages = [ pkgs.distrobox ];
|
||||
persistDirs = [ ".local/share/containers" ];
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue