2021-02-14 05:38:20 +03:00
|
|
|
# Hosts
|
|
|
|
|
|
|
|
Nix flakes contain an output called `nixosConfigurations` declaring an
|
2021-04-27 20:26:45 +03:00
|
|
|
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 05:38:20 +03:00
|
|
|
|
2021-04-27 20:26:45 +03: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 05:38:20 +03:00
|
|
|
|
|
|
|
For each host, the configuration automatically sets the `networking.hostName`
|
2021-04-27 20:26:45 +03:00
|
|
|
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 05:38:20 +03: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 05:26:27 +03:00
|
|
|
is best saved for [profile modules](./profiles.md).
|
2021-02-14 05:38:20 +03:00
|
|
|
|
2021-04-19 05:26:27 +03:00
|
|
|
This is a good place to import sets of profiles, called [suites](./suites.md),
|
2021-02-14 05:38:20 +03:00
|
|
|
that you intend to use on your machine.
|
|
|
|
|
2021-03-16 05:04:28 +03:00
|
|
|
|
2021-02-14 05:38:20 +03:00
|
|
|
## Example
|
|
|
|
|
2021-04-27 20:26:45 +03:00
|
|
|
flake.nix:
|
|
|
|
```nix
|
|
|
|
{
|
2021-05-18 20:23:43 +03:00
|
|
|
nixos = {
|
|
|
|
imports = [ (devos.lib.importHosts ./hosts) ];
|
|
|
|
hosts = {
|
2021-04-27 20:26:45 +03:00
|
|
|
librem = {
|
|
|
|
channelName = "latest";
|
2021-05-18 19:11:29 +03:00
|
|
|
modules = [ nixos-hardware.nixosModules.purism-librem-13v3 ];
|
2021-04-27 20:26:45 +03:00
|
|
|
};
|
2021-05-18 20:23:43 +03:00
|
|
|
};
|
|
|
|
};
|
2021-04-27 20:26:45 +03:00
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2021-02-15 03:41:15 +03:00
|
|
|
hosts/librem.nix:
|
2021-02-14 05:38:20 +03:00
|
|
|
```nix
|
2021-04-27 20:26:45 +03:00
|
|
|
{ suites, ... }:
|
2021-02-14 05:38:20 +03:00
|
|
|
{
|
2021-04-27 20:26:45 +03:00
|
|
|
imports = suites.laptop;
|
2021-02-14 05:38:20 +03: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
|