forked from jan-leila/nix-config
		
	feat: installed lidarr
This commit is contained in:
		
							parent
							
								
									62bb650878
								
							
						
					
					
						commit
						5ccfe1a337
					
				
					 6 changed files with 82 additions and 1 deletions
				
			
		|  | @ -362,6 +362,10 @@ | ||||||
|       enable = true; |       enable = true; | ||||||
|       openFirewall = true; |       openFirewall = true; | ||||||
|     }; |     }; | ||||||
|  |     lidarr = { | ||||||
|  |       enable = true; | ||||||
|  |       openFirewall = true; | ||||||
|  |     }; | ||||||
|     jackett = { |     jackett = { | ||||||
|       enable = true; |       enable = true; | ||||||
|       openFirewall = true; |       openFirewall = true; | ||||||
|  |  | ||||||
|  | @ -12,14 +12,15 @@ | ||||||
|     ./forgejo |     ./forgejo | ||||||
|     ./home-assistant |     ./home-assistant | ||||||
|     ./immich |     ./immich | ||||||
|  |     ./jackett | ||||||
|     ./jellyfin |     ./jellyfin | ||||||
|  |     ./lidarr | ||||||
|     ./panoramax |     ./panoramax | ||||||
|     ./paperless |     ./paperless | ||||||
|     ./qbittorent.nix |     ./qbittorent.nix | ||||||
|     ./radarr |     ./radarr | ||||||
|     ./searx |     ./searx | ||||||
|     ./sonarr |     ./sonarr | ||||||
|     ./jackett |  | ||||||
|     ./wyoming.nix |     ./wyoming.nix | ||||||
|   ]; |   ]; | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								modules/nixos-modules/server/lidarr/default.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										6
									
								
								modules/nixos-modules/server/lidarr/default.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,6 @@ | ||||||
|  | {...}: { | ||||||
|  |   imports = [ | ||||||
|  |     ./proxy.nix | ||||||
|  |     ./impermanence.nix | ||||||
|  |   ]; | ||||||
|  | } | ||||||
							
								
								
									
										26
									
								
								modules/nixos-modules/server/lidarr/impermanence.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								modules/nixos-modules/server/lidarr/impermanence.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,26 @@ | ||||||
|  | { | ||||||
|  |   lib, | ||||||
|  |   config, | ||||||
|  |   ... | ||||||
|  | }: let | ||||||
|  |   lidarr_data_directory = "/var/lib/lidarr/.config/Lidarr"; | ||||||
|  | in { | ||||||
|  |   config = lib.mkIf (config.services.lidarr.enable && config.host.impermanence.enable) { | ||||||
|  |     assertions = [ | ||||||
|  |       { | ||||||
|  |         assertion = config.services.lidarr.dataDir == lidarr_data_directory; | ||||||
|  |         message = "lidarr data directory does not match persistence"; | ||||||
|  |       } | ||||||
|  |     ]; | ||||||
|  | 
 | ||||||
|  |     environment.persistence."/persist/system/root" = { | ||||||
|  |       directories = [ | ||||||
|  |         { | ||||||
|  |           directory = lidarr_data_directory; | ||||||
|  |           user = "lidarr"; | ||||||
|  |           group = "lidarr"; | ||||||
|  |         } | ||||||
|  |       ]; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | } | ||||||
							
								
								
									
										28
									
								
								modules/nixos-modules/server/lidarr/proxy.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								modules/nixos-modules/server/lidarr/proxy.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,28 @@ | ||||||
|  | { | ||||||
|  |   lib, | ||||||
|  |   config, | ||||||
|  |   ... | ||||||
|  | }: { | ||||||
|  |   options.services.lidarr = { | ||||||
|  |     subdomain = lib.mkOption { | ||||||
|  |       type = lib.types.nullOr lib.types.str; | ||||||
|  |       default = null; | ||||||
|  |       description = "Subdomain for reverse proxy. If null, service will be local only."; | ||||||
|  |     }; | ||||||
|  |     extraSubdomains = lib.mkOption { | ||||||
|  |       type = lib.types.listOf lib.types.str; | ||||||
|  |       default = []; | ||||||
|  |       description = "Extra subdomains for reverse proxy."; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   config = lib.mkIf (config.services.lidarr.enable && config.services.lidarr.subdomain != null) { | ||||||
|  |     host.reverse_proxy.subdomains.lidarr = { | ||||||
|  |       subdomain = config.services.lidarr.subdomain; | ||||||
|  |       extraSubdomains = config.services.lidarr.extraSubdomains; | ||||||
|  |       target = "http://127.0.0.1:8686"; | ||||||
|  |       websockets.enable = true; | ||||||
|  |       forwardHeaders.enable = true; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  | @ -29,6 +29,7 @@ | ||||||
|     radarr = 2014; |     radarr = 2014; | ||||||
|     sonarr = 2015; |     sonarr = 2015; | ||||||
|     bazarr = 2016; |     bazarr = 2016; | ||||||
|  |     lidarr = 2017; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   gids = { |   gids = { | ||||||
|  | @ -50,6 +51,7 @@ | ||||||
|     radarr = 2014; |     radarr = 2014; | ||||||
|     sonarr = 2015; |     sonarr = 2015; | ||||||
|     bazarr = 2016; |     bazarr = 2016; | ||||||
|  |     lidarr = 2017; | ||||||
|   }; |   }; | ||||||
| 
 | 
 | ||||||
|   users = config.users.users; |   users = config.users.users; | ||||||
|  | @ -221,6 +223,12 @@ in { | ||||||
|             isSystemUser = true; |             isSystemUser = true; | ||||||
|             group = config.users.users.bazarr.name; |             group = config.users.users.bazarr.name; | ||||||
|           }; |           }; | ||||||
|  | 
 | ||||||
|  |           lidarr = { | ||||||
|  |             uid = lib.mkForce uids.lidarr; | ||||||
|  |             isSystemUser = true; | ||||||
|  |             group = config.users.users.lidarr.name; | ||||||
|  |           }; | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
|         groups = { |         groups = { | ||||||
|  | @ -261,6 +269,7 @@ in { | ||||||
|               users.radarr.name |               users.radarr.name | ||||||
|               users.sonarr.name |               users.sonarr.name | ||||||
|               users.bazarr.name |               users.bazarr.name | ||||||
|  |               users.lidarr.name | ||||||
|               leyla |               leyla | ||||||
|               eve |               eve | ||||||
|               ivy |               ivy | ||||||
|  | @ -365,6 +374,13 @@ in { | ||||||
|               users.bazarr.name |               users.bazarr.name | ||||||
|             ]; |             ]; | ||||||
|           }; |           }; | ||||||
|  | 
 | ||||||
|  |           lidarr = { | ||||||
|  |             gid = lib.mkForce gids.lidarr; | ||||||
|  |             members = [ | ||||||
|  |               users.lidarr.name | ||||||
|  |             ]; | ||||||
|  |           }; | ||||||
|         }; |         }; | ||||||
|       }; |       }; | ||||||
|     } |     } | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue