feat(ops/nixos): Add module for running a Quassel daemon
The upstream module is not flexible enough for my needs, so I made my own. Change-Id: Ie9f786da7eb8c878e0782b07a075c064ad8cd253 Reviewed-on: https://cl.tvl.fyi/c/depot/+/953 Tested-by: BuildkiteCI Reviewed-by: glittershark <grfn@gws.fyi>
This commit is contained in:
		
							parent
							
								
									df80e19bf5
								
							
						
					
					
						commit
						449afaa384
					
				
					 1 changed files with 76 additions and 0 deletions
				
			
		
							
								
								
									
										76
									
								
								ops/nixos/quassel.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								ops/nixos/quassel.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,76 @@ | |||
| # A more modern module for running Quassel. | ||||
| { config, lib, pkgs, ... }: | ||||
| 
 | ||||
| let | ||||
|   cfg = config.services.depot.quassel; | ||||
|   quasselDaemon = pkgs.quassel.override { | ||||
|     monolithic = false; | ||||
|     enableDaemon = true; | ||||
|     withKDE = false; | ||||
|   }; | ||||
| in { | ||||
|   options.services.depot.quassel = with lib; { | ||||
|     enable = mkEnableOption "Quassel IRC daemon"; | ||||
| 
 | ||||
|     acmeHost = mkOption { | ||||
|       description = "ACME host to use for the Quassel TLS certificate"; | ||||
|       type = lib.types.str; | ||||
|     }; | ||||
| 
 | ||||
|     bindAddresses = mkOption { | ||||
|       description = "Addresses Quassel will bind to/listen on"; | ||||
|       default = [ "127.0.0.1" ]; | ||||
|     }; | ||||
| 
 | ||||
|     logLevel = mkOption { | ||||
|       description = "Log level for Quassel Core"; | ||||
|       default = "Info"; | ||||
|       type = lib.types.enum [ | ||||
|         "Debug" | ||||
|         "Info" | ||||
|         "Warning" | ||||
|         "Error" | ||||
|       ]; | ||||
|     }; | ||||
| 
 | ||||
|     port = mkOption { | ||||
|       default = 6698; | ||||
|       description = '' | ||||
|         The port number the Quassel daemon will be listening to. | ||||
|       ''; | ||||
|     }; | ||||
|   }; | ||||
| 
 | ||||
|   config = with lib; mkIf cfg.enable { | ||||
|     systemd.services.quassel = { | ||||
|       description = "Quassel IRC daemon"; | ||||
|       wantedBy = [ "multi-user.target" ]; | ||||
| 
 | ||||
|       script = concatStringsSep " " [ | ||||
|         "${quasselDaemon}/bin/quasselcore" | ||||
|         "--listen=${concatStringsSep "," cfg.bindAddresses}" | ||||
|         "--port=${toString cfg.port}" | ||||
|         "--configdir=/var/lib/quassel" | ||||
|         "--require-ssl" | ||||
|         "--ssl-cert=/var/lib/acme/${cfg.acmeHost}/full.pem" | ||||
|         "--loglevel=${cfg.logLevel}" | ||||
|       ]; | ||||
| 
 | ||||
|       serviceConfig = { | ||||
|         Restart = "always"; | ||||
|         User = "quassel"; | ||||
|         Group = "quassel"; | ||||
|         StateDirectory = "quassel"; | ||||
|       }; | ||||
|     }; | ||||
| 
 | ||||
|     users = { | ||||
|       users.quassel = { | ||||
|         isNormalUser = false; | ||||
|         group = "quassel"; | ||||
|       }; | ||||
| 
 | ||||
|       groups.quassel = {}; | ||||
|     }; | ||||
|   }; | ||||
| } | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue