feat(nix): add database module and enable mongodb,mysql,pgsql
This commit is contained in:
parent
ea77bf62ad
commit
774527379a
2 changed files with 97 additions and 0 deletions
|
@ -30,6 +30,13 @@
|
||||||
platform = "intel";
|
platform = "intel";
|
||||||
root.drive = "/dev/disk/by-id/nvme-eui.002538d221b47b01";
|
root.drive = "/dev/disk/by-id/nvme-eui.002538d221b47b01";
|
||||||
};
|
};
|
||||||
|
extraCfg.server = {
|
||||||
|
databases = {
|
||||||
|
mongodb.enable = true;
|
||||||
|
mysql.enable = true;
|
||||||
|
postgresql.enable = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
90
nix/modules/server/databases.nix
Normal file
90
nix/modules/server/databases.nix
Normal file
|
@ -0,0 +1,90 @@
|
||||||
|
{ lib, config, ... }:
|
||||||
|
let
|
||||||
|
inherit (builtins) toString;
|
||||||
|
inherit (lib.modules) mkIf mkMerge mkOverride;
|
||||||
|
inherit (lib.lists) singleton;
|
||||||
|
inherit (lib.options) mkEnableOption;
|
||||||
|
inherit (config.flake.lib.options) mkPortOption;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
allowedUnfreePackages = [ "mongodb" ];
|
||||||
|
flake.modules.nixos.default =
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
let
|
||||||
|
cfg = config.server.databases;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.server.databases = {
|
||||||
|
mongodb = {
|
||||||
|
enable = mkEnableOption "the MongoDB server";
|
||||||
|
port = mkPortOption 27017;
|
||||||
|
};
|
||||||
|
mysql = {
|
||||||
|
enable = mkEnableOption "the MySQL server";
|
||||||
|
port = mkPortOption 3306;
|
||||||
|
};
|
||||||
|
postgresql = {
|
||||||
|
enable = mkEnableOption "the postgresql server";
|
||||||
|
port = mkPortOption 5432;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkMerge [
|
||||||
|
(mkIf cfg.postgresql.enable {
|
||||||
|
networking.firewall.allowedTCPPorts = singleton cfg.postgresql.port;
|
||||||
|
persistDirs = singleton {
|
||||||
|
directory = toString config.services.postgresql.dataDir;
|
||||||
|
user = "postgres";
|
||||||
|
group = "postgres";
|
||||||
|
};
|
||||||
|
services.postgresql = {
|
||||||
|
enable = true;
|
||||||
|
enableTCPIP = true;
|
||||||
|
settings = { inherit (cfg.postgresql) port; };
|
||||||
|
authentication = mkOverride 10 ''
|
||||||
|
#type database DBuser auth-method
|
||||||
|
local all all trust
|
||||||
|
|
||||||
|
# ipv4
|
||||||
|
host all all 0.0.0.0/0 trust
|
||||||
|
'';
|
||||||
|
ensureDatabases = singleton "alphastory";
|
||||||
|
ensureUsers = singleton {
|
||||||
|
name = "alphastory";
|
||||||
|
ensureDBOwnership = true;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})
|
||||||
|
(mkIf cfg.mongodb.enable {
|
||||||
|
networking.firewall.allowedTCPPorts = [ cfg.mongodb.port ];
|
||||||
|
persistDirs = singleton {
|
||||||
|
directory = toString config.services.mongodb.dbpath;
|
||||||
|
user = "mongodb";
|
||||||
|
group = "mongodb";
|
||||||
|
};
|
||||||
|
services.mongodb = {
|
||||||
|
enable = true;
|
||||||
|
bind_ip = "0.0.0.0";
|
||||||
|
extraConfig = ''
|
||||||
|
net.port: ${toString cfg.mongodb.port}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
})
|
||||||
|
(mkIf cfg.mysql.enable {
|
||||||
|
networking.firewall.allowedTCPPorts = [ cfg.mysql.port ];
|
||||||
|
persistDirs = singleton {
|
||||||
|
directory = toString config.services.mysql.dataDir;
|
||||||
|
user = "mysql";
|
||||||
|
group = "mysql";
|
||||||
|
};
|
||||||
|
services.mysql = {
|
||||||
|
enable = true;
|
||||||
|
package = pkgs.mariadb;
|
||||||
|
settings.mysqld = {
|
||||||
|
inherit (cfg.mysql) port;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
})
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue