60 lines
1.2 KiB
Nix
60 lines
1.2 KiB
Nix
{ lib, config, ... }:
|
|
let
|
|
enabled = config.mod.ssh.enable;
|
|
in
|
|
{
|
|
options = {
|
|
mod.ssh = {
|
|
enable = lib.mkEnableOption "enable ssh module";
|
|
};
|
|
};
|
|
|
|
config = lib.mkIf enabled {
|
|
home-manager.users.alex = {
|
|
programs.ssh = {
|
|
enable = true;
|
|
|
|
matchBlocks = {
|
|
"codeberg.org" = {
|
|
hostname = "codeberg.org";
|
|
identityFile = "/home/alex/.ssh/alex.tadpole-codeberg.org";
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
age.secrets = {
|
|
"alex.tadpole-codeberg.org" = {
|
|
file = ../../../../secrets/tadpole/alex.tadpole-codeberg.org.age;
|
|
path = "/home/alex/.ssh/alex.tadpole-codeberg.org";
|
|
owner = "alex";
|
|
group = "users";
|
|
};
|
|
"alex.tadpole-codeberg.org.pub" = {
|
|
file = ../../../../secrets/tadpole/alex.tadpole-codeberg.org.pub.age;
|
|
path = "/home/alex/.ssh/alex.tadpole-codeberg.org.pub";
|
|
owner = "alex";
|
|
group = "users";
|
|
};
|
|
};
|
|
|
|
services = {
|
|
openssh = {
|
|
enable = true;
|
|
ports = [ 1122 ];
|
|
|
|
hostKeys = [{
|
|
path = "/etc/ssh/tadpole";
|
|
type = "ed25519";
|
|
}];
|
|
};
|
|
};
|
|
|
|
networking = {
|
|
firewall = {
|
|
allowedTCPPorts = [ 1122 ];
|
|
};
|
|
};
|
|
};
|
|
}
|