feat: login success page (#1849)

* feat: login success page

* fix: script import on mfa verify
This commit is contained in:
Livio Amstutz 2021-06-10 14:18:07 +02:00 committed by GitHub
parent bdf3887f9e
commit 6830de6385
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 110 additions and 14 deletions

View File

@ -1,11 +0,0 @@
package handler
import (
"github.com/caos/zitadel/internal/domain"
"net/http"
)
func (l *Login) redirectToCallback(w http.ResponseWriter, r *http.Request, authReq *domain.AuthRequest) {
callback := l.oidcAuthCallbackURL + authReq.ID
http.Redirect(w, r, callback, http.StatusFound)
}

View File

@ -0,0 +1,45 @@
package handler
import (
"net/http"
"github.com/caos/zitadel/internal/domain"
)
const (
tmplLoginSuccess = "login_success"
)
type loginSuccessData struct {
userData
RedirectURI string `schema:"redirect-uri"`
}
func (l *Login) redirectToLoginSuccess(w http.ResponseWriter, r *http.Request, id string) {
http.Redirect(w, r, l.renderer.pathPrefix+EndpointLoginSuccess+"?authRequestID="+id, http.StatusFound)
}
func (l *Login) handleLoginSuccess(w http.ResponseWriter, r *http.Request) {
authRequest, _ := l.getAuthRequest(r)
if authRequest != nil {
if !(len(authRequest.PossibleSteps) == 1 && authRequest.PossibleSteps[0].Type() == domain.NextStepRedirectToCallback) {
l.renderNextStep(w, r, authRequest)
return
}
}
l.renderSuccessAndCallback(w, r, authRequest, nil)
}
func (l *Login) renderSuccessAndCallback(w http.ResponseWriter, r *http.Request, authReq *domain.AuthRequest, err error) {
var errType, errMessage string
if err != nil {
errMessage = l.getErrorMessage(r, err)
}
data := loginSuccessData{
userData: l.getUserData(r, authReq, "Login Successful", errType, errMessage),
}
if authReq != nil {
data.RedirectURI = l.oidcAuthCallbackURL
}
l.renderer.RenderTemplate(w, r, l.renderer.Templates[tmplLoginSuccess], data, nil)
}

View File

@ -66,6 +66,7 @@ func CreateRenderer(pathPrefix string, staticDir http.FileSystem, staticStorage
tmplChangeUsernameDone: "change_username_done.html", tmplChangeUsernameDone: "change_username_done.html",
tmplLinkUsersDone: "link_users_done.html", tmplLinkUsersDone: "link_users_done.html",
tmplExternalNotFoundOption: "external_not_found_option.html", tmplExternalNotFoundOption: "external_not_found_option.html",
tmplLoginSuccess: "login_success.html",
} }
funcs := map[string]interface{}{ funcs := map[string]interface{}{
"resourceUrl": func(file string) string { "resourceUrl": func(file string) string {
@ -252,7 +253,7 @@ func (l *Login) chooseNextStep(w http.ResponseWriter, r *http.Request, authReq *
l.chooseNextStep(w, r, authReq, 1, err) l.chooseNextStep(w, r, authReq, 1, err)
return return
} }
l.redirectToCallback(w, r, authReq) l.redirectToLoginSuccess(w, r, authReq.ID)
case *domain.ChangePasswordStep: case *domain.ChangePasswordStep:
l.renderChangePassword(w, r, authReq, err) l.renderChangePassword(w, r, authReq, err)
case *domain.VerifyEMailStep: case *domain.VerifyEMailStep:

View File

@ -35,6 +35,7 @@ const (
EndpointExternalRegisterCallback = "/register/externalidp/callback" EndpointExternalRegisterCallback = "/register/externalidp/callback"
EndpointRegisterOrg = "/register/org" EndpointRegisterOrg = "/register/org"
EndpointLogoutDone = "/logout/done" EndpointLogoutDone = "/logout/done"
EndpointLoginSuccess = "/login/success"
EndpointExternalNotFoundOption = "/externaluser/option" EndpointExternalNotFoundOption = "/externaluser/option"
EndpointResources = "/resources" EndpointResources = "/resources"
@ -82,5 +83,6 @@ func CreateRouter(login *Login, staticDir http.FileSystem, interceptors ...mux.M
router.PathPrefix(EndpointResources).Handler(login.handleResources(staticDir)).Methods(http.MethodGet) router.PathPrefix(EndpointResources).Handler(login.handleResources(staticDir)).Methods(http.MethodGet)
router.HandleFunc(EndpointRegisterOrg, login.handleRegisterOrg).Methods(http.MethodGet) router.HandleFunc(EndpointRegisterOrg, login.handleRegisterOrg).Methods(http.MethodGet)
router.HandleFunc(EndpointRegisterOrg, login.handleRegisterOrgCheck).Methods(http.MethodPost) router.HandleFunc(EndpointRegisterOrg, login.handleRegisterOrgCheck).Methods(http.MethodPost)
router.HandleFunc(EndpointLoginSuccess, login.handleLoginSuccess).Methods(http.MethodGet)
return router return router
} }

View File

@ -200,6 +200,11 @@ ExternalNotFoundOption:
Link: Verlinken Link: Verlinken
AutoRegister: Automatisches registrieren AutoRegister: Automatisches registrieren
LoginSuccess:
Title: Erfolgreich eingeloggt
AutoRedirect: Du wirst automatisch zurück in die Applikation geleitet. Danach kannst du diese Fenster schliessen.
Redirected: Du kannst diese Fenster nun schliessen.
LogoutDone: LogoutDone:
Title: Ausgeloggt Title: Ausgeloggt
Description: Du wurdest erfolgreich ausgeloggt. Description: Du wurdest erfolgreich ausgeloggt.

View File

@ -190,6 +190,11 @@ RegistrationOrg:
PrivacyLinkText: privacy policy PrivacyLinkText: privacy policy
PrivacyLink: https://zitadel.ch/pdf/privacy.pdf PrivacyLink: https://zitadel.ch/pdf/privacy.pdf
LoginSuccess:
Title: Login successful
AutoRedirect: You will be directed back to your application automatically. If not, click on the button below. You can close the window afterwards.
Redirected: You can now close this window.
LogoutDone: LogoutDone:
Title: Logged out Title: Logged out
Description: You have logged out successfully. Description: You have logged out successfully.

View File

@ -0,0 +1,17 @@
document.addEventListener('DOMContentLoaded', function () {
autoSubmit();
});
function autoSubmit() {
let form = document.getElementsByTagName('form')[0];
if (form) {
let button = document.getElementById("redirect-button");
if (button) {
button.addEventListener("click", function (event) {
location.reload();
event.preventDefault();
});
}
form.submit();
}
}

View File

@ -0,0 +1,32 @@
{{template "main-top" .}}
<div class="lgn-head">
<h1>{{t "LoginSuccess.Title"}}</h1>
{{ template "user-profile" . }}
{{if .RedirectURI}}
<p>{{t "LoginSuccess.AutoRedirect"}}</p>
</div>
<form action="{{ .RedirectURI }}" method="GET">
<input type="hidden" name="id" value="{{ .AuthReqID }}" />
{{ template "error-message" .}}
<div class="lgn-actions">
<span class="fill-space"></span>
<button id="redirect-button" class="lgn-raised-button lgn-primary">{{t "Actions.Next"}}</button>
</div>
</form>
<script src="{{ resourceUrl "scripts/login_success.js" }}"></script>
{{else}}
<p>{{t "LoginSuccess.Redirected"}}</p>
</div>
{{end}}
{{template "main-bottom" .}}