First version.
This commit is contained in:
parent
9b10e41062
commit
23b1a10581
@ -115,6 +115,7 @@ func setAutoresponseViaEmail(recipient, sender, saslUser, clientIp string) error
|
|||||||
// Send mail via sendmail
|
// Send mail via sendmail
|
||||||
sendMail(recipient, sender, func(sink io.WriteCloser) {
|
sendMail(recipient, sender, func(sink io.WriteCloser) {
|
||||||
defer sink.Close()
|
defer sink.Close()
|
||||||
|
|
||||||
sink.Write([]byte(fmt.Sprintf("From: %v\nTo: %v\nSubject: Autoresponder\n\n"+
|
sink.Write([]byte(fmt.Sprintf("From: %v\nTo: %v\nSubject: Autoresponder\n\n"+
|
||||||
"Autoresponse disabled for %v by SASL authenticated user: %v from: %v\n",
|
"Autoresponse disabled for %v by SASL authenticated user: %v from: %v\n",
|
||||||
recipient, sender, sender, saslUser, clientIp)))
|
recipient, sender, sender, saslUser, clientIp)))
|
||||||
@ -159,10 +160,14 @@ func setAutoresponseViaEmail(recipient, sender, saslUser, clientIp string) error
|
|||||||
}
|
}
|
||||||
|
|
||||||
switch true {
|
switch true {
|
||||||
case strings.Index(strings.ToLower(line), "from: ") == 0:
|
case strings.Index(strings.ToLower(line), "from: ") == 0 ||
|
||||||
|
strings.Index(strings.ToLower(line), "content-type: ") == 0 ||
|
||||||
|
strings.Index(strings.ToLower(line), "mime-version: ") == 0:
|
||||||
_, err = writer.WriteString(line)
|
_, err = writer.WriteString(line)
|
||||||
|
|
||||||
case strings.Index(strings.ToLower(line), "to: ") == 0:
|
case strings.Index(strings.ToLower(line), "to: ") == 0:
|
||||||
_, err = writer.WriteString("To: THIS GETS REPLACED\n")
|
_, err = writer.WriteString("To: THIS GETS REPLACED\n")
|
||||||
|
|
||||||
case strings.Index(strings.ToLower(line), "subject: ") == 0:
|
case strings.Index(strings.ToLower(line), "subject: ") == 0:
|
||||||
_, err = writer.WriteString("Subject: Autoresponder\n")
|
_, err = writer.WriteString("Subject: Autoresponder\n")
|
||||||
}
|
}
|
||||||
@ -197,6 +202,7 @@ func setAutoresponseViaEmail(recipient, sender, saslUser, clientIp string) error
|
|||||||
// Forward email using supplied arguments and stdin (email body)
|
// Forward email using supplied arguments and stdin (email body)
|
||||||
func forwardEmailAndAutoresponse(recipient, sender, saslUser, clientIp string, responseRate uint) error {
|
func forwardEmailAndAutoresponse(recipient, sender, saslUser, clientIp string, responseRate uint) error {
|
||||||
recipientResponsePath := filepath.Join(RESPONSE_DIR, recipient)
|
recipientResponsePath := filepath.Join(RESPONSE_DIR, recipient)
|
||||||
|
recipientRateLog := filepath.Join(RATE_LOG_DIR, recipient)
|
||||||
recipientSenderRateLog := filepath.Join(RATE_LOG_DIR, recipient, sender)
|
recipientSenderRateLog := filepath.Join(RATE_LOG_DIR, recipient, sender)
|
||||||
|
|
||||||
if fileExists(recipientResponsePath) {
|
if fileExists(recipientResponsePath) {
|
||||||
@ -217,13 +223,69 @@ func forwardEmailAndAutoresponse(recipient, sender, saslUser, clientIp string, r
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// If sendResponse is true, then send response and touch rate log file
|
// If sendResponse is true and sender and recipiend differ, then send response and touch rate log file
|
||||||
if sendResponse {
|
if sendResponse && strings.ToLower(recipient) != strings.ToLower(sender) {
|
||||||
//fmt.Println("Sending response")
|
//fmt.Println("Sending response")
|
||||||
//!!!
|
fl, err := os.Open(recipientResponsePath)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
defer fl.Close()
|
||||||
|
sendMail(recipient, sender, func(sink io.WriteCloser) {
|
||||||
|
defer sink.Close()
|
||||||
|
|
||||||
|
// Open recipientResponsePath file and do some replacements on the fly
|
||||||
|
reader := bufio.NewReader(fl)
|
||||||
|
state := 0
|
||||||
|
for {
|
||||||
|
line, err := reader.ReadString('\n')
|
||||||
|
if err != nil {
|
||||||
|
if err == io.EOF {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
syslg.Err(err.Error())
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
switch state {
|
||||||
|
case 0:
|
||||||
|
switch true {
|
||||||
|
case line == "\n" || line == "\r\n" || line == "\r":
|
||||||
|
state = 1
|
||||||
|
|
||||||
|
case strings.Index(strings.ToLower(line), "from: ") == 0:
|
||||||
|
line = fmt.Sprintf("From: %v\n", recipient)
|
||||||
|
|
||||||
|
case strings.Index(strings.ToLower(line), "to: ") == 0:
|
||||||
|
line = fmt.Sprintf("To: %v\n", sender)
|
||||||
|
}
|
||||||
|
fallthrough
|
||||||
|
|
||||||
|
default:
|
||||||
|
sink.Write([]byte(line))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//!!!
|
})
|
||||||
|
err = os.MkdirAll(recipientRateLog, 0770)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
// Touch rate log file
|
||||||
|
fl, err = os.Create(recipientSenderRateLog)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
fl.Close()
|
||||||
|
syslg.Info(fmt.Sprintf("Autoresponse sent from %v to %v", recipient, sender))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Now resend original mail
|
||||||
|
sendMail(sender, recipient, func(sink io.WriteCloser) {
|
||||||
|
defer sink.Close()
|
||||||
|
|
||||||
|
io.Copy(sink, os.Stdout)
|
||||||
|
})
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
@ -385,7 +447,12 @@ func enableExAutoresponse(email string, nostdout bool) error {
|
|||||||
// Delete autoresponse for email
|
// Delete autoresponse for email
|
||||||
func deleteAutoresponse(email string, nostdout bool) error {
|
func deleteAutoresponse(email string, nostdout bool) error {
|
||||||
deleteResponsePath := filepath.Join(RESPONSE_DIR, email)
|
deleteResponsePath := filepath.Join(RESPONSE_DIR, email)
|
||||||
|
disabledDeleteResponsePath := deleteResponsePath + "_DISABLED"
|
||||||
|
recipientRateLog := filepath.Join(RATE_LOG_DIR, email)
|
||||||
|
|
||||||
if fileExists(deleteResponsePath) {
|
if fileExists(deleteResponsePath) {
|
||||||
|
os.Remove(disabledDeleteResponsePath)
|
||||||
|
os.RemoveAll(recipientRateLog)
|
||||||
err := os.Remove(deleteResponsePath)
|
err := os.Remove(deleteResponsePath)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
msg := fmt.Sprintf("%v cannot be deleted: %v", deleteResponsePath, err)
|
msg := fmt.Sprintf("%v cannot be deleted: %v", deleteResponsePath, err)
|
||||||
@ -529,7 +596,6 @@ func main() {
|
|||||||
syslg.Info(fmt.Sprintf("Requested email forward from %v, to %v", *senderPtr, *recipientPtr))
|
syslg.Info(fmt.Sprintf("Requested email forward from %v, to %v", *senderPtr, *recipientPtr))
|
||||||
|
|
||||||
err := forwardEmailAndAutoresponse(*recipientPtr, *senderPtr, *saslUserPtr, *clientIpPtr, *responseRatePtr)
|
err := forwardEmailAndAutoresponse(*recipientPtr, *senderPtr, *saslUserPtr, *clientIpPtr, *responseRatePtr)
|
||||||
//!!!
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
syslg.Err(err.Error())
|
syslg.Err(err.Error())
|
||||||
os.Exit(1)
|
os.Exit(1)
|
||||||
|
Reference in New Issue
Block a user