|
@@ -3,9 +3,11 @@ package main
|
|
import (
|
|
import (
|
|
"crypto/tls"
|
|
"crypto/tls"
|
|
"flag"
|
|
"flag"
|
|
|
|
+ "io"
|
|
"log"
|
|
"log"
|
|
"net"
|
|
"net"
|
|
"net/smtp"
|
|
"net/smtp"
|
|
|
|
+ "os"
|
|
"strings"
|
|
"strings"
|
|
"time"
|
|
"time"
|
|
|
|
|
|
@@ -14,6 +16,7 @@ import (
|
|
)
|
|
)
|
|
|
|
|
|
var (
|
|
var (
|
|
|
|
+ logFile = flag.String("logfile", "/var/log/smtpd-proxy.log", "Path to logfile")
|
|
hostName = flag.String("hostname", "localhost.localdomain", "Server hostname")
|
|
hostName = flag.String("hostname", "localhost.localdomain", "Server hostname")
|
|
welcomeMsg = flag.String("welcome_msg", "", "Welcome message for SMTP session")
|
|
welcomeMsg = flag.String("welcome_msg", "", "Welcome message for SMTP session")
|
|
listen = flag.String("listen", "127.0.0.1:25 [::1]:25", "Address and port to listen for incoming SMTP")
|
|
listen = flag.String("listen", "127.0.0.1:25 [::1]:25", "Address and port to listen for incoming SMTP")
|
|
@@ -49,6 +52,16 @@ func main() {
|
|
|
|
|
|
iniflags.Parse()
|
|
iniflags.Parse()
|
|
|
|
|
|
|
|
+ if *logFile != "" {
|
|
|
|
+ f, err := os.OpenFile(*logFile, os.O_RDWR | os.O_CREATE | os.O_APPEND, 0600)
|
|
|
|
+ if err != nil {
|
|
|
|
+ log.Fatalf("Error opening logfile: %v", err)
|
|
|
|
+ }
|
|
|
|
+ defer f.Close()
|
|
|
|
+ wrt := io.MultiWriter(os.Stdout, f)
|
|
|
|
+ log.SetOutput(wrt)
|
|
|
|
+ }
|
|
|
|
+
|
|
listeners := strings.Split(*listen, " ")
|
|
listeners := strings.Split(*listen, " ")
|
|
|
|
|
|
for i := range(listeners) {
|
|
for i := range(listeners) {
|