From 85515b1338726b424aea63a19c71d02f1a2408b4 Mon Sep 17 00:00:00 2001 From: "Aleksandar N. Kostadinov" Date: Wed, 5 Jan 2022 00:46:56 +0200 Subject: [PATCH] optional STARTTLS support fixes #142 --- lib/mail_catcher.rb | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) diff --git a/lib/mail_catcher.rb b/lib/mail_catcher.rb index a1fd54b3..05682433 100644 --- a/lib/mail_catcher.rb +++ b/lib/mail_catcher.rb @@ -106,7 +106,19 @@ def parse! arguments=ARGV, defaults=@defaults options[:smtp_port] = port end - parser.on("--http-ip IP", "Set the ip address of the http server") do |ip| + parser.on("--smtp-starttls", "Enable STARTTLS for the smtp server") do + options[:smtp_starttls] = true + end + + parser.on("--smtp-private-key PATH", String, "Set the private key file for the smtp server") do |path| + options[:smtp_private_key_file] = path + end + + parser.on("--smtp-cert PATH", String, "Set the certificate of the smtp server") do |path| + options[:smtp_cert_chain_path] = path + end + + parser.on("--http-ip IP", String, "Set the ip address of the http server") do |ip| options[:http_ip] = ip end @@ -180,6 +192,13 @@ def run! options=nil EventMachine.run do # Set up an SMTP server to run within EventMachine rescue_port options[:smtp_port] do + Smtp.parms = { + starttls: options[:smtp_starttls], + starttls_options: { + private_key_file: options[:smtp_private_key_file], + cert_chain_file: options[:smtp_cert_chain_path], + }, + } EventMachine.start_server options[:smtp_ip], options[:smtp_port], Smtp puts "==> #{smtp_url}" end