77 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
		
		
			
		
	
	
			77 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
|   | let  | ||
|  |   certs = import ./common/acme/server/snakeoil-certs.nix; | ||
|  | in | ||
|  | import ./make-test-python.nix { | ||
|  |   name = "postfix"; | ||
|  | 
 | ||
|  |   machine = { pkgs, ... }: { | ||
|  |     imports = [ common/user-account.nix ]; | ||
|  |     services.postfix = { | ||
|  |       enable = true; | ||
|  |       enableSubmission = true; | ||
|  |       enableSubmissions = true; | ||
|  |       sslCACert = certs.ca.cert; | ||
|  |       sslCert = certs."acme.test".cert; | ||
|  |       sslKey = certs."acme.test".key; | ||
|  |       submissionsOptions = { | ||
|  |           smtpd_sasl_auth_enable = "yes"; | ||
|  |           smtpd_client_restrictions = "permit"; | ||
|  |           milter_macro_daemon_name = "ORIGINATING"; | ||
|  |       }; | ||
|  |     }; | ||
|  | 
 | ||
|  |     security.pki.certificateFiles = [ | ||
|  |       certs.ca.cert | ||
|  |     ]; | ||
|  | 
 | ||
|  |     networking.extraHosts = ''
 | ||
|  |       127.0.0.1 acme.test | ||
|  |     '';
 | ||
|  | 
 | ||
|  |     environment.systemPackages = let | ||
|  |       sendTestMail = pkgs.writeScriptBin "send-testmail" ''
 | ||
|  |         #!${pkgs.python3.interpreter} | ||
|  |         import smtplib | ||
|  | 
 | ||
|  |         with smtplib.SMTP('acme.test') as smtp: | ||
|  |           smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test\n\nTest data.') | ||
|  |           smtp.quit() | ||
|  |       '';
 | ||
|  | 
 | ||
|  |       sendTestMailStarttls = pkgs.writeScriptBin "send-testmail-starttls" ''
 | ||
|  |         #!${pkgs.python3.interpreter} | ||
|  |         import smtplib | ||
|  |         import ssl | ||
|  | 
 | ||
|  |         ctx = ssl.create_default_context() | ||
|  | 
 | ||
|  |         with smtplib.SMTP('acme.test') as smtp: | ||
|  |           smtp.ehlo() | ||
|  |           smtp.starttls(context=ctx) | ||
|  |           smtp.ehlo() | ||
|  |           smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test STARTTLS\n\nTest data.') | ||
|  |           smtp.quit() | ||
|  |       '';
 | ||
|  | 
 | ||
|  |       sendTestMailSmtps = pkgs.writeScriptBin "send-testmail-smtps" ''
 | ||
|  |         #!${pkgs.python3.interpreter} | ||
|  |         import smtplib | ||
|  |         import ssl | ||
|  | 
 | ||
|  |         ctx = ssl.create_default_context() | ||
|  | 
 | ||
|  |         with smtplib.SMTP_SSL(host='acme.test', context=ctx) as smtp: | ||
|  |           smtp.sendmail('root@localhost', 'alice@localhost', 'Subject: Test SMTPS\n\nTest data.') | ||
|  |           smtp.quit() | ||
|  |       '';
 | ||
|  |     in [ sendTestMail sendTestMailStarttls sendTestMailSmtps ]; | ||
|  |   }; | ||
|  | 
 | ||
|  |   testScript = ''
 | ||
|  |     machine.wait_for_unit("postfix.service") | ||
|  |     machine.succeed("send-testmail") | ||
|  |     machine.succeed("send-testmail-starttls") | ||
|  |     machine.succeed("send-testmail-smtps") | ||
|  |   '';
 | ||
|  | } |