| 
									
										
										
										
											2023-03-12 16:00:57 +01: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 15:46:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | package email | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"net/smtp" | 
					
						
							| 
									
										
										
										
											2022-01-31 10:46:20 +00:00
										 |  |  | 	"text/template" | 
					
						
							| 
									
										
										
										
											2021-10-31 15:46:23 +01: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 17:11:04 +01: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 13:11:46 +01: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 11:45:53 +02: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 13:25:10 +02: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 15:46:23 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // NewSender returns a new email Sender interface with the given configuration, or an error if something goes wrong. | 
					
						
							| 
									
										
										
										
											2021-12-07 13:31:39 +01:00
										 |  |  | func NewSender() (Sender, error) { | 
					
						
							| 
									
										
										
										
											2022-05-30 13:41:24 +01:00
										 |  |  | 	templateBaseDir := config.GetWebTemplateBaseDir() | 
					
						
							| 
									
										
										
										
											2021-12-07 13:31:39 +01:00
										 |  |  | 	t, err := loadTemplates(templateBaseDir) | 
					
						
							| 
									
										
										
										
											2021-10-31 15:46:23 +01: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() | 
					
						
							| 
									
										
										
										
											2021-10-31 15:46:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return &sender{ | 
					
						
							| 
									
										
										
										
											2021-12-07 13:31:39 +01:00
										 |  |  | 		hostAddress: fmt.Sprintf("%s:%d", host, port), | 
					
						
							|  |  |  | 		from:        from, | 
					
						
							|  |  |  | 		auth:        smtp.PlainAuth("", username, password, host), | 
					
						
							| 
									
										
										
										
											2021-10-31 15:46:23 +01:00
										 |  |  | 		template:    t, | 
					
						
							|  |  |  | 	}, nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type sender struct { | 
					
						
							|  |  |  | 	hostAddress string | 
					
						
							|  |  |  | 	from        string | 
					
						
							|  |  |  | 	auth        smtp.Auth | 
					
						
							|  |  |  | 	template    *template.Template | 
					
						
							|  |  |  | } |