2022-10-08 23:53:35 -07:00
|
|
|
{ stdenv
|
|
|
|
, pkgs
|
|
|
|
, lib
|
2022-04-19 14:21:55 -07:00
|
|
|
}:
|
2023-01-14 23:36:16 -08:00
|
|
|
{ name
|
|
|
|
|
|
|
|
, database
|
|
|
|
, username
|
|
|
|
, password ? null
|
|
|
|
, passwordFile ? null
|
|
|
|
|
|
|
|
, dependsOn ? {}
|
2022-10-08 23:53:35 -07:00
|
|
|
}:
|
|
|
|
|
|
|
|
assert lib.assertMsg (
|
2023-01-14 23:36:16 -08:00
|
|
|
(password == null && passwordFile != null)
|
|
|
|
|| (password != null && passwordFile == null)
|
2022-10-08 23:53:35 -07:00
|
|
|
) "set either postgresPassword or postgresPasswordFile";
|
2022-04-19 14:21:55 -07:00
|
|
|
|
|
|
|
# From https://github.com/svanderburg/dysnomia/blob/master/dysnomia-modules/postgresql-database.in
|
|
|
|
# and https://github.com/svanderburg/dysnomia/blob/master/tests/deployment/postgresql-database.nix
|
|
|
|
#
|
|
|
|
# On activation, an initial dump can be restored. If the mutable component
|
|
|
|
# contains a sub folder named postgresql-databases/, then the dump files stored
|
|
|
|
# inside get imported.
|
|
|
|
|
2022-12-17 16:45:00 -08:00
|
|
|
# TODO: https://stackoverflow.com/a/69480184/1013628
|
2023-01-14 23:36:16 -08:00
|
|
|
{
|
|
|
|
inherit name;
|
|
|
|
inherit database username password passwordFile;
|
|
|
|
|
|
|
|
pkg = stdenv.mkDerivation {
|
|
|
|
name = database;
|
|
|
|
|
|
|
|
src = pkgs.writeTextDir "${database}.sql" ''
|
|
|
|
CREATE USER "${username}" WITH PASSWORD '${password}';
|
2023-02-19 20:11:20 -08:00
|
|
|
GRANT ALL PRIVILEGES ON DATABASE "${database}" TO "${username}";
|
2023-01-14 23:36:16 -08:00
|
|
|
'';
|
|
|
|
|
|
|
|
buildCommand = ''
|
|
|
|
mkdir -p $out/postgresql-databases
|
|
|
|
cp $src/*.sql $out/postgresql-databases
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
inherit dependsOn;
|
|
|
|
type = "postgresql-database";
|
2022-04-19 14:21:55 -07:00
|
|
|
}
|