57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{ config, lib, pkgs, ... }:
 | 
						|
 | 
						|
let
 | 
						|
  cfg = config.services.lorri;
 | 
						|
  socketPath = "lorri/daemon.socket";
 | 
						|
in {
 | 
						|
  options = {
 | 
						|
    services.lorri = {
 | 
						|
      enable = lib.mkOption {
 | 
						|
        default = false;
 | 
						|
        type = lib.types.bool;
 | 
						|
        description = ''
 | 
						|
          Enables the daemon for `lorri`, a nix-shell replacement for project
 | 
						|
          development. The socket-activated daemon starts on the first request
 | 
						|
          issued by the `lorri` command.
 | 
						|
        '';
 | 
						|
      };
 | 
						|
      package = lib.mkOption {
 | 
						|
        default = pkgs.lorri;
 | 
						|
        type = lib.types.package;
 | 
						|
        description = ''
 | 
						|
          The lorri package to use.
 | 
						|
        '';
 | 
						|
        defaultText = lib.literalExample "pkgs.lorri";
 | 
						|
        example = lib.literalExample "pkgs.lorri";
 | 
						|
      };
 | 
						|
    };
 | 
						|
  };
 | 
						|
 | 
						|
  config = lib.mkIf cfg.enable {
 | 
						|
    systemd.user.sockets.lorri = {
 | 
						|
      description = "Socket for Lorri Daemon";
 | 
						|
      wantedBy = [ "sockets.target" ];
 | 
						|
      socketConfig = {
 | 
						|
        ListenStream = "%t/${socketPath}";
 | 
						|
        RuntimeDirectory = "lorri";
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    systemd.user.services.lorri = {
 | 
						|
      description = "Lorri Daemon";
 | 
						|
      requires = [ "lorri.socket" ];
 | 
						|
      after = [ "lorri.socket" ];
 | 
						|
      path = with pkgs; [ config.nix.package git gnutar gzip ];
 | 
						|
      serviceConfig = {
 | 
						|
        ExecStart = "${cfg.package}/bin/lorri daemon";
 | 
						|
        PrivateTmp = true;
 | 
						|
        ProtectSystem = "strict";
 | 
						|
        ProtectHome = "read-only";
 | 
						|
        Restart = "on-failure";
 | 
						|
      };
 | 
						|
    };
 | 
						|
 | 
						|
    environment.systemPackages = [ cfg.package ];
 | 
						|
  };
 | 
						|
}
 |