2017-01-14 13:04:57 +01:00
|
|
|
Home Manager using Nix
|
|
|
|
======================
|
|
|
|
|
|
|
|
This project provides a basic system for managing a user environment
|
|
|
|
using the [Nix][] package manager together with the Nix libraries
|
2021-01-10 22:47:08 +01:00
|
|
|
found in [Nixpkgs][]. It allows declarative configuration of user
|
2021-01-08 15:26:58 +01:00
|
|
|
specific (non global) packages and dotfiles.
|
|
|
|
|
|
|
|
Before attempting to use Home Manager please read the warning below.
|
2017-01-14 13:04:57 +01:00
|
|
|
|
2020-03-01 17:06:18 +01:00
|
|
|
For a more systematic overview of Home Manager and its available
|
|
|
|
options, please see the [Home Manager manual][manual].
|
2020-01-19 16:44:38 +01:00
|
|
|
|
2017-01-14 13:04:57 +01:00
|
|
|
Words of warning
|
|
|
|
----------------
|
|
|
|
|
2021-01-09 10:04:44 +01:00
|
|
|
Unfortunately, it is quite possible to get difficult to understand
|
|
|
|
errors when working with Home Manager, such as infinite loops with no
|
|
|
|
clear source reference. You should therefore be comfortable using the
|
|
|
|
Nix language and the various tools in the Nix ecosystem. Reading
|
|
|
|
through the [Nix Pills][] document is a good way to familiarize
|
|
|
|
yourself with them.
|
2017-01-14 13:04:57 +01:00
|
|
|
|
2021-01-09 10:04:44 +01:00
|
|
|
If you are not very familiar with Nix but still want to use Home
|
|
|
|
Manager then you are strongly encouraged to start with a small and
|
|
|
|
very simple configuration and gradually make it more elaborate as you
|
|
|
|
learn.
|
2020-06-25 00:10:08 +02:00
|
|
|
|
2017-05-06 00:44:00 +02:00
|
|
|
In some cases Home Manager cannot detect whether it will overwrite a
|
|
|
|
previous manual configuration. For example, the Gnome Terminal module
|
|
|
|
will write to your dconf store and cannot tell whether a configuration
|
2021-04-08 17:11:39 +02:00
|
|
|
that it is about to be overwritten was from a previous Home Manager
|
2017-05-06 00:44:00 +02:00
|
|
|
generation or from manual configuration.
|
2017-01-14 13:04:57 +01:00
|
|
|
|
2021-06-05 19:52:10 +02:00
|
|
|
Home Manager targets [NixOS][] unstable and NixOS version 21.05 (the
|
2017-06-15 18:11:49 +02:00
|
|
|
current stable version), it may or may not work on other Linux
|
|
|
|
distributions and NixOS versions.
|
2017-04-01 23:05:36 +02:00
|
|
|
|
2017-05-06 00:44:00 +02:00
|
|
|
Also, the `home-manager` tool does not explicitly support rollbacks at
|
|
|
|
the moment so if your home directory gets messed up you'll have to fix
|
2018-01-27 10:17:42 +01:00
|
|
|
it yourself. See the [rollbacks](#rollbacks) section for instructions
|
|
|
|
on how to manually perform a rollback.
|
2017-01-14 13:04:57 +01:00
|
|
|
|
|
|
|
Now when your expectations have been built up and you are eager to try
|
|
|
|
all this out you can go ahead and read the rest of this text.
|
|
|
|
|
2019-03-22 19:10:43 +01:00
|
|
|
Contact
|
|
|
|
-------
|
|
|
|
|
2019-03-23 23:20:22 +01:00
|
|
|
You can chat with us on IRC in the channel [#home-manager][] on
|
2021-05-29 20:22:40 +02:00
|
|
|
[OFTC][].
|
2019-03-22 19:10:43 +01:00
|
|
|
|
2017-01-14 13:04:57 +01:00
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
|
|
|
Currently the easiest way to install Home Manager is as follows:
|
|
|
|
|
2020-05-16 18:09:09 +02:00
|
|
|
1. Make sure you have a working Nix installation. Specifically, make
|
|
|
|
sure that your user is able to build and install Nix packages. For
|
|
|
|
example, you should be able to successfully run a command like
|
|
|
|
`nix-instantiate '<nixpkgs>' -A hello` without having to switch to
|
|
|
|
the root user. For a multi-user install of Nix this means that
|
|
|
|
your user must be covered by the
|
2018-09-15 13:27:21 +02:00
|
|
|
[`allowed-users`][nixAllowedUsers] Nix option. On NixOS you can
|
|
|
|
control this option using the
|
2017-11-05 22:24:42 +01:00
|
|
|
[`nix.allowedUsers`][nixosAllowedUsers] system option.
|
|
|
|
|
2021-11-14 23:10:46 +01:00
|
|
|
Note that Nix 2.4 is not yet fully supported. Most significantly,
|
|
|
|
Home Manager is incompatible with the new `nix profile` command.
|
2020-10-26 17:08:16 +01:00
|
|
|
|
2020-12-19 01:29:32 +01:00
|
|
|
2. Add the appropriate Home Manager channel. If you are following
|
|
|
|
Nixpkgs master or an unstable channel you can run
|
2017-01-14 13:04:57 +01:00
|
|
|
|
2021-10-09 22:44:17 +02:00
|
|
|
```shell
|
|
|
|
nix-channel --add https://github.com/nix-community/home-manager/archive/master.tar.gz home-manager
|
|
|
|
nix-channel --update
|
2017-01-14 13:04:57 +01:00
|
|
|
```
|
|
|
|
|
2021-06-05 19:52:10 +02:00
|
|
|
and if you follow a Nixpkgs version 21.05 channel you can run
|
2017-06-15 18:11:49 +02:00
|
|
|
|
2021-10-09 22:44:17 +02:00
|
|
|
```shell
|
|
|
|
nix-channel --add https://github.com/nix-community/home-manager/archive/release-21.05.tar.gz home-manager
|
|
|
|
nix-channel --update
|
2017-06-15 18:11:49 +02:00
|
|
|
```
|
|
|
|
|
2018-12-23 10:47:12 +01:00
|
|
|
On NixOS you may need to log out and back in for the channel to
|
|
|
|
become available. On non-NixOS you may have to add
|
|
|
|
|
|
|
|
```shell
|
|
|
|
export NIX_PATH=$HOME/.nix-defexpr/channels${NIX_PATH:+:}$NIX_PATH
|
|
|
|
```
|
|
|
|
|
|
|
|
to your shell (see [nix#2033](https://github.com/NixOS/nix/issues/2033)).
|
|
|
|
|
2018-12-03 00:48:07 +01:00
|
|
|
3. Install Home Manager and create the first Home Manager generation:
|
2017-09-25 14:14:51 +02:00
|
|
|
|
2021-10-09 22:44:17 +02:00
|
|
|
```shell
|
|
|
|
nix-shell '<home-manager>' -A install
|
2017-01-14 13:04:57 +01:00
|
|
|
```
|
|
|
|
|
2018-12-03 00:48:07 +01:00
|
|
|
Once finished, Home Manager should be active and available in your
|
|
|
|
user environment.
|
2017-01-14 13:04:57 +01:00
|
|
|
|
2018-12-03 00:48:07 +01:00
|
|
|
3. If you do not plan on having Home Manager manage your shell
|
2018-01-04 13:27:29 +01:00
|
|
|
configuration then you must source the
|
|
|
|
|
2021-10-09 22:44:17 +02:00
|
|
|
```shell
|
2018-09-15 13:27:21 +02:00
|
|
|
$HOME/.nix-profile/etc/profile.d/hm-session-vars.sh
|
2018-01-04 13:27:29 +01:00
|
|
|
```
|
|
|
|
|
2021-09-04 10:22:58 +02:00
|
|
|
file in your shell configuration. This file can be sourced
|
|
|
|
directly by POSIX.2-like shells such as [Bash][] or [Z shell][].
|
2021-07-29 18:05:48 +02:00
|
|
|
[Fish][] users can use utilities such as [foreign-env][] or
|
|
|
|
[babelfish][].
|
2018-01-04 13:27:29 +01:00
|
|
|
|
|
|
|
For example, if you use Bash then add
|
|
|
|
|
|
|
|
```bash
|
|
|
|
. "$HOME/.nix-profile/etc/profile.d/hm-session-vars.sh"
|
|
|
|
```
|
|
|
|
|
2020-12-13 17:25:45 +01:00
|
|
|
or this when managing home configuration together with system
|
|
|
|
configuration
|
|
|
|
|
|
|
|
```bash
|
|
|
|
. "/etc/profiles/per-user/$USER/etc/profile.d/hm-session-vars.sh"
|
|
|
|
```
|
|
|
|
|
2021-07-29 18:05:48 +02:00
|
|
|
to your `~/.profile` file.
|
2018-01-04 13:27:29 +01:00
|
|
|
|
2018-12-03 00:48:07 +01:00
|
|
|
If instead of using channels you want to run Home Manager from a Git
|
|
|
|
checkout of the repository then you can use the
|
|
|
|
`programs.home-manager.path` option to specify the absolute path to
|
|
|
|
the repository.
|
2017-10-23 14:01:38 +02:00
|
|
|
|
2021-11-14 00:12:54 +01:00
|
|
|
Once installed you can now read the [usage section][manual usage] of the manual.
|
2017-05-06 12:50:32 +02:00
|
|
|
|
2020-09-26 12:38:33 +02:00
|
|
|
Nix Flakes
|
|
|
|
----------
|
2020-09-01 08:13:04 +02:00
|
|
|
|
2020-09-26 12:38:33 +02:00
|
|
|
Home Manager includes a `flake.nix` file for compatibility with [Nix Flakes][]
|
|
|
|
for those that wish to use it as a module. A bare-minimum `flake.nix` would be
|
|
|
|
as follows:
|
2020-09-01 08:13:04 +02:00
|
|
|
|
|
|
|
```nix
|
|
|
|
{
|
|
|
|
description = "NixOS configuration";
|
|
|
|
|
|
|
|
inputs = {
|
|
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
|
2020-09-29 20:30:06 +02:00
|
|
|
home-manager.url = "github:nix-community/home-manager";
|
2020-09-01 08:13:04 +02:00
|
|
|
};
|
|
|
|
|
2020-09-26 12:38:33 +02:00
|
|
|
outputs = { home-manager, nixpkgs, ... }: {
|
2020-09-01 08:13:04 +02:00
|
|
|
nixosConfigurations = {
|
2020-09-26 12:38:33 +02:00
|
|
|
hostname = nixpkgs.lib.nixosSystem {
|
2020-09-01 08:13:04 +02:00
|
|
|
system = "x86_64-linux";
|
|
|
|
modules = [
|
|
|
|
./configuration.nix
|
2020-09-26 12:38:33 +02:00
|
|
|
home-manager.nixosModules.home-manager
|
|
|
|
{
|
|
|
|
home-manager.useGlobalPkgs = true;
|
|
|
|
home-manager.useUserPackages = true;
|
2020-12-23 18:40:24 +01:00
|
|
|
home-manager.users.jdoe = import ./home.nix;
|
2021-11-01 17:42:22 +01:00
|
|
|
|
|
|
|
# Optionally, use home-manager.extraSpecialArgs to pass
|
|
|
|
# arguments to home.nix
|
2020-09-26 12:38:33 +02:00
|
|
|
}
|
2020-09-01 08:13:04 +02:00
|
|
|
];
|
2020-09-26 12:38:33 +02:00
|
|
|
};
|
2020-09-01 08:13:04 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2021-11-11 22:46:52 +01:00
|
|
|
If you are not using NixOS you can place the following flake in
|
|
|
|
`~/.config/nixpkgs/flake.nix` to load your standard Home Manager
|
|
|
|
configuration:
|
|
|
|
|
|
|
|
```nix
|
|
|
|
{
|
|
|
|
description = "A Home Manager flake";
|
|
|
|
|
|
|
|
inputs = {
|
|
|
|
nixpkgs.url = "github:nixos/nixpkgs/nixpkgs-unstable";
|
|
|
|
home-manager.url = "github:nix-community/home-manager";
|
|
|
|
home-manager.inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
|
|
|
|
|
|
|
outputs = inputs: {
|
|
|
|
homeConfigurations = {
|
|
|
|
jdoe = inputs.home-manager.lib.homeManagerConfiguration {
|
|
|
|
system = "x86_64-linux";
|
|
|
|
homeDirectory = "/home/jdoe";
|
|
|
|
username = "jdoe";
|
|
|
|
configuration.imports = [ ./home.nix ];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2020-12-01 02:11:48 +01:00
|
|
|
Note, the Home Manager library is exported by the flake under
|
|
|
|
`lib.hm`.
|
|
|
|
|
2020-12-13 17:25:45 +01:00
|
|
|
When using flakes, switch to new configurations as you do for the
|
|
|
|
whole system (e. g. `nixos-rebuild switch --flake <path>`) instead of
|
|
|
|
using the `home-manager` command line tool.
|
|
|
|
|
2020-02-23 22:40:31 +01:00
|
|
|
Releases
|
|
|
|
--------
|
|
|
|
|
|
|
|
Home Manager is developed against `nixpkgs-unstable` branch, which
|
|
|
|
often causes it to contain tweaks for changes/packages not yet
|
|
|
|
released in stable NixOS. To avoid breaking users' configurations,
|
|
|
|
Home Manager is released in branches corresponding to NixOS releases
|
2021-06-05 19:52:10 +02:00
|
|
|
(e.g. `release-21.05`). These branches get fixes, but usually not new
|
2020-02-23 22:40:31 +01:00
|
|
|
modules. If you need a module to be backported, then feel free to open
|
|
|
|
an issue.
|
|
|
|
|
2021-11-14 00:59:24 +01:00
|
|
|
License
|
|
|
|
-------
|
|
|
|
|
|
|
|
This project is licensed under the terms of the [MIT license](LICENSE).
|
|
|
|
|
2018-01-04 13:27:29 +01:00
|
|
|
[Bash]: https://www.gnu.org/software/bash/
|
2017-01-14 13:04:57 +01:00
|
|
|
[Nix]: https://nixos.org/nix/
|
|
|
|
[NixOS]: https://nixos.org/
|
|
|
|
[Nixpkgs]: https://nixos.org/nixpkgs/
|
2017-11-05 22:24:42 +01:00
|
|
|
[nixAllowedUsers]: https://nixos.org/nix/manual/#conf-allowed-users
|
|
|
|
[nixosAllowedUsers]: https://nixos.org/nixos/manual/options.html#opt-nix.allowedUsers
|
2018-01-04 13:27:29 +01:00
|
|
|
[Z shell]: http://zsh.sourceforge.net/
|
2020-10-19 21:22:35 +02:00
|
|
|
[manual]: https://nix-community.github.io/home-manager/
|
2021-11-14 00:12:54 +01:00
|
|
|
[manual usage]: https://nix-community.github.io/home-manager/#ch-usage
|
2020-10-19 21:22:35 +02:00
|
|
|
[configuration options]: https://nix-community.github.io/home-manager/options.html
|
2021-05-29 19:29:15 +02:00
|
|
|
[#home-manager]: https://webchat.oftc.net/?channels=home-manager
|
2021-05-29 20:22:40 +02:00
|
|
|
[OFTC]: https://oftc.net/
|
2019-03-23 23:20:22 +01:00
|
|
|
[samueldr]: https://github.com/samueldr/
|
2020-06-25 00:10:08 +02:00
|
|
|
[Nix Pills]: https://nixos.org/nixos/nix-pills/
|
2020-09-26 12:38:33 +02:00
|
|
|
[Nix Flakes]: https://nixos.wiki/wiki/Flakes
|
2021-07-29 18:05:48 +02:00
|
|
|
[Fish]: https://fishshell.com
|
|
|
|
[foreign-env]: https://github.com/oh-my-fish/plugin-foreign-env
|
|
|
|
[babelfish]: https://github.com/bouk/babelfish
|