summaryrefslogtreecommitdiff
path: root/internal/processing/admin
diff options
context:
space:
mode:
Diffstat (limited to 'internal/processing/admin')
-rw-r--r--internal/processing/admin/admin.go5
-rw-r--r--internal/processing/admin/email.go61
2 files changed, 65 insertions, 1 deletions
diff --git a/internal/processing/admin/admin.go b/internal/processing/admin/admin.go
index 83dbc5f5b..ad0279dbf 100644
--- a/internal/processing/admin/admin.go
+++ b/internal/processing/admin/admin.go
@@ -18,6 +18,7 @@
package admin
import (
+ "github.com/superseriousbusiness/gotosocial/internal/email"
"github.com/superseriousbusiness/gotosocial/internal/media"
"github.com/superseriousbusiness/gotosocial/internal/state"
"github.com/superseriousbusiness/gotosocial/internal/transport"
@@ -29,14 +30,16 @@ type Processor struct {
tc typeutils.TypeConverter
mediaManager media.Manager
transportController transport.Controller
+ emailSender email.Sender
}
// New returns a new admin processor.
-func New(state *state.State, tc typeutils.TypeConverter, mediaManager media.Manager, transportController transport.Controller) Processor {
+func New(state *state.State, tc typeutils.TypeConverter, mediaManager media.Manager, transportController transport.Controller, emailSender email.Sender) Processor {
return Processor{
state: state,
tc: tc,
mediaManager: mediaManager,
transportController: transportController,
+ emailSender: emailSender,
}
}
diff --git a/internal/processing/admin/email.go b/internal/processing/admin/email.go
new file mode 100644
index 000000000..88396db76
--- /dev/null
+++ b/internal/processing/admin/email.go
@@ -0,0 +1,61 @@
+// 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/>.
+
+package admin
+
+import (
+ "context"
+ "fmt"
+
+ "github.com/superseriousbusiness/gotosocial/internal/config"
+ "github.com/superseriousbusiness/gotosocial/internal/email"
+ "github.com/superseriousbusiness/gotosocial/internal/gtserror"
+ "github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
+)
+
+// EmailTest sends a generic test email to the given toAddress (which
+// should be a valid email address). To help callers differentiate between
+// proper errors and the smtp errors they're likely fishing for, will return
+// 422 + help text on an SMTP error, or error 500 otherwise.
+func (p *Processor) EmailTest(ctx context.Context, account *gtsmodel.Account, toAddress string) gtserror.WithCode {
+ // Pull our instance entry from the database,
+ // so we can greet the email recipient nicely.
+ instance, err := p.state.DB.GetInstance(ctx, config.GetHost())
+ if err != nil {
+ err = fmt.Errorf("SendConfirmEmail: error getting instance: %s", err)
+ return gtserror.NewErrorInternalError(err)
+ }
+
+ testData := email.TestData{
+ SendingUsername: account.Username,
+ InstanceURL: instance.URI,
+ InstanceName: instance.Title,
+ }
+
+ if err := p.emailSender.SendTestEmail(toAddress, testData); err != nil {
+ if errorType := gtserror.Type(err); errorType == gtserror.TypeSMTP {
+ // An error occurred during the SMTP part.
+ // We should indicate this to the caller, as
+ // it will likely help them debug the issue.
+ return gtserror.NewErrorUnprocessableEntity(err, err.Error())
+ }
+ // An actual error has occurred.
+ return gtserror.NewErrorInternalError(err)
+ }
+
+ return nil
+}