2023-03-12 15:00:57 +00:00
|
|
|
// GoToSocial
|
|
|
|
// Copyright (C) GoToSocial Authors admin@gotosocial.org
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-or-later
|
|
|
|
//
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU Affero General Public License as published by
|
|
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
|
|
// (at your option) any later version.
|
|
|
|
//
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU Affero General Public License for more details.
|
|
|
|
//
|
|
|
|
// You should have received a copy of the GNU Affero General Public License
|
|
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
2021-10-31 14:46:23 +00:00
|
|
|
|
|
|
|
package email
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/smtp"
|
2022-01-31 10:46:20 +00:00
|
|
|
"text/template"
|
2021-10-31 14:46:23 +00:00
|
|
|
|
|
|
|
"github.com/superseriousbusiness/gotosocial/internal/config"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Sender contains functions for sending emails to instance users/new signups.
|
|
|
|
type Sender interface {
|
|
|
|
// SendConfirmEmail sends a 'please confirm your email' style email to the given toAddress, with the given data.
|
|
|
|
SendConfirmEmail(toAddress string, data ConfirmData) error
|
|
|
|
|
|
|
|
// SendResetEmail sends a 'reset your password' style email to the given toAddress, with the given data.
|
|
|
|
SendResetEmail(toAddress string, data ResetData) error
|
2023-03-14 16:11:04 +00:00
|
|
|
|
|
|
|
// SendTestEmail sends a 'testing email sending' style email to the given toAddress, with the given data.
|
|
|
|
SendTestEmail(toAddress string, data TestData) error
|
2023-03-19 12:11:46 +00:00
|
|
|
|
|
|
|
// SendNewReportEmail sends an email notification to the given addresses, letting them
|
|
|
|
// know that a new report has been created targeting a user on this instance.
|
|
|
|
//
|
|
|
|
// It is expected that the toAddresses have already been filtered to ensure that they
|
|
|
|
// all belong to admins + moderators.
|
|
|
|
SendNewReportEmail(toAddresses []string, data NewReportData) error
|
|
|
|
|
|
|
|
// SendReportClosedEmail sends an email notification to the given address, letting them
|
|
|
|
// know that a report that they created has been closed / resolved by an admin.
|
|
|
|
SendReportClosedEmail(toAddress string, data ReportClosedData) error
|
2024-04-11 10:45:53 +01:00
|
|
|
|
|
|
|
// SendNewSignupEmail sends an email notification to the given addresses,
|
|
|
|
// letting them know that a new sign-up has been submitted to the instance.
|
|
|
|
//
|
|
|
|
// It is expected that the toAddresses have already been filtered to ensure
|
|
|
|
// that they all belong to active admins + moderators.
|
|
|
|
SendNewSignupEmail(toAddress []string, data NewSignupData) error
|
2024-04-13 12:25:10 +01:00
|
|
|
|
|
|
|
// SendSignupApprovedEmail sends an email to the given address
|
|
|
|
// that their sign-up request has been approved by a moderator.
|
|
|
|
SendSignupApprovedEmail(toAddress string, data SignupApprovedData) error
|
|
|
|
|
|
|
|
// SendSignupRejectedEmail sends an email to the given address
|
|
|
|
// that their sign-up request has been rejected by a moderator.
|
|
|
|
SendSignupRejectedEmail(toAddress string, data SignupRejectedData) error
|
2021-10-31 14:46:23 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewSender returns a new email Sender interface with the given configuration, or an error if something goes wrong.
|
2021-12-07 12:31:39 +00:00
|
|
|
func NewSender() (Sender, error) {
|
2022-05-30 13:41:24 +01:00
|
|
|
templateBaseDir := config.GetWebTemplateBaseDir()
|
2021-12-07 12:31:39 +00:00
|
|
|
t, err := loadTemplates(templateBaseDir)
|
2021-10-31 14:46:23 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2022-05-30 13:41:24 +01:00
|
|
|
username := config.GetSMTPUsername()
|
|
|
|
password := config.GetSMTPPassword()
|
|
|
|
host := config.GetSMTPHost()
|
|
|
|
port := config.GetSMTPPort()
|
|
|
|
from := config.GetSMTPFrom()
|
2024-06-22 22:36:30 +01:00
|
|
|
msgIDHost := config.GetHost()
|
2021-10-31 14:46:23 +00:00
|
|
|
|
|
|
|
return &sender{
|
2021-12-07 12:31:39 +00:00
|
|
|
hostAddress: fmt.Sprintf("%s:%d", host, port),
|
|
|
|
from: from,
|
|
|
|
auth: smtp.PlainAuth("", username, password, host),
|
2024-06-22 22:36:30 +01:00
|
|
|
msgIDHost: msgIDHost,
|
2021-10-31 14:46:23 +00:00
|
|
|
template: t,
|
|
|
|
}, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type sender struct {
|
|
|
|
hostAddress string
|
|
|
|
from string
|
|
|
|
auth smtp.Auth
|
2024-06-22 22:36:30 +01:00
|
|
|
msgIDHost string
|
2021-10-31 14:46:23 +00:00
|
|
|
template *template.Template
|
|
|
|
}
|