summary refs log blame commit diff
path: root/modules/services/databases/postgresql.nix
blob: 207701f13551da5ca1e058b5816df8fed824b49a (plain) (tree)
1
2
3
4
5
6
7
8
9
10
11
12

                    
   
                                             
 






                                                        
                                                             
 

                                                 
  
 
















































































                                                                              
 
 




                                                   

                                               
        
 

                                 
 
                                              
 

                                          
 

                                               
 

                  





                                                                                               
             
 

                                                                                            
 
    
  
 
{pkgs, config, ...}:

let
  inherit (pkgs.lib) mkOption mkIf singleton;

  cfg = config.services.postgresql;

  postgresql = pkgs.postgresql;

  startDependency = if config.services.gw6c.enable then 
    "gw6c" else "network-interfaces";

  run = "${pkgs.su}/bin/su -s ${pkgs.stdenv.shell} postgres";

  flags = if cfg.enableTCPIP then ["-i"] else [];

in

{

  ###### interface
  
  options = {
  
    services.postgresql = {
    
      enable = mkOption {
        default = false;
        description = ''
          Whether to run PostgreSQL.
        '';
      };
      
      port = mkOption {
        default = "5432";
        description = ''
          Port for PostgreSQL.
        '';
      };
      
      logDir = mkOption {
        default = "/var/log/postgresql";
        description = ''
          Log directory for PostgreSQL.
        '';
      };
      
      dataDir = mkOption {
        default = "/var/db/postgresql";
        description = ''
          Data directory for PostgreSQL.
        '';
      };
      
      subServices = mkOption {
        default = [];
        description = ''
          Subservices list. As it is already implememnted, 
          here is an interface...
        '';
      };
      
      authentication = mkOption {
        default = ''
          # Generated file; do not edit!
          local all all              ident sameuser
          host  all all 127.0.0.1/32 md5
          host  all all ::1/128      md5
        '';
        description = ''
          Hosts (except localhost), who you allow to connect.
        '';
      };
      
      allowedHosts = mkOption {
        default = [];
        description = ''
          Hosts (except localhost), who you allow to connect.
        '';
      };
      
      authMethod = mkOption {
        default = " ident sameuser ";
        description = ''
          How to authorize users. 
          Note: ident needs absolute trust to all allowed client hosts.
        '';
      };
      
      enableTCPIP = mkOption {
        default = false;
        description = ''
          Whether to run PostgreSQL with -i flag to enable TCP/IP connections.
        '';
      };
      
    };

  };


  ###### implementation
  
  config = mkIf config.services.postgresql.enable {

    users.extraUsers = singleton
      { name = "postgres";
        description = "PostgreSQL server user";
      };

    users.extraGroups = singleton
      { name = "postgres"; };

    environment.systemPackages = [postgresql];

    jobAttrs.postgresql =
      { description = "PostgreSQL server";

        startOn = "${startDependency}/started";
        stopOn = "shutdown";

        preStart =
          ''
            if ! test -e ${cfg.dataDir}; then
                mkdir -m 0700 -p ${cfg.dataDir}
                chown -R postgres ${cfg.dataDir}
                ${run} -c '${postgresql}/bin/initdb -D ${cfg.dataDir} -U root'
            fi
            cp -f ${pkgs.writeText "pg_hba.conf" cfg.authentication} ${cfg.dataDir}/pg_hba.conf
          '';

        exec = "${run} -c '${postgresql}/bin/postgres -D ${cfg.dataDir} ${toString flags}'";
      };

  };
  
}