2023-07-01 09:46:19 -07:00
|
|
|
{
|
|
|
|
description = "Home Assistant example for Self Host Blocks";
|
|
|
|
|
|
|
|
inputs = {
|
2023-12-09 10:16:41 -08:00
|
|
|
selfhostblocks.url = "github:ibizaman/selfhostblocks";
|
2023-07-01 09:46:19 -07:00
|
|
|
};
|
|
|
|
|
2023-12-25 23:31:59 -08:00
|
|
|
outputs = inputs@{ self, selfhostblocks, ... }: {
|
2023-07-01 09:46:19 -07:00
|
|
|
colmena = {
|
|
|
|
meta = {
|
2023-12-25 23:31:59 -08:00
|
|
|
nixpkgs = import selfhostblocks.inputs.nixpkgs {
|
2023-07-01 09:46:19 -07:00
|
|
|
system = "x86_64-linux";
|
|
|
|
};
|
|
|
|
specialArgs = inputs;
|
|
|
|
};
|
|
|
|
|
2024-01-08 00:36:23 -08:00
|
|
|
basic = { config, ... }: {
|
|
|
|
imports = [
|
|
|
|
./configuration.nix
|
|
|
|
selfhostblocks.inputs.sops-nix.nixosModules.default
|
|
|
|
selfhostblocks.nixosModules.x86_64-linux.default
|
|
|
|
];
|
|
|
|
|
|
|
|
# Used by colmena to know which target host to deploy to.
|
|
|
|
deployment = {
|
|
|
|
targetHost = "example";
|
|
|
|
targetUser = "nixos";
|
|
|
|
targetPort = 2222;
|
|
|
|
};
|
|
|
|
|
|
|
|
shb.home-assistant = {
|
|
|
|
enable = true;
|
|
|
|
domain = "example.com";
|
|
|
|
subdomain = "ha";
|
|
|
|
sopsFile = ./secrets.yaml;
|
|
|
|
};
|
|
|
|
|
|
|
|
nixpkgs.config.permittedInsecurePackages = [
|
|
|
|
"openssl-1.1.1w"
|
|
|
|
];
|
|
|
|
|
|
|
|
# Set to true for more debug info with `journalctl -f -u nginx`.
|
|
|
|
shb.nginx.accessLog = false;
|
|
|
|
shb.nginx.debugLog = false;
|
|
|
|
};
|
|
|
|
|
|
|
|
ldap = { config, ... }: {
|
2023-07-01 09:46:19 -07:00
|
|
|
imports = [
|
|
|
|
./configuration.nix
|
2023-12-25 23:31:59 -08:00
|
|
|
selfhostblocks.inputs.sops-nix.nixosModules.default
|
2023-11-19 09:06:53 -08:00
|
|
|
selfhostblocks.nixosModules.x86_64-linux.default
|
2023-07-01 09:46:19 -07:00
|
|
|
];
|
|
|
|
|
2023-12-09 08:32:28 -08:00
|
|
|
# Used by colmena to know which target host to deploy to.
|
|
|
|
deployment = {
|
|
|
|
targetHost = "example";
|
|
|
|
targetUser = "nixos";
|
|
|
|
targetPort = 2222;
|
|
|
|
};
|
|
|
|
|
2023-11-19 09:06:53 -08:00
|
|
|
shb.ldap = {
|
|
|
|
enable = true;
|
|
|
|
domain = "example.com";
|
|
|
|
subdomain = "ldap";
|
|
|
|
ldapPort = 3890;
|
2023-12-09 10:16:41 -08:00
|
|
|
webUIListenPort = 17170;
|
2023-11-19 09:06:53 -08:00
|
|
|
dcdomain = "dc=example,dc=com";
|
2023-12-09 10:16:41 -08:00
|
|
|
ldapUserPasswordFile = config.sops.secrets."lldap/user_password".path;
|
|
|
|
jwtSecretFile = config.sops.secrets."lldap/jwt_secret".path;
|
|
|
|
};
|
|
|
|
sops.secrets."lldap/user_password" = {
|
|
|
|
sopsFile = ./secrets.yaml;
|
|
|
|
mode = "0440";
|
|
|
|
owner = "lldap";
|
|
|
|
group = "lldap";
|
|
|
|
restartUnits = [ "lldap.service" ];
|
|
|
|
};
|
|
|
|
sops.secrets."lldap/jwt_secret" = {
|
2023-11-19 09:06:53 -08:00
|
|
|
sopsFile = ./secrets.yaml;
|
2023-12-09 10:16:41 -08:00
|
|
|
mode = "0440";
|
|
|
|
owner = "lldap";
|
|
|
|
group = "lldap";
|
|
|
|
restartUnits = [ "lldap.service" ];
|
2023-11-19 09:06:53 -08:00
|
|
|
};
|
|
|
|
|
2023-07-01 09:46:19 -07:00
|
|
|
shb.home-assistant = {
|
|
|
|
enable = true;
|
2023-11-19 09:06:53 -08:00
|
|
|
domain = "example.com";
|
2024-01-08 00:36:23 -08:00
|
|
|
ldap = {
|
|
|
|
enable = true;
|
|
|
|
host = "127.0.0.1";
|
|
|
|
port = config.shb.ldap.webUIListenPort;
|
|
|
|
userGroup = "homeassistant_user";
|
|
|
|
};
|
2023-07-01 09:46:19 -07:00
|
|
|
subdomain = "ha";
|
|
|
|
sopsFile = ./secrets.yaml;
|
|
|
|
};
|
2023-11-19 09:06:53 -08:00
|
|
|
|
2024-01-08 00:36:23 -08:00
|
|
|
nixpkgs.config.permittedInsecurePackages = [
|
|
|
|
"openssl-1.1.1w"
|
|
|
|
];
|
2023-07-01 09:46:19 -07:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|