2017-12-13 22:02:11 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
with lib;
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.environment;
|
|
|
|
in
|
|
|
|
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
environment.shells = mkOption {
|
|
|
|
type = types.listOf (types.either types.shellPackage types.path);
|
|
|
|
default = [];
|
2021-10-23 13:05:52 +00:00
|
|
|
example = literalExpression "[ pkgs.bashInteractive pkgs.zsh ]";
|
2024-04-14 21:02:32 +00:00
|
|
|
description = ''
|
2017-12-13 22:02:11 +00:00
|
|
|
A list of permissible login shells for user accounts.
|
2024-10-24 14:16:19 +00:00
|
|
|
|
|
|
|
The default macOS shells will be automatically included:
|
|
|
|
- /bin/bash
|
|
|
|
- /bin/csh
|
|
|
|
- /bin/dash
|
|
|
|
- /bin/ksh
|
|
|
|
- /bin/sh
|
|
|
|
- /bin/tcsh
|
|
|
|
- /bin/zsh
|
2017-12-13 22:02:11 +00:00
|
|
|
'';
|
|
|
|
apply = map (v: if types.shellPackage.check v then "/run/current-system/sw${v.shellPath}" else v);
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf (cfg.shells != []) {
|
|
|
|
|
|
|
|
environment.etc."shells".text = ''
|
|
|
|
# List of acceptable shells for chpass(1).
|
|
|
|
# Ftpd will not allow users to connect who are not using
|
|
|
|
# one of these shells.
|
|
|
|
|
|
|
|
/bin/bash
|
|
|
|
/bin/csh
|
2020-11-21 19:06:52 +00:00
|
|
|
/bin/dash
|
2017-12-13 22:02:11 +00:00
|
|
|
/bin/ksh
|
|
|
|
/bin/sh
|
|
|
|
/bin/tcsh
|
|
|
|
/bin/zsh
|
|
|
|
|
|
|
|
# List of shells managed by nix.
|
|
|
|
${concatStringsSep "\n" cfg.shells}
|
|
|
|
'';
|
|
|
|
|
2023-12-23 11:41:58 +00:00
|
|
|
environment.etc."shells".knownSha256Hashes = [
|
|
|
|
"9d5aa72f807091b481820d12e693093293ba33c73854909ad7b0fb192c2db193" # macOS
|
|
|
|
];
|
|
|
|
|
2017-12-13 22:02:11 +00:00
|
|
|
};
|
|
|
|
}
|