mirror of
https://github.com/go-gitea/gitea.git
synced 2025-12-10 19:44:33 +01:00
Merge eec13ccdff3458844836d923e328827dc3a2170e into c287a8cdb589172bbba8969357a671dabc6596bd
This commit is contained in:
commit
1eac20fb6f
@ -206,6 +206,47 @@ func SignInOAuthCallback(ctx *context.Context) {
|
|||||||
ctx.ServerError("SyncGroupsToTeams", err)
|
ctx.ServerError("SyncGroupsToTeams", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
} else if setting.OAuth2Client.AccountLinking == setting.OAuth2AccountLinkingAuto {
|
||||||
|
// allow ACCOUNT_LINKING=auto to work without ENABLE_AUTO_REGISTRATION.
|
||||||
|
user := &user_model.User{Email: gothUser.Email}
|
||||||
|
hasUser, err := user_model.GetUser(ctx, user)
|
||||||
|
if err != nil {
|
||||||
|
ctx.ServerError("UserLinkAccount", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if hasUser {
|
||||||
|
if user.ProhibitLogin || !user.IsActive {
|
||||||
|
log.Info("Failed authentication attempt for %s from %s: user has disabled sign-in", user.Name, ctx.RemoteAddr())
|
||||||
|
ctx.Flash.Error(ctx.Tr("auth.prohibit_login"))
|
||||||
|
ctx.Redirect(setting.AppSubURL + "/user/login")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if err := externalaccount.LinkAccountToUser(ctx, authSource.ID, user, gothUser); err != nil {
|
||||||
|
ctx.ServerError("LinkAccountToUser", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
userHasTwoFactorAuth, err := auth.HasTwoFactorOrWebAuthn(ctx, user.ID)
|
||||||
|
if err != nil {
|
||||||
|
ctx.ServerError("HasTwoFactorOrWebAuthn", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if err := updateSession(ctx, nil, map[string]any{
|
||||||
|
session.KeyUID: user.ID,
|
||||||
|
session.KeyUname: user.Name,
|
||||||
|
session.KeyUserHasTwoFactorAuth: userHasTwoFactorAuth,
|
||||||
|
}); err != nil {
|
||||||
|
ctx.ServerError("updateSession", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
ctx.Csrf.PrepareForSessionUser(ctx)
|
||||||
|
ctx.Redirect(setting.AppSubURL + "/")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
showLinkingLogin(ctx, authSource.ID, gothUser)
|
||||||
|
return
|
||||||
} else {
|
} else {
|
||||||
// no existing user is found, request attach or new account
|
// no existing user is found, request attach or new account
|
||||||
showLinkingLogin(ctx, authSource.ID, gothUser)
|
showLinkingLogin(ctx, authSource.ID, gothUser)
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user