Skip to content

Commit

Permalink
docs: add 'System management with nix flakes' guide
Browse files Browse the repository at this point in the history
  • Loading branch information
woile committed Jul 22, 2023
1 parent 971ea3d commit 9441082
Show file tree
Hide file tree
Showing 3 changed files with 149 additions and 3 deletions.
19 changes: 16 additions & 3 deletions flake.nix
Original file line number Diff line number Diff line change
Expand Up @@ -209,7 +209,7 @@
getModules = f: [ f.flakeModules.flakeModules ];
intro = ''
Adds the `flakeModules` attribute and `flakeModule` alias.
This module makes deduplication and `disabledModules` work, even if the definitions are inline modules or [`importApply`](../define-module-in-separate-file.html#importapply).
'';
installationDeclareInput = false;
Expand Down Expand Up @@ -286,6 +286,19 @@
'';
};

nixos-flake = {
title = "nix-cargo-integration";
baseUrl = "https://github.com/srid/nixos-flake/blob/master";
intro = ''
A flake-parts module to manage NixOS and macOS machines, along with home-manager support, in a unified fashion
'';
installation = ''
## Installation
See the [documentation](https://zero-to-flakes.com/nixos-flake).
'';
};

pre-commit-hooks-nix = {
baseUrl = "https://github.com/cachix/pre-commit-hooks.nix/blob/master";
intro = ''
Expand Down Expand Up @@ -326,7 +339,7 @@
Add definitions from the [Standard](https://github.com/divnix/std#readme) DevOps framework to your flake.
It organizes and disciplines your Nix and thereby speeds you up.
It also comes with great horizontal integrations of high quality
It also comes with great horizontal integrations of high quality
vertical DevOps tooling crafted by the Nix Ecosystem.
'';
};
Expand All @@ -341,7 +354,7 @@
- Cache which files have changed for super fast re-formatting.
- Just type treefmt in any folder and it reformats the whole code tree.
This module is defined in [`numtide/treefmt-nix`](https://github.com/numtide/treefmt-nix). The `treefmt` repo is about the [tool](https://github.com/numtide/treefmt) itself.
This module is defined in [`numtide/treefmt-nix`](https://github.com/numtide/treefmt-nix). The `treefmt` repo is about the [tool](https://github.com/numtide/treefmt) itself.
'';
};

Expand Down
1 change: 1 addition & 0 deletions site/src/SUMMARY.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
- [Define a Module in a Separate File](./define-module-in-separate-file.md)
- [Define Custom Flake Attribute](./define-custom-flake-attribute.md)
- [Dogfood a Reusable Flake Module](./dogfood-a-reusable-module.md)
- [System management with nix flakes](./nixos-flake.md)
- [Explanation]()
- [Overlays](./overlays.md)
- [Reference Documentation]()
Expand Down
132 changes: 132 additions & 0 deletions site/src/nixos-flake.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
# System management with nix flakes

If your goal is to control your machine using [nix flakes](https://nixos.wiki/wiki/Flakes), this guide is for you.

Machines come in different flavors, you may already be using nixos, another linux distribution or mac (with arm or intel architecture). You can manage them all using "the flake way".

Be sure to have nix installed in your system.

Let's start!

## Terminology

- `host`: a machine, like a desktop computer, a laptop or a server in the cloud
- `hostname`: name given to the machine, use `hostname -s` to retrieve it in unix systems
- `templates`: in this context they refer to nix templates

## Getting started

All of our configurations will be conveniently housed within a `nixos-config` folder, irrespective of the underlying system being used.

No matter the system used, we are gonna create a folder that will contain all the configurations for the host system. You have the option to back up the project on a Git platform such as GitHub, GitLab, Gittea, and others. Additionally, you can easily extend it to multiple hosts if needed.

If you publish your configuration to github, please add the label `flake-parts-nixos-flake` to make it easier to find.

Let's begin

```sh
mkdir ~/nixos-config
cd ~/nixos-config
```

And we are going to initialize the fantastic [nixos-flake](https://github.com/srid/nixos-flake) which uses itself flakes-parts.

```sh
nix flake init -t github:srid/nixos-flake
```

This will initialize a flake with support for nixos, nix-darwin and home-manager combined.

If you'd rather initialize only a macos, or another linux distribution, check the [nixos-flake docs](https://zero-to-flakes.com/nixos-flake/templates).

## Configuring different systems

### On nixos

Your nix configuration should be on `/etc/nixos`, you should have something like:

```console
$ ls /etc/nixos
configuration.nix hardware-configuration.nix
```

Let's copy the existing system there.

```sh
TARGET="~/nixos-config/hosts/$(hostname -s)"
mkdir -p "$TARGET"
cp -r /etc/nixos "$TARGET"
```

Now it's time for you to dig into the `flake.nix`, update the `TODO`s with your `username` and `hostname`, and
finally, import the configurations that we previously copied.

The last step is to activate the flake:

```sh
nix run .#activate
```

### On other linux distributions

If you are using a non-nixos linux distribution, you probably should use the `home` template (you can add other systems later). And you'll use nix as a replacement for your dotfiles, with the advantage of having a declarative language, with declarative aliases, packages from nixpkgs and many more configurations.

```sh
nix flake init -t github:srid/nixos-flake#home
```

Configure at will.

And finally, activate it:

```sh
nix run .#activate-home
```

### On Mac

If you are on an Intel Mac, change `mkARMMacosSystem` to `mkIntelMacosSystem` and run

```sh
nix run .#activate
```

## Folder structure

You can use this set up as a starting point for a multi-machine and multi-user configuration for your fleet of machines.

```sh
nixos-config/
├── hardware/
│   ├── sd-image/
│   └── dell-xps13.nix # example of a specific hardware
├── home/
│   └── default.nix # shared home config
├── hosts/
├── nix-darwin/
│   └── default.nix
├── nixos/
│   └── default.nix
├── users/
│   ├── config.nix
│   └── default.nix
├── flake.lock
└── flake.nix
```

inside the `hosts` you'd create a "host" combining a user + home + nixos* + nix-darwin* + hardware\*

\* optional, depends on your needs

## Getting help

For questions related to flake-parts head to the [flake-parts discussions](https://github.com/hercules-ci/flake-parts/discussions) on github.

For questions related to nixos-flake head to the [nixos-flake discussions](https://github.com/srid/nixos-flake/discussions) on github.


## Resources

- https://github.com/srid/nixos-config
- https://github.com/lovesegfault/nix-config
- https://nixos-and-flakes.thiscute.world/nixos-with-flakes/modularize-the-configuration

0 comments on commit 9441082

Please sign in to comment.