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-12-02 05:20:53 +01:00
|
|
|
Home Manager targets [NixOS][] unstable and NixOS version 21.11 (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
|
|
|
|
------------
|
|
|
|
|
2021-11-14 23:55:18 +01:00
|
|
|
Home Manager can be used in three primary ways:
|
|
|
|
|
|
|
|
1. Using the standalone `home-manager` tool. For platforms other than
|
|
|
|
NixOS and Darwin, this is the only available choice. It is also
|
|
|
|
recommended for people on NixOS or Darwin that want to manage their
|
|
|
|
home directory independently of the system as a whole. See
|
|
|
|
[Standalone installation][manual standalone install] in the manual
|
|
|
|
for instructions on how to perform this installation.
|
|
|
|
|
|
|
|
2. As a module within a NixOS system configuration. This allows the
|
|
|
|
user profiles to be built together with the system when running
|
|
|
|
`nixos-rebuild`. See [NixOS module installation][manual nixos
|
|
|
|
install] in the manual for a description of this setup.
|
|
|
|
|
|
|
|
3. As a module within a [nix-darwin][] system configuration. This
|
|
|
|
allows the user profiles to be built together with the system when
|
|
|
|
running `darwin-rebuild`. See [nix-darwin module
|
|
|
|
installation][manual nix-darwin install] in the manual for a
|
|
|
|
description of this setup.
|
2017-05-06 12:50:32 +02:00
|
|
|
|
2021-04-30 01:29:39 +02:00
|
|
|
Translations
|
|
|
|
------------
|
|
|
|
|
|
|
|
Home Manager has basic support for internationalization through
|
|
|
|
[gettext](https://www.gnu.org/software/gettext/). The translations are
|
|
|
|
hosted by [Weblate](https://weblate.org/). If you would like to
|
|
|
|
contribute to the translation effort then start by going to the
|
|
|
|
[Home Manager Weblate project](https://hosted.weblate.org/engage/home-manager/).
|
|
|
|
|
|
|
|
<a href="https://hosted.weblate.org/engage/home-manager/">
|
|
|
|
<img src="https://hosted.weblate.org/widgets/home-manager/-/multi-auto.svg" alt="Translation status" />
|
|
|
|
</a>
|
|
|
|
|
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-12-02 05:20:53 +01:00
|
|
|
(e.g. `release-21.11`). 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).
|
|
|
|
|
2017-01-14 13:04:57 +01:00
|
|
|
[Nix]: https://nixos.org/nix/
|
|
|
|
[NixOS]: https://nixos.org/
|
|
|
|
[Nixpkgs]: https://nixos.org/nixpkgs/
|
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/
|
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-11-14 23:55:18 +01:00
|
|
|
[nix-darwin]: https://github.com/LnL7/nix-darwin/
|
|
|
|
[manual standalone install]: https://nix-community.github.io/home-manager/index.html#sec-install-standalone
|
|
|
|
[manual nixos install]: https://nix-community.github.io/home-manager/index.html#sec-install-nixos-module
|
|
|
|
[manual nix-darwin install]: https://nix-community.github.io/home-manager/index.html#sec-install-nix-darwin-module
|