1
0
Fork 0
mirror of https://github.com/nix-community/home-manager.git synced 2025-11-21 17:59:39 +01:00
home-manager/modules/programs/tmate.nix
Austin Horstman cba2f9ce95 treewide: reformat nixfmt-rfc-style
Reformat repository using new nixfmt-rfc-style.
2025-04-08 08:50:05 -07:00

83 lines
2.1 KiB
Nix

{
config,
lib,
pkgs,
...
}:
let
inherit (lib)
literalExpression
mkOption
optional
types
;
cfg = config.programs.tmate;
in
{
meta.maintainers = [ lib.maintainers.jlesquembre ];
options = {
programs.tmate = {
enable = lib.mkEnableOption "tmate";
package = lib.mkPackageOption pkgs "tmate" { };
host = mkOption {
type = with types; nullOr str;
default = null;
example = literalExpression "tmate.io";
description = "Tmate server address.";
};
port = mkOption {
type = with types; nullOr port;
default = null;
example = 2222;
description = "Tmate server port.";
};
dsaFingerprint = mkOption {
type = with types; nullOr str;
default = null;
example = literalExpression "SHA256:1111111111111111111111111111111111111111111";
description = "Tmate server EdDSA key fingerprint.";
};
rsaFingerprint = mkOption {
type = with types; nullOr str;
default = null;
example = literalExpression "SHA256:1111111111111111111111111111111111111111111";
description = "Tmate server RSA key fingerprint.";
};
extraConfig = mkOption {
type = types.lines;
default = "";
description = ''
Additional content written at the end of
{file}`~/.tmate.conf`.
'';
};
};
};
config = lib.mkIf cfg.enable {
home.packages = [ cfg.package ];
home.file.".tmate.conf" =
let
conf =
optional (cfg.host != null) ''set -g tmate-server-host "${cfg.host}"''
++ optional (cfg.port != null) "set -g tmate-server-port ${builtins.toString cfg.port}"
++ optional (
cfg.dsaFingerprint != null
) ''set -g tmate-server-ed25519-fingerprint "${cfg.dsaFingerprint}"''
++ optional (
cfg.rsaFingerprint != null
) ''set -g tmate-server-rsa-fingerprint "${cfg.rsaFingerprint}"''
++ optional (cfg.extraConfig != "") cfg.extraConfig;
in
lib.mkIf (conf != [ ]) { text = lib.concatLines conf; };
};
}