2017-07-31 10:40:41 +00:00
|
|
|
{ lib, pkgs, config, ... } :
|
|
|
|
let
|
2017-11-02 19:35:05 +00:00
|
|
|
cfg = config.services.pgmanage;
|
2017-07-31 10:40:41 +00:00
|
|
|
|
|
|
|
confFile = pkgs.writeTextFile {
|
2017-11-02 19:35:05 +00:00
|
|
|
name = "pgmanage.conf";
|
2017-07-31 10:40:41 +00:00
|
|
|
text = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
connection_file = ${pgmanageConnectionsFile}
|
2017-07-31 10:40:41 +00:00
|
|
|
|
|
|
|
allow_custom_connections = ${builtins.toJSON cfg.allowCustomConnections}
|
|
|
|
|
2017-11-02 19:35:05 +00:00
|
|
|
pgmanage_port = ${toString cfg.port}
|
2017-07-31 10:40:41 +00:00
|
|
|
|
|
|
|
super_only = ${builtins.toJSON cfg.superOnly}
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
${lib.optionalString (cfg.loginGroup != null) "login_group = ${cfg.loginGroup}"}
|
2017-07-31 10:40:41 +00:00
|
|
|
|
|
|
|
login_timeout = ${toString cfg.loginTimeout}
|
|
|
|
|
2017-11-02 19:35:05 +00:00
|
|
|
web_root = ${cfg.package}/etc/pgmanage/web_root
|
2017-07-31 10:40:41 +00:00
|
|
|
|
2018-04-01 17:16:04 +00:00
|
|
|
sql_root = ${cfg.sqlRoot}
|
2017-07-31 10:40:41 +00:00
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
${lib.optionalString (cfg.tls != null) ''
|
2017-07-31 10:40:41 +00:00
|
|
|
tls_cert = ${cfg.tls.cert}
|
|
|
|
tls_key = ${cfg.tls.key}
|
|
|
|
''}
|
|
|
|
|
|
|
|
log_level = ${cfg.logLevel}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2017-11-02 19:35:05 +00:00
|
|
|
pgmanageConnectionsFile = pkgs.writeTextFile {
|
|
|
|
name = "pgmanage-connections.conf";
|
2024-08-27 18:43:01 +00:00
|
|
|
text = lib.concatStringsSep "\n"
|
|
|
|
(lib.mapAttrsToList (name : conn : "${name}: ${conn}") cfg.connections);
|
2017-07-31 10:40:41 +00:00
|
|
|
};
|
|
|
|
|
2017-11-02 19:35:05 +00:00
|
|
|
pgmanage = "pgmanage";
|
2017-07-31 10:40:41 +00:00
|
|
|
|
2018-06-23 11:32:13 +00:00
|
|
|
in {
|
|
|
|
|
|
|
|
options.services.pgmanage = {
|
2024-08-27 18:43:01 +00:00
|
|
|
enable = lib.mkEnableOption "PostgreSQL Administration for the web";
|
2017-07-31 10:40:41 +00:00
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
package = lib.mkPackageOption pkgs "pgmanage" { };
|
2017-07-31 10:40:41 +00:00
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
connections = lib.mkOption {
|
|
|
|
type = lib.types.attrsOf lib.types.str;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = {};
|
|
|
|
example = {
|
2019-08-13 21:52:01 +00:00
|
|
|
nuc-server = "hostaddr=192.168.0.100 port=5432 dbname=postgres";
|
|
|
|
mini-server = "hostaddr=127.0.0.1 port=5432 dbname=postgres sslmode=require";
|
2017-07-31 10:40:41 +00:00
|
|
|
};
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
pgmanage requires at least one PostgreSQL server be defined.
|
2022-08-02 15:34:22 +00:00
|
|
|
|
2017-07-31 10:40:41 +00:00
|
|
|
Detailed information about PostgreSQL connection strings is available at:
|
2023-10-30 20:41:44 +00:00
|
|
|
<https://www.postgresql.org/docs/current/libpq-connect.html>
|
2022-08-02 15:34:22 +00:00
|
|
|
|
2017-07-31 10:40:41 +00:00
|
|
|
Note that you should not specify your user name or password. That
|
|
|
|
information will be entered on the login screen. If you specify a
|
2017-11-02 19:35:05 +00:00
|
|
|
username or password, it will be removed by pgmanage before attempting to
|
2017-07-31 10:40:41 +00:00
|
|
|
connect to a database.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
allowCustomConnections = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = false;
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
This tells pgmanage whether or not to allow anyone to use a custom
|
2017-07-31 10:40:41 +00:00
|
|
|
connection from the login screen.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
port = lib.mkOption {
|
|
|
|
type = lib.types.port;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = 8080;
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
This tells pgmanage what port to listen on for browser requests.
|
2017-07-31 10:40:41 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
localOnly = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = true;
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
This tells pgmanage whether or not to set the listening socket to local
|
2017-07-31 10:40:41 +00:00
|
|
|
addresses only.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
superOnly = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = true;
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
This tells pgmanage whether or not to only allow super users to
|
2017-07-31 10:40:41 +00:00
|
|
|
login. The recommended value is true and will restrict users who are not
|
|
|
|
super users from logging in to any PostgreSQL instance through
|
2017-11-02 19:35:05 +00:00
|
|
|
pgmanage. Note that a connection will be made to PostgreSQL in order to
|
2017-07-31 10:40:41 +00:00
|
|
|
test if the user is a superuser.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
loginGroup = lib.mkOption {
|
|
|
|
type = lib.types.nullOr lib.types.str;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = null;
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
This tells pgmanage to only allow users in a certain PostgreSQL group to
|
|
|
|
login to pgmanage. Note that a connection will be made to PostgreSQL in
|
2017-07-31 10:40:41 +00:00
|
|
|
order to test if the user is a member of the login group.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
loginTimeout = lib.mkOption {
|
|
|
|
type = lib.types.int;
|
2017-07-31 10:40:41 +00:00
|
|
|
default = 3600;
|
|
|
|
description = ''
|
|
|
|
Number of seconds of inactivity before user is automatically logged
|
|
|
|
out.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
sqlRoot = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
2017-11-02 19:35:05 +00:00
|
|
|
default = "/var/lib/pgmanage";
|
2017-07-31 10:40:41 +00:00
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
This tells pgmanage where to put the SQL file history. All tabs are saved
|
|
|
|
to this location so that if you get disconnected from pgmanage you
|
2017-07-31 10:40:41 +00:00
|
|
|
don't lose your work.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
tls = lib.mkOption {
|
|
|
|
type = lib.types.nullOr (lib.types.submodule {
|
2017-07-31 10:40:41 +00:00
|
|
|
options = {
|
2024-08-27 18:43:01 +00:00
|
|
|
cert = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
2017-07-31 10:40:41 +00:00
|
|
|
description = "TLS certificate";
|
|
|
|
};
|
2024-08-27 18:43:01 +00:00
|
|
|
key = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
2017-07-31 10:40:41 +00:00
|
|
|
description = "TLS key";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
});
|
|
|
|
default = null;
|
|
|
|
description = ''
|
2017-11-02 19:35:05 +00:00
|
|
|
These options tell pgmanage where the TLS Certificate and Key files
|
2017-07-31 10:40:41 +00:00
|
|
|
reside. If you use these options then you'll only be able to access
|
2017-11-02 19:35:05 +00:00
|
|
|
pgmanage through a secure TLS connection. These options are only
|
|
|
|
necessary if you wish to connect directly to pgmanage using a secure TLS
|
|
|
|
connection. As an alternative, you can set up pgmanage in a reverse proxy
|
2017-07-31 10:40:41 +00:00
|
|
|
configuration. This allows your web server to terminate the secure
|
2017-11-02 19:35:05 +00:00
|
|
|
connection and pass on the request to pgmanage. You can find help to set
|
2017-07-31 10:40:41 +00:00
|
|
|
up this configuration in:
|
2017-11-02 19:35:05 +00:00
|
|
|
<https://github.com/pgManage/pgManage/blob/master/INSTALL_NGINX.md>
|
2017-07-31 10:40:41 +00:00
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
logLevel = lib.mkOption {
|
|
|
|
type = lib.types.enum ["error" "warn" "notice" "info"];
|
2017-07-31 10:40:41 +00:00
|
|
|
default = "error";
|
|
|
|
description = ''
|
|
|
|
Verbosity of logs
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-08-27 18:43:01 +00:00
|
|
|
config = lib.mkIf cfg.enable {
|
2018-06-23 11:32:13 +00:00
|
|
|
systemd.services.pgmanage = {
|
|
|
|
description = "pgmanage - PostgreSQL Administration for the web";
|
|
|
|
wants = [ "postgresql.service" ];
|
|
|
|
after = [ "postgresql.service" ];
|
|
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig = {
|
|
|
|
User = pgmanage;
|
|
|
|
Group = pgmanage;
|
2021-12-29 22:59:26 +00:00
|
|
|
ExecStart = "${cfg.package}/sbin/pgmanage -c ${confFile}" +
|
2024-08-27 18:43:01 +00:00
|
|
|
lib.optionalString cfg.localOnly " --local-only=true";
|
2017-07-31 10:40:41 +00:00
|
|
|
};
|
2018-06-23 11:32:13 +00:00
|
|
|
};
|
|
|
|
users = {
|
2019-08-13 21:52:01 +00:00
|
|
|
users.${pgmanage} = {
|
2018-06-23 11:32:13 +00:00
|
|
|
name = pgmanage;
|
|
|
|
group = pgmanage;
|
|
|
|
home = cfg.sqlRoot;
|
|
|
|
createHome = true;
|
2021-03-07 13:54:00 +00:00
|
|
|
isSystemUser = true;
|
2017-07-31 10:40:41 +00:00
|
|
|
};
|
2019-08-13 21:52:01 +00:00
|
|
|
groups.${pgmanage} = {
|
2018-06-23 11:32:13 +00:00
|
|
|
name = pgmanage;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2017-07-31 10:40:41 +00:00
|
|
|
}
|