devos/doc/concepts/hosts.md

62 lines
2 KiB
Markdown
Raw Normal View History

2021-02-14 03:38:20 +01:00
# Hosts
Nix flakes contain an output called `nixosConfigurations` declaring an
attribute set of valid NixOS systems. To simplify the management and creation
of these hosts, devos automatically imports every _.nix_ file inside this
directory to the mentioned attribute set, applying the projects defaults to
each. The only hard requirement is that the file contain a valid NixOS module.
2021-02-14 03:38:20 +01:00
As an example, a file `hosts/system.nix` will be available via the flake
output `nixosConfigurations.system`. You can have as many hosts as you want
and all of them will be automatically imported based on their name.
2021-02-14 03:38:20 +01:00
For each host, the configuration automatically sets the `networking.hostName`
attribute to the name of the file minus the _.nix_ extension. This is for
convenience, since `nixos-rebuild` automatically searches for a configuration
matching the current systems hostname if one is not specified explicitly.
You can set channels, systems, and add extra modules to each host by editing the
`nixos.hosts` argument in flake.nix. This is the perfect place to import
host specific modules from external sources, such as the
[nixos-hardware][nixos-hardware] repository.
2021-02-14 03:38:20 +01:00
It is recommended that the host modules only contain configuration information
specific to a particular piece of hardware. Anything reusable across machines
2021-04-19 04:26:27 +02:00
is best saved for [profile modules](./profiles.md).
2021-02-14 03:38:20 +01:00
2021-04-19 04:26:27 +02:00
This is a good place to import sets of profiles, called [suites](./suites.md),
2021-02-14 03:38:20 +01:00
that you intend to use on your machine.
2021-02-14 03:38:20 +01:00
## Example
flake.nix:
```nix
{
nixos.hosts = mkMerge [
(devos.lib.importHosts ./hosts)
{
librem = {
channelName = "latest";
modules = [ nixos-hardware.nixosModules.purism-librem-13v3 ];
};
}
];
}
```
2021-02-15 01:41:15 +01:00
hosts/librem.nix:
2021-02-14 03:38:20 +01:00
```nix
{ suites, ... }:
2021-02-14 03:38:20 +01:00
{
imports = suites.laptop;
2021-02-14 03:38:20 +01:00
boot.loader.systemd-boot.enable = true;
boot.loader.efi.canTouchEfiVariables = true;
fileSystems."/" = { device = "/dev/disk/by-label/nixos"; };
}
```
[nixos-hardware]: https://github.com/NixOS/nixos-hardware