mastus: radicale
This commit is contained in:
		
							parent
							
								
									ded5ae9b68
								
							
						
					
					
						commit
						680eaf6043
					
				@ -12,6 +12,7 @@
 | 
				
			|||||||
      ./gogs.nix
 | 
					      ./gogs.nix
 | 
				
			||||||
      ./letsencrypt.nix
 | 
					      ./letsencrypt.nix
 | 
				
			||||||
      ./blog.nix
 | 
					      ./blog.nix
 | 
				
			||||||
 | 
					      ./radicale.nix
 | 
				
			||||||
    ];
 | 
					    ];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  boot.loader.grub.enable = true;
 | 
					  boot.loader.grub.enable = true;
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										77
									
								
								mastus/radicale.nix
									
									
									
									
									
										Normal file
									
								
							
							
								
								
								
								
								
									
									
								
							
						
						
									
										77
									
								
								mastus/radicale.nix
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,77 @@
 | 
				
			|||||||
 | 
					{ config, pkgs, ... }:
 | 
				
			||||||
 | 
					let
 | 
				
			||||||
 | 
					  radicalePort = 8002;
 | 
				
			||||||
 | 
					in
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					  services.radicale = {
 | 
				
			||||||
 | 
					    enable = true;
 | 
				
			||||||
 | 
					    config = ''
 | 
				
			||||||
 | 
					      [server]
 | 
				
			||||||
 | 
					      hosts = 127.0.0.1:${toString radicalePort}
 | 
				
			||||||
 | 
					      ssl = false
 | 
				
			||||||
 | 
					      dns_lookup = false
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      [storage]
 | 
				
			||||||
 | 
					      filesystem_folder = /var/lib/radicale/storage
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      [auth]
 | 
				
			||||||
 | 
					      type = IMAP
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      [rights]
 | 
				
			||||||
 | 
					      type = owner_only
 | 
				
			||||||
 | 
					    '';
 | 
				
			||||||
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  security.acme.certs."gebner.org".extraDomains."radicale.gebner.org" = null;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  services.nginx.httpConfig = ''
 | 
				
			||||||
 | 
					    server {
 | 
				
			||||||
 | 
					      listen [::]:80;
 | 
				
			||||||
 | 
					      listen 80;
 | 
				
			||||||
 | 
					      server_name radicale.gebner.org;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      location /.well-known/acme-challenge {
 | 
				
			||||||
 | 
					        default_type text/plain;
 | 
				
			||||||
 | 
					        alias /var/lib/acme/www/.well-known/acme-challenge;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      location / {
 | 
				
			||||||
 | 
					        rewrite ^(.*) https://$host$1 permanent;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    server {
 | 
				
			||||||
 | 
					      listen [::]:443;
 | 
				
			||||||
 | 
					      listen 443;
 | 
				
			||||||
 | 
					      server_name radicale.gebner.org;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      ssl on;
 | 
				
			||||||
 | 
					      ssl_certificate_key /var/lib/acme/gebner.org/key.pem;
 | 
				
			||||||
 | 
					      ssl_certificate /var/lib/acme/gebner.org/fullchain.pem;
 | 
				
			||||||
 | 
					      ssl_dhparam /etc/nginx/dhparam.pem;
 | 
				
			||||||
 | 
					      ssl_protocols TLSv1.1 TLSv1.2;
 | 
				
			||||||
 | 
					      ssl_ciphers 'ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-GCM-SHA384:DHE-RSA-AES128-GCM-SHA256:DHE-DSS-AES128-GCM-SHA256:kEDH+AESGCM:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA:ECDHE-ECDSA-AES128-SHA:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA:ECDHE-ECDSA-AES256-SHA:DHE-RSA-AES128-SHA256:DHE-RSA-AES128-SHA:DHE-DSS-AES128-SHA256:DHE-RSA-AES256-SHA256:DHE-DSS-AES256-SHA:DHE-RSA-AES256-SHA:!aNULL:!eNULL:!EXPORT:!DES:!RC4:!3DES:!MD5:!PSK';
 | 
				
			||||||
 | 
					      ssl_prefer_server_ciphers on;
 | 
				
			||||||
 | 
					      add_header Strict-Transport-Security max-age=15768000;
 | 
				
			||||||
 | 
					      ssl_stapling on;
 | 
				
			||||||
 | 
					      ssl_stapling_verify on;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      location / {
 | 
				
			||||||
 | 
					        proxy_set_header X-Real-IP $remote_addr;
 | 
				
			||||||
 | 
					        proxy_set_header X-Forwarded-Host $host;
 | 
				
			||||||
 | 
					        proxy_set_header X-Forwarded-Server $host;
 | 
				
			||||||
 | 
					        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
 | 
				
			||||||
 | 
					        proxy_set_header Host $http_host;
 | 
				
			||||||
 | 
					        proxy_redirect off;
 | 
				
			||||||
 | 
					        proxy_buffering off;
 | 
				
			||||||
 | 
					        proxy_pass http://gogs;
 | 
				
			||||||
 | 
					        client_max_body_size 30M;
 | 
				
			||||||
 | 
					        break;
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    upstream radicale {
 | 
				
			||||||
 | 
					      server 127.0.0.1:${toString radicalePort};
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					  '';
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -3,7 +3,7 @@ let
 | 
				
			|||||||
  configuration = { config, pkgs, ... }: {
 | 
					  configuration = { config, pkgs, ... }: {
 | 
				
			||||||
    imports = [ ./configuration.nix ];
 | 
					    imports = [ ./configuration.nix ];
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    users.extraUsers.gebner.password = "";
 | 
					    users.extraUsers.gebner.password = "password";
 | 
				
			||||||
    users.users.root.password = "";
 | 
					    users.users.root.password = "";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    boot.enableContainers = true;
 | 
					    boot.enableContainers = true;
 | 
				
			||||||
@ -21,7 +21,7 @@ let
 | 
				
			|||||||
      '';
 | 
					      '';
 | 
				
			||||||
    };
 | 
					    };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    environment.systemPackages = with pkgs; [ elinks ];
 | 
					    environment.systemPackages = with pkgs; [ elinks carddav-util ];
 | 
				
			||||||
  };
 | 
					  };
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  nixos = import <nixpkgs/nixos> { configuration = configuration; };
 | 
					  nixos = import <nixpkgs/nixos> { configuration = configuration; };
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
		Reference in New Issue
	
	Block a user