Compare commits
	
		
			2 commits
		
	
	
		
			2007c9ce76
			...
			afcc959bf9
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| afcc959bf9 | |||
| 7b69040928 | 
					 6 changed files with 130 additions and 15 deletions
				
			
		|  | @ -18,6 +18,7 @@ | ||||||
|     ./services/conduit.nix |     ./services/conduit.nix | ||||||
|     ./services/foundryvtt.nix |     ./services/foundryvtt.nix | ||||||
|     ./services/gitea.nix |     ./services/gitea.nix | ||||||
|  |     ./services/metrics.nix | ||||||
|     ./services/nextcloud.nix |     ./services/nextcloud.nix | ||||||
|     ./services/webserver.nix |     ./services/webserver.nix | ||||||
|     ./services/wireguard.nix |     ./services/wireguard.nix | ||||||
|  |  | ||||||
							
								
								
									
										86
									
								
								configuration/services/metrics.nix
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								configuration/services/metrics.nix
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,86 @@ | ||||||
|  | { | ||||||
|  |   config, | ||||||
|  |   pkgs, | ||||||
|  |   lib, | ||||||
|  |   ... | ||||||
|  | }: let | ||||||
|  |   domain = "metrics.${config.services.nginx.domain}"; | ||||||
|  |   yaml = pkgs.formats.yaml {}; | ||||||
|  | in { | ||||||
|  |   services.victoriametrics.enable = true; | ||||||
|  | 
 | ||||||
|  |   services.grafana = { | ||||||
|  |     enable = true; | ||||||
|  |     settings = { | ||||||
|  |       server.http_port = 3001; # Default overlaps with gitea | ||||||
|  | 
 | ||||||
|  |       security = { | ||||||
|  |         admin_user = "tlater"; | ||||||
|  |         admin_password = "$__file{${config.sops.secrets."grafana/adminPassword".path}}"; | ||||||
|  |         secret_key = "$__file{${config.sops.secrets."grafana/secretKey".path}}"; | ||||||
|  |         cookie_secure = true; | ||||||
|  |         cookie_samesite = "strict"; | ||||||
|  |         content_security_policy = true; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       database = { | ||||||
|  |         user = "grafana"; | ||||||
|  |         name = "grafana"; | ||||||
|  |         type = "postgres"; | ||||||
|  |         host = "/run/postgresql"; | ||||||
|  |       }; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|  |     provision = { | ||||||
|  |       enable = true; | ||||||
|  | 
 | ||||||
|  |       datasources.settings.datasources = [ | ||||||
|  |         { | ||||||
|  |           name = "Victoriametrics - tlater.net"; | ||||||
|  |           url = "http://localhost:8428"; | ||||||
|  |           type = "prometheus"; | ||||||
|  |         } | ||||||
|  |       ]; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   services.prometheus.exporters = { | ||||||
|  |     node = { | ||||||
|  |       enable = true; | ||||||
|  |       enabledCollectors = ["systemd"]; | ||||||
|  |       listenAddress = "127.0.0.1"; | ||||||
|  |     }; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   systemd.services.export-to-victoriametrics = let | ||||||
|  |     promscrape = yaml.generate "prometheus.yml" { | ||||||
|  |       scrape_configs = [ | ||||||
|  |         { | ||||||
|  |           job_name = "tlater.net"; | ||||||
|  |           static_configs = [ | ||||||
|  |             { | ||||||
|  |               targets = | ||||||
|  |                 lib.mapAttrsToList (name: exporter: "${exporter.listenAddress}:${toString exporter.port}") | ||||||
|  |                 (lib.filterAttrs (name: exporter: (builtins.isAttrs exporter) && exporter.enable) | ||||||
|  |                   config.services.prometheus.exporters); | ||||||
|  |             } | ||||||
|  |           ]; | ||||||
|  |         } | ||||||
|  |       ]; | ||||||
|  |     }; | ||||||
|  |   in { | ||||||
|  |     enable = true; | ||||||
|  |     path = [pkgs.victoriametrics]; | ||||||
|  |     wantedBy = ["multi-user.target"]; | ||||||
|  |     script = "vmagent -promscrape.config=${promscrape} -remoteWrite.url=http://localhost:8428/api/v1/write"; | ||||||
|  |   }; | ||||||
|  | 
 | ||||||
|  |   services.nginx.virtualHosts."${domain}" = { | ||||||
|  |     forceSSL = true; | ||||||
|  |     enableACME = true; | ||||||
|  |     extraConfig = '' | ||||||
|  |       add_header Strict-Transport-Security "max-age=15552000; includeSubDomains" always; | ||||||
|  |     ''; | ||||||
|  |     locations."/".proxyPass = "http://localhost:3001"; | ||||||
|  |   }; | ||||||
|  | } | ||||||
|  | @ -16,6 +16,12 @@ | ||||||
|     # that operation needs to be performed manually on the system as |     # that operation needs to be performed manually on the system as | ||||||
|     # well. |     # well. | ||||||
|     ensureUsers = [ |     ensureUsers = [ | ||||||
|  |       { | ||||||
|  |         name = "grafana"; | ||||||
|  |         ensurePermissions = { | ||||||
|  |           "DATABASE grafana" = "ALL PRIVILEGES"; | ||||||
|  |         }; | ||||||
|  |       } | ||||||
|       { |       { | ||||||
|         name = "nextcloud"; |         name = "nextcloud"; | ||||||
|         ensurePermissions = { |         ensurePermissions = { | ||||||
|  | @ -25,6 +31,7 @@ | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
|     ensureDatabases = [ |     ensureDatabases = [ | ||||||
|  |       "grafana" | ||||||
|       "nextcloud" |       "nextcloud" | ||||||
|     ]; |     ]; | ||||||
|   }; |   }; | ||||||
|  |  | ||||||
|  | @ -3,28 +3,37 @@ | ||||||
|     defaultSopsFile = ../keys/production.yaml; |     defaultSopsFile = ../keys/production.yaml; | ||||||
| 
 | 
 | ||||||
|     secrets = { |     secrets = { | ||||||
|  |       # Grafana | ||||||
|  |       "grafana/adminPassword" = { | ||||||
|  |         owner = "grafana"; | ||||||
|  |         group = "grafana"; | ||||||
|  |       }; | ||||||
|  |       "grafana/secretKey" = { | ||||||
|  |         owner = "grafana"; | ||||||
|  |         group = "grafana"; | ||||||
|  |       }; | ||||||
|  | 
 | ||||||
|  |       # Heisenbridge | ||||||
|  |       "heisenbridge/as-token" = {}; | ||||||
|  |       "heisenbridge/hs-token" = {}; | ||||||
|  | 
 | ||||||
|  |       # Nextcloud | ||||||
|       "nextcloud/tlater" = { |       "nextcloud/tlater" = { | ||||||
|         owner = "nextcloud"; |         owner = "nextcloud"; | ||||||
|         group = "nextcloud"; |         group = "nextcloud"; | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|       "steam/tlater" = {}; |       # Restic | ||||||
| 
 |  | ||||||
|       "heisenbridge/as-token" = {}; |  | ||||||
|       "heisenbridge/hs-token" = {}; |  | ||||||
| 
 |  | ||||||
|       "wireguard/server-key" = { |  | ||||||
|         owner = "root"; |  | ||||||
|         group = "systemd-network"; |  | ||||||
|         mode = "0440"; |  | ||||||
|       }; |  | ||||||
| 
 |  | ||||||
|       "restic/local-backups" = { |       "restic/local-backups" = { | ||||||
|         owner = "root"; |         owner = "root"; | ||||||
|         group = "backup"; |         group = "backup"; | ||||||
|         mode = "0440"; |         mode = "0440"; | ||||||
|       }; |       }; | ||||||
| 
 | 
 | ||||||
|  |       # Steam | ||||||
|  |       "steam/tlater" = {}; | ||||||
|  | 
 | ||||||
|  |       # Turn | ||||||
|       "turn/env" = {}; |       "turn/env" = {}; | ||||||
|       "turn/secret" = { |       "turn/secret" = { | ||||||
|         owner = "turnserver"; |         owner = "turnserver"; | ||||||
|  | @ -35,6 +44,13 @@ | ||||||
|       "turn/ssl-cert" = { |       "turn/ssl-cert" = { | ||||||
|         owner = "turnserver"; |         owner = "turnserver"; | ||||||
|       }; |       }; | ||||||
|  | 
 | ||||||
|  |       # Wireguard | ||||||
|  |       "wireguard/server-key" = { | ||||||
|  |         owner = "root"; | ||||||
|  |         group = "systemd-network"; | ||||||
|  |         mode = "0440"; | ||||||
|  |       }; | ||||||
|     }; |     }; | ||||||
|   }; |   }; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | @ -1,3 +1,5 @@ | ||||||
|  | metrics: | ||||||
|  |     tlater: ENC[AES256_GCM,data:4nB0H45nlongb0x1OOKzNXIk96PovZ7OwENovnBZUwMl9ncfYwTHT30OlLsPA75w1govH0jyBRkn1Pe/qHzY1Zt53B8=,iv:AfZ4So6HnjOXzqiHM3WpOsQZJs2CEckuxGfyDxc4TNA=,tag:fIXOKJSVDLpLbiLd2zAu9w==,type:str] | ||||||
| nextcloud: | nextcloud: | ||||||
|     tlater: ENC[AES256_GCM,data:zNsPm4uFaIRe3LjcwmayRg==,iv:5wam6bP5zP708jC9UrLV0s8qspl3Pm4fPzbMFYBUyPQ=,tag:apnJUMeJwMn9q0NhO4ptmA==,type:str] |     tlater: ENC[AES256_GCM,data:zNsPm4uFaIRe3LjcwmayRg==,iv:5wam6bP5zP708jC9UrLV0s8qspl3Pm4fPzbMFYBUyPQ=,tag:apnJUMeJwMn9q0NhO4ptmA==,type:str] | ||||||
| steam: | steam: | ||||||
|  | @ -21,8 +23,8 @@ sops: | ||||||
|     azure_kv: [] |     azure_kv: [] | ||||||
|     hc_vault: [] |     hc_vault: [] | ||||||
|     age: [] |     age: [] | ||||||
|     lastmodified: "2023-09-23T18:55:44Z" |     lastmodified: "2023-09-25T00:42:25Z" | ||||||
|     mac: ENC[AES256_GCM,data:psqgXozY9L7nduZ11GF+mbIrZ4RUySqBixkWL5z0cYeoLA3URb/dr028LCmNgQS9l8aJVsjVkyLBJIU/8wmiUNqRy/VI5iqV5mu+sxXhUVwFL0dAAWP1lOKwwT5uGK89/ioqkphgzuWD37vGe2vYddKkJF0M+zlz12fqkMjaisU=,iv:UyRoJbfuGU3K/Mp5DQ1kY0Z+nKSSo46BGNAcxt+vAvc=,tag:HkP6+qxQ8J/xAYJXYoG/6g==,type:str] |     mac: ENC[AES256_GCM,data:28o/elUKslgn5auYfr34N9fE7B6EoZ6njL6yT0emjfoTjsCADJOLcHfUDNWb3AMP3Z5e/w8WsxI7MpwuwUXRvZ6u9Kui1IBcQu/V6GEzpBVw7JkLHZvsUFHOj/uEBcPvON7pKfXtG3vdH8FF1cxeenFm1Z0cX4C0WrNaxumGknA=,iv:GYK0/JZtCkbVorus+9HQbtxAnIXviiNkoC9dMqTHflM=,tag:R3N5hf/UV2nqyOI50Imr6g==,type:str] | ||||||
|     pgp: |     pgp: | ||||||
|         - created_at: "2022-10-12T00:46:51Z" |         - created_at: "2022-10-12T00:46:51Z" | ||||||
|           enc: | |           enc: | | ||||||
|  |  | ||||||
|  | @ -1,3 +1,6 @@ | ||||||
|  | grafana: | ||||||
|  |     adminPassword: ENC[AES256_GCM,data:dYfaxUpQpzA=,iv:j5wSem8C5+V4c5qRzXQJhsU7/FOtpvrnaEyFBmW6zJ4=,tag:oc8n3TkEbjF2gjuOobZuLA==,type:str] | ||||||
|  |     secretKey: ENC[AES256_GCM,data:Atruvh2MsNY=,iv:y2MaCUCEzGIydHp6G0DJHfk289S1is0twKm2oUYwDhM=,tag:nAWeg+YqaYqk6k22oBkAhQ==,type:str] | ||||||
| nextcloud: | nextcloud: | ||||||
|     tlater: ENC[AES256_GCM,data:91kDcO4hpng=,iv:ayuILRmRru4ZxTCur9H2xHuLjkDzwPdS/4lEog/tesU=,tag:qYhJxnNDcCwUM7xe7Tlcjw==,type:str] |     tlater: ENC[AES256_GCM,data:91kDcO4hpng=,iv:ayuILRmRru4ZxTCur9H2xHuLjkDzwPdS/4lEog/tesU=,tag:qYhJxnNDcCwUM7xe7Tlcjw==,type:str] | ||||||
| steam: | steam: | ||||||
|  | @ -21,8 +24,8 @@ sops: | ||||||
|     azure_kv: [] |     azure_kv: [] | ||||||
|     hc_vault: [] |     hc_vault: [] | ||||||
|     age: [] |     age: [] | ||||||
|     lastmodified: "2023-09-22T21:07:02Z" |     lastmodified: "2023-10-01T23:00:06Z" | ||||||
|     mac: ENC[AES256_GCM,data:gItC41S8MInLmikdH1okhPs+FVf8sCF/iQeJ5reigBunHkOngoc6nOFANyAcNZETszzhgTLXXtmVNEjW46v6K7D6nmoi/zwpedUxwzMwDC5I28VTMDHVMAThYSGtdo6kig8i2pi8rzEQd1DStxMv3TWML5y6DDTlFsd3lfudaHA=,iv:zXebvIVPR76GwUhpactwRgF/eEmx2OBkT18E8lkwzRA=,tag:6HyISACbFCGlpIIgkFeA/A==,type:str] |     mac: ENC[AES256_GCM,data:oEJ3Nwlx5YTVLvWa12On1O+LakU42rsAD1wD52MTlzuwgyRZ/g49pL6pQiL6S0uE7wC0EOqOvg2pCtDxxHe3WNjEpcxnWWftdEjw2laLnBuOqduQmVW+Sn23SzoRkl7PwOH1jTQHzRyciyYkJT1/vCNnbNdKg1eqnbpxPysg6/A=,iv:dC8eNEXhzC8Nx1rfXQdDKtlO01QhyW9ncNFEK/yakrg=,tag:vQ4AW/mqnA9Vs5NNzFsYWQ==,type:str] | ||||||
|     pgp: |     pgp: | ||||||
|         - created_at: "2022-10-12T16:48:23Z" |         - created_at: "2022-10-12T16:48:23Z" | ||||||
|           enc: | |           enc: | | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue