diff options
| author | 2021-10-31 15:46:23 +0100 | |
|---|---|---|
| committer | 2021-10-31 15:46:23 +0100 | |
| commit | 2aaec827321ec711b98e13335899cf750f270105 (patch) | |
| tree | bafa15a0c2a469adf97b2c437fdc31428516424e /internal/api/s2s/user | |
| parent | regenerate swagger docs (#293) (diff) | |
| download | gotosocial-2aaec827321ec711b98e13335899cf750f270105.tar.xz | |
smtp + email confirmation (#285)
* add smtp configuration
* add email confirm + reset templates
* add email sender to testrig
* flesh out the email sender interface
* go fmt
* golint
* update from field with more clarity
* tidy up the email formatting
* fix tests
* add email sender to processor
* tidy client api processing a bit
* further tidying in fromClientAPI
* pin new account to user
* send msg to processor on new account creation
* generate confirm email uri
* remove emailer from account processor again
* add processCreateAccountFromClientAPI
* move emailer accountprocessor => userprocessor
* add email sender to user processor
* SendConfirmEmail function
* add noop email sender
* use noop email sender in tests
* only assemble message if callback is not nil
* use noop email sender if no smtp host is defined
* minify email html before sending
* fix wrong email address
* email confirm test
* fmt
* serve web hndler
* add email confirm handler
* init test log properly on testrig
* log emails that *would* have been sent
* go fmt ./...
* unexport confirm email handler
* updatedAt
* test confirm email function
* don't allow tokens older than 7 days
* change error message a bit
* add basic smtp docs
* add a few more snippets
* typo
* add email sender to outbox tests
* don't use dutch wikipedia link
* don't minify email html
Diffstat (limited to 'internal/api/s2s/user')
| -rw-r--r-- | internal/api/s2s/user/inboxpost_test.go | 12 | ||||
| -rw-r--r-- | internal/api/s2s/user/outboxget_test.go | 9 | ||||
| -rw-r--r-- | internal/api/s2s/user/repliesget_test.go | 9 | ||||
| -rw-r--r-- | internal/api/s2s/user/user_test.go | 5 | ||||
| -rw-r--r-- | internal/api/s2s/user/userget_test.go | 3 | 
5 files changed, 26 insertions, 12 deletions
| diff --git a/internal/api/s2s/user/inboxpost_test.go b/internal/api/s2s/user/inboxpost_test.go index 554f3d729..3f02affdb 100644 --- a/internal/api/s2s/user/inboxpost_test.go +++ b/internal/api/s2s/user/inboxpost_test.go @@ -85,7 +85,8 @@ func (suite *InboxPostTestSuite) TestPostBlock() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -184,7 +185,8 @@ func (suite *InboxPostTestSuite) TestPostUnblock() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -273,7 +275,8 @@ func (suite *InboxPostTestSuite) TestPostUpdate() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -391,7 +394,8 @@ func (suite *InboxPostTestSuite) TestPostDelete() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	err = processor.Start(context.Background())  	suite.NoError(err)  	userModule := user.New(suite.config, processor).(*user.Module) diff --git a/internal/api/s2s/user/outboxget_test.go b/internal/api/s2s/user/outboxget_test.go index f1818683e..4f5ea3f17 100644 --- a/internal/api/s2s/user/outboxget_test.go +++ b/internal/api/s2s/user/outboxget_test.go @@ -46,7 +46,8 @@ func (suite *OutboxGetTestSuite) TestGetOutbox() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -99,7 +100,8 @@ func (suite *OutboxGetTestSuite) TestGetOutboxFirstPage() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -152,7 +154,8 @@ func (suite *OutboxGetTestSuite) TestGetOutboxNextPage() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request diff --git a/internal/api/s2s/user/repliesget_test.go b/internal/api/s2s/user/repliesget_test.go index 44717ad42..32cd0c366 100644 --- a/internal/api/s2s/user/repliesget_test.go +++ b/internal/api/s2s/user/repliesget_test.go @@ -49,7 +49,8 @@ func (suite *RepliesGetTestSuite) TestGetReplies() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -108,7 +109,8 @@ func (suite *RepliesGetTestSuite) TestGetRepliesNext() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request @@ -170,7 +172,8 @@ func (suite *RepliesGetTestSuite) TestGetRepliesLast() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request diff --git a/internal/api/s2s/user/user_test.go b/internal/api/s2s/user/user_test.go index 268523724..fc4232bde 100644 --- a/internal/api/s2s/user/user_test.go +++ b/internal/api/s2s/user/user_test.go @@ -25,6 +25,7 @@ import (  	"github.com/superseriousbusiness/gotosocial/internal/api/security"  	"github.com/superseriousbusiness/gotosocial/internal/config"  	"github.com/superseriousbusiness/gotosocial/internal/db" +	"github.com/superseriousbusiness/gotosocial/internal/email"  	"github.com/superseriousbusiness/gotosocial/internal/federation"  	"github.com/superseriousbusiness/gotosocial/internal/gtsmodel"  	"github.com/superseriousbusiness/gotosocial/internal/processing" @@ -39,6 +40,7 @@ type UserStandardTestSuite struct {  	db             db.DB  	tc             typeutils.TypeConverter  	federator      federation.Federator +	emailSender    email.Sender  	processor      processing.Processor  	storage        *kv.KVStore  	securityModule *security.Module @@ -75,7 +77,8 @@ func (suite *UserStandardTestSuite) SetupTest() {  	suite.storage = testrig.NewTestStorage()  	testrig.InitTestLog()  	suite.federator = testrig.NewTestFederator(suite.db, testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db), suite.storage) -	suite.processor = testrig.NewTestProcessor(suite.db, suite.storage, suite.federator) +	suite.emailSender = testrig.NewEmailSender("../../../../web/template/", nil) +	suite.processor = testrig.NewTestProcessor(suite.db, suite.storage, suite.federator, suite.emailSender)  	suite.userModule = user.New(suite.config, suite.processor).(*user.Module)  	suite.securityModule = security.New(suite.config, suite.db).(*security.Module)  	testrig.StandardDBSetup(suite.db, suite.testAccounts) diff --git a/internal/api/s2s/user/userget_test.go b/internal/api/s2s/user/userget_test.go index d8d1df148..68f16fc76 100644 --- a/internal/api/s2s/user/userget_test.go +++ b/internal/api/s2s/user/userget_test.go @@ -47,7 +47,8 @@ func (suite *UserGetTestSuite) TestGetUser() {  	tc := testrig.NewTestTransportController(testrig.NewMockHTTPClient(nil), suite.db)  	federator := testrig.NewTestFederator(suite.db, tc, suite.storage) -	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator) +	emailSender := testrig.NewEmailSender("../../../../web/template/", nil) +	processor := testrig.NewTestProcessor(suite.db, suite.storage, federator, emailSender)  	userModule := user.New(suite.config, processor).(*user.Module)  	// setup request | 
