2023-01-14 16:57:10 +01:00
// Copyright 2023 The Gitea Authors. All rights reserved.
// SPDX-License-Identifier: MIT
package setting
import (
"fmt"
"net/mail"
"strings"
"code.gitea.io/gitea/modules/log"
)
var IncomingEmail = struct {
Enabled bool
ReplyToAddress string
TokenPlaceholder string ` ini:"-" `
Host string
Port int
UseTLS bool ` ini:"USE_TLS" `
SkipTLSVerify bool ` ini:"SKIP_TLS_VERIFY" `
Username string
Password string
Mailbox string
DeleteHandledMessage bool
MaximumMessageSize uint32
} {
Mailbox : "INBOX" ,
DeleteHandledMessage : true ,
TokenPlaceholder : "%{token}" ,
MaximumMessageSize : 10485760 ,
}
2023-02-20 00:12:01 +08:00
func loadIncomingEmailFrom ( rootCfg ConfigProvider ) {
mustMapSetting ( rootCfg , "email.incoming" , & IncomingEmail )
2023-01-14 16:57:10 +01:00
if ! IncomingEmail . Enabled {
return
}
if err := checkReplyToAddress ( IncomingEmail . ReplyToAddress ) ; err != nil {
log . Fatal ( "Invalid incoming_mail.REPLY_TO_ADDRESS (%s): %v" , IncomingEmail . ReplyToAddress , err )
}
}
func checkReplyToAddress ( address string ) error {
parsed , err := mail . ParseAddress ( IncomingEmail . ReplyToAddress )
if err != nil {
return err
}
if parsed . Name != "" {
return fmt . Errorf ( "name must not be set" )
}
c := strings . Count ( IncomingEmail . ReplyToAddress , IncomingEmail . TokenPlaceholder )
switch c {
case 0 :
return fmt . Errorf ( "%s must appear in the user part of the address (before the @)" , IncomingEmail . TokenPlaceholder )
case 1 :
default :
return fmt . Errorf ( "%s must appear only once" , IncomingEmail . TokenPlaceholder )
}
parts := strings . Split ( IncomingEmail . ReplyToAddress , "@" )
if ! strings . Contains ( parts [ 0 ] , IncomingEmail . TokenPlaceholder ) {
return fmt . Errorf ( "%s must appear in the user part of the address (before the @)" , IncomingEmail . TokenPlaceholder )
}
return nil
}