142 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			142 lines
		
	
	
		
			3.5 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{ config, lib, pkgs, ... }:
 | 
						|
 | 
						|
let
 | 
						|
  cfg = config.services.ergo;
 | 
						|
 | 
						|
  inherit (lib) mkEnableOption mkIf mkOption optionalString types;
 | 
						|
 | 
						|
  configFile = pkgs.writeText "ergo.conf" (''
 | 
						|
ergo {
 | 
						|
  directory = "${cfg.dataDir}"
 | 
						|
  node {
 | 
						|
    mining = false
 | 
						|
  }
 | 
						|
  wallet.secretStorage.secretDir = "${cfg.dataDir}/wallet/keystore"
 | 
						|
}
 | 
						|
 | 
						|
scorex {
 | 
						|
  network {
 | 
						|
    bindAddress = "${cfg.listen.ip}:${toString cfg.listen.port}"
 | 
						|
  }
 | 
						|
'' + optionalString (cfg.api.keyHash != null) ''
 | 
						|
 restApi {
 | 
						|
    apiKeyHash = "${cfg.api.keyHash}"
 | 
						|
    bindAddress = "${cfg.api.listen.ip}:${toString cfg.api.listen.port}"
 | 
						|
 }
 | 
						|
'' + ''
 | 
						|
}
 | 
						|
'');
 | 
						|
 | 
						|
in {
 | 
						|
 | 
						|
  options = {
 | 
						|
 | 
						|
    services.ergo = {
 | 
						|
      enable = mkEnableOption "Ergo service";
 | 
						|
 | 
						|
      dataDir = mkOption {
 | 
						|
        type = types.path;
 | 
						|
        default = "/var/lib/ergo";
 | 
						|
        description = "The data directory for the Ergo node.";
 | 
						|
      };
 | 
						|
 | 
						|
      listen = {
 | 
						|
        ip = mkOption {
 | 
						|
          type = types.str;
 | 
						|
          default = "0.0.0.0";
 | 
						|
          description = "IP address on which the Ergo node should listen.";
 | 
						|
        };
 | 
						|
 | 
						|
        port = mkOption {
 | 
						|
          type = types.port;
 | 
						|
          default = 9006;
 | 
						|
          description = "Listen port for the Ergo node.";
 | 
						|
        };
 | 
						|
      };
 | 
						|
 | 
						|
      api = {
 | 
						|
       keyHash = mkOption {
 | 
						|
        type = types.nullOr types.str;
 | 
						|
        default = null;
 | 
						|
        example = "324dcf027dd4a30a932c441f365a25e86b173defa4b8e58948253471b81b72cf";
 | 
						|
        description = "Hex-encoded Blake2b256 hash of an API key as a 64-chars long Base16 string.";
 | 
						|
       };
 | 
						|
 | 
						|
       listen = {
 | 
						|
        ip = mkOption {
 | 
						|
          type = types.str;
 | 
						|
          default = "0.0.0.0";
 | 
						|
          description = "IP address that the Ergo node API should listen on if <option>api.keyHash</option> is defined.";
 | 
						|
          };
 | 
						|
 | 
						|
        port = mkOption {
 | 
						|
          type = types.port;
 | 
						|
          default = 9052;
 | 
						|
          description = "Listen port for the API endpoint if <option>api.keyHash</option> is defined.";
 | 
						|
        };
 | 
						|
       };
 | 
						|
      };
 | 
						|
 | 
						|
      testnet = mkOption {
 | 
						|
         type = types.bool;
 | 
						|
         default = false;
 | 
						|
         description = "Connect to testnet network instead of the default mainnet.";
 | 
						|
      };
 | 
						|
 | 
						|
      user = mkOption {
 | 
						|
        type = types.str;
 | 
						|
        default = "ergo";
 | 
						|
        description = "The user as which to run the Ergo node.";
 | 
						|
      };
 | 
						|
 | 
						|
      group = mkOption {
 | 
						|
        type = types.str;
 | 
						|
        default = cfg.user;
 | 
						|
        description = "The group as which to run the Ergo node.";
 | 
						|
      };
 | 
						|
 | 
						|
      openFirewall = mkOption {
 | 
						|
        type = types.bool;
 | 
						|
        default = false;
 | 
						|
        description = "Open ports in the firewall for the Ergo node as well as the API.";
 | 
						|
      };
 | 
						|
    };
 | 
						|
  };
 | 
						|
 | 
						|
  config = mkIf cfg.enable {
 | 
						|
 | 
						|
    systemd.tmpfiles.rules = [
 | 
						|
      "d '${cfg.dataDir}' 0770 '${cfg.user}' '${cfg.group}' - -"
 | 
						|
    ];
 | 
						|
 | 
						|
    systemd.services.ergo = {
 | 
						|
      description = "ergo server";
 | 
						|
      wantedBy = [ "multi-user.target" ];
 | 
						|
      after = [ "network-online.target" ];
 | 
						|
      serviceConfig = {
 | 
						|
        User = cfg.user;
 | 
						|
        Group = cfg.group;
 | 
						|
        ExecStart = ''${pkgs.ergo}/bin/ergo \
 | 
						|
                      ${optionalString (!cfg.testnet)
 | 
						|
                      "--mainnet"} \
 | 
						|
                      -c ${configFile}'';
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    networking.firewall = mkIf cfg.openFirewall {
 | 
						|
      allowedTCPPorts = [ cfg.listen.port ] ++ [ cfg.api.listen.port ];
 | 
						|
    };
 | 
						|
 | 
						|
    users.users.${cfg.user} = {
 | 
						|
      name = cfg.user;
 | 
						|
      group = cfg.group;
 | 
						|
      description = "Ergo daemon user";
 | 
						|
      home = cfg.dataDir;
 | 
						|
      isSystemUser = true;
 | 
						|
    };
 | 
						|
 | 
						|
    users.groups.${cfg.group} = {};
 | 
						|
 | 
						|
  };
 | 
						|
}
 |