Skip to content

Commit

Permalink
move invite by mail to services package (go-gitea#21513)
Browse files Browse the repository at this point in the history
followup  go-gitea#20307
close go-gitea#21511

-> make it easy to also add API equivalent later ...
  • Loading branch information
6543 authored Oct 20, 2022
1 parent fe442db commit bd272e4
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 6 deletions.
7 changes: 1 addition & 6 deletions routers/web/org/teams.go
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@ import (
"code.gitea.io/gitea/modules/web"
"code.gitea.io/gitea/routers/utils"
"code.gitea.io/gitea/services/forms"
"code.gitea.io/gitea/services/mailer"
org_service "code.gitea.io/gitea/services/org"
)

Expand Down Expand Up @@ -132,8 +131,7 @@ func TeamsAction(ctx *context.Context) {
if err != nil {
if user_model.IsErrUserNotExist(err) {
if setting.MailService != nil && user_model.ValidateEmail(uname) == nil {
invite, err := org_model.CreateTeamInvite(ctx, ctx.Doer, ctx.Org.Team, uname)
if err != nil {
if err := org_service.CreateTeamInvite(ctx, ctx.Doer, ctx.Org.Team, uname); err != nil {
if org_model.IsErrTeamInviteAlreadyExist(err) {
ctx.Flash.Error(ctx.Tr("form.duplicate_invite_to_team"))
} else if org_model.IsErrUserEmailAlreadyAdded(err) {
Expand All @@ -142,9 +140,6 @@ func TeamsAction(ctx *context.Context) {
ctx.ServerError("CreateTeamInvite", err)
return
}
} else if err := mailer.MailTeamInvite(ctx, ctx.Doer, ctx.Org.Team, invite); err != nil {
ctx.ServerError("MailTeamInvite", err)
return
}
} else {
ctx.Flash.Error(ctx.Tr("form.user_not_exist"))
Expand Down
23 changes: 23 additions & 0 deletions services/org/team_invite.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
// Copyright 2022 The Gitea Authors. All rights reserved.
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file.

package org

import (
"context"

org_model "code.gitea.io/gitea/models/organization"
user_model "code.gitea.io/gitea/models/user"
"code.gitea.io/gitea/services/mailer"
)

// CreateTeamInvite make a persistent invite in db and mail it
func CreateTeamInvite(ctx context.Context, inviter *user_model.User, team *org_model.Team, uname string) error {
invite, err := org_model.CreateTeamInvite(ctx, inviter, team, uname)
if err != nil {
return err
}

return mailer.MailTeamInvite(ctx, inviter, team, invite)
}

0 comments on commit bd272e4

Please sign in to comment.