aboutsummaryrefslogtreecommitdiff
path: root/nixpkgs/nixos/modules/config/gnu.nix
diff options
context:
space:
mode:
Diffstat (limited to 'nixpkgs/nixos/modules/config/gnu.nix')
-rw-r--r--nixpkgs/nixos/modules/config/gnu.nix46
1 files changed, 46 insertions, 0 deletions
diff --git a/nixpkgs/nixos/modules/config/gnu.nix b/nixpkgs/nixos/modules/config/gnu.nix
new file mode 100644
index 00000000000..93d13097019
--- /dev/null
+++ b/nixpkgs/nixos/modules/config/gnu.nix
@@ -0,0 +1,46 @@
+{ config, lib, pkgs, ... }:
+
+with lib;
+
+{
+ options = {
+ gnu = mkOption {
+ type = types.bool;
+ default = false;
+ description = ''
+ When enabled, GNU software is chosen by default whenever a there is
+ a choice between GNU and non-GNU software (e.g., GNU lsh
+ vs. OpenSSH).
+ '';
+ };
+ };
+
+ config = mkIf config.gnu {
+
+ environment.systemPackages = with pkgs;
+ # TODO: Adjust `requiredPackages' from `system-path.nix'.
+ # TODO: Add Inetutils once it has the new `ifconfig'.
+ [ parted
+ #fdisk # XXX: GNU fdisk currently fails to build and it's redundant
+ # with the `parted' command.
+ nano zile
+ texinfo # for the stand-alone Info reader
+ ]
+ ++ stdenv.lib.optional (!stdenv.isAarch32) grub2;
+
+
+ # GNU GRUB, where available.
+ boot.loader.grub.enable = !pkgs.stdenv.isAarch32;
+ boot.loader.grub.version = 2;
+
+ # GNU lsh.
+ services.openssh.enable = false;
+ services.lshd.enable = true;
+ programs.ssh.startAgent = false;
+ services.xserver.startGnuPGAgent = true;
+
+ # TODO: GNU dico.
+ # TODO: GNU Inetutils' inetd.
+ # TODO: GNU Pies.
+ };
+}