Switch home-assistant to PostgreSQL

Signed-off-by: main <magic_rb@redalder.org>
This commit is contained in:
main 2022-10-25 18:34:25 +02:00
parent ecdcf01e77
commit b6dc065c5d

View file

@ -1,4 +1,40 @@
{ nglib, nixpkgs }: { nglib, nixpkgs }:
{
postgresql = nglib.makeSystem {
system = "x86_64-linux";
name = "nixng-hass-postgresql";
inherit nixpkgs;
config = { pkgs, config, ... }:
{
config = {
dumb-init = {
enable = true;
type.services = {};
};
services.postgresql = {
enable = true;
package = pkgs.postgresql_12;
initialScript = "/secrets/init.sql";
enableTCPIP = true;
authentication = "host all all all md5";
ensureDatabases = [ "hass" ];
ensureExtensions = {
"pg_trgm" = [ "hass" ];
};
ensureUsers = [
{ name = "hass"; ensurePermissions = {
"DATABASE \"hass\"" = "ALL PRIVILEGES";
};
}
];
};
};
};
};
hass =
nglib.makeSystem { nglib.makeSystem {
system = "x86_64-linux"; system = "x86_64-linux";
name = "nixng-home-assistant"; name = "nixng-home-assistant";
@ -26,16 +62,14 @@ nglib.makeSystem {
services.home-assistant = { services.home-assistant = {
enable = true; enable = true;
envsubst = true; envsubst = true;
customComponents = { customComponents = {};
xiaomi_gateway3 = pkgs.fetchFromGitHub {
owner = "AlexxIT";
repo = "XiaomiGateway3";
rev = "v1.6.5";
sha256 = "sha256-RSIJqsbgnktl7zNaxAKUoMjbkrJ1aJTej0vjlCgstJ8=";
} + "/custom_components/xiaomi_gateway3";
};
config = config =
{ default_config = {}; { default_config = {};
recorder = {
db_url = "postgresql://hass:\${PSQL_PASSWORD}@127.0.0.1/hass";
db_max_retries = 5;
db_retry_wait = 30;
};
stream = {}; stream = {};
http = { http = {
server_port = "8123"; server_port = "8123";
@ -85,9 +119,11 @@ nglib.makeSystem {
"ssdp" "ssdp"
"mqtt" "mqtt"
"stream" "stream"
"recorder"
]; ];
extraPackages = ps: with ps; extraPackages = ps: with ps;
[ xmodem [ xmodem
psycopg2
]; ];
}).overridePythonAttrs (old: }).overridePythonAttrs (old:
{ doCheck = false; { doCheck = false;
@ -95,4 +131,6 @@ nglib.makeSystem {
}; };
}; };
}); });
};
} }