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
}
2024-04-22 15:58:19 +02:00
// Handle aliases
sec := rootCfg . Section ( "email.incoming" )
if sec . HasKey ( "USER" ) && ! sec . HasKey ( "USERNAME" ) {
IncomingEmail . Username = sec . Key ( "USER" ) . String ( )
}
if sec . HasKey ( "PASSWD" ) && ! sec . HasKey ( "PASSWORD" ) {
IncomingEmail . Password = sec . Key ( "PASSWD" ) . String ( )
}
2024-04-22 16:27:32 +02:00
// Infer Port if not set
if IncomingEmail . Port == 0 {
if IncomingEmail . UseTLS {
IncomingEmail . Port = 993
} else {
IncomingEmail . Port = 143
}
}
2024-04-29 04:47:56 -04:00
if err := checkReplyToAddress ( ) ; err != nil {
2023-01-14 16:57:10 +01:00
log . Fatal ( "Invalid incoming_mail.REPLY_TO_ADDRESS (%s): %v" , IncomingEmail . ReplyToAddress , err )
}
}
2024-04-29 04:47:56 -04:00
func checkReplyToAddress ( ) error {
2023-01-14 16:57:10 +01:00
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
}