diff options
Diffstat (limited to 'src/main')
-rw-r--r-- | src/main/java/com/juick/www/controllers/Login.java | 19 | ||||
-rw-r--r-- | src/main/resources/templates/layouts/login.html (renamed from src/main/resources/templates/views/login.html) | 45 |
2 files changed, 47 insertions, 17 deletions
diff --git a/src/main/java/com/juick/www/controllers/Login.java b/src/main/java/com/juick/www/controllers/Login.java index 8f3e9e9a..33fcc011 100644 --- a/src/main/java/com/juick/www/controllers/Login.java +++ b/src/main/java/com/juick/www/controllers/Login.java @@ -19,12 +19,16 @@ package com.juick.www.controllers; import com.juick.model.User; import com.juick.service.UserService; import com.juick.service.security.annotation.Visitor; + +import org.springframework.security.core.AuthenticationException; +import org.springframework.security.web.WebAttributes; import org.springframework.stereotype.Controller; import org.springframework.ui.ModelMap; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestParam; import javax.inject.Inject; +import javax.servlet.http.HttpSession; /** * @author Ugnich Anton @@ -35,14 +39,21 @@ public class Login { private UserService userService; @GetMapping("/login") - public String getloginForm( - @Visitor User visitor, - @RequestParam(required = false, defaultValue = "true") boolean redirect) { + public String getloginForm(@Visitor User visitor, HttpSession session, + @RequestParam(required = false, defaultValue = "true") boolean redirect, ModelMap model) { if (!visitor.isAnonymous()) { return redirect ? "redirect:/" : "redirect:/login/success"; } - return "views/login"; + AuthenticationException authEx = (AuthenticationException) session + .getAttribute(WebAttributes.AUTHENTICATION_EXCEPTION); + + if (authEx != null) { + model.addAttribute("authErrorMessage", authEx.getLocalizedMessage()); + } + + return "layouts/login"; } + @GetMapping("/login/success") public String getSuccessLogin(@Visitor User visitor, ModelMap model) { model.addAttribute("hash", userService.getHashByUID(visitor.getUid())); diff --git a/src/main/resources/templates/views/login.html b/src/main/resources/templates/layouts/login.html index 2f6cc741..4a3be9b8 100644 --- a/src/main/resources/templates/views/login.html +++ b/src/main/resources/templates/layouts/login.html @@ -3,20 +3,35 @@ <head> <title>Juick</title> - <script type="text/javascript" src="//ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js" - defer="defer"></script> + <link rel="stylesheet" type="text/css" href="{{ beans.webApp.styleUrl }}" /> + <script> + function showLoginForm() { + var form = document.getElementById('signinform'); + form.style.display = 'block'; + var nick = document.getElementById('nickinput'); + nick.focus(); + return false; + } + function ready(fn) { + if (document.readyState != 'loading') { + fn(); + } else { + document.addEventListener('DOMContentLoaded', fn); + } + } + ready(function() { + var params = new URLSearchParams(window.location.search); + if (params.has('error')) { + showLoginForm(); + } + }); + </script> <style> * { margin: 0; padding: 0; } - html { - font-family: sans-serif; - font-size: 12pt; - background: #f8f8f8; - } - body { margin: 100px auto 0 auto; width: 1000px; @@ -74,12 +89,12 @@ padding-top: 25px; } - #signup > div { + #signup>div { width: 100%; margin: 15px 0; } - #signup > div > a { + #signup>div>a { display: block; width: 100%; height: 32px; @@ -99,7 +114,7 @@ background: url("") no-repeat #6d8fb3; } - #xmpp > a { + #xmpp>a { color: #333; background: url("") no-repeat #BBB; } @@ -135,12 +150,15 @@ margin: 3px 0; padding: 3px; } + + .err { + color: red; + } </style> <link rel="icon" href="//i.juick.com/favicon.png" /> </head> <body> - <ul id="tags"> <li><a href="/tag/juick" style="left: 359px; top: 120px; width: 311px; height: 99px;">juick</a></li> <li><a href="/tag/linux" style="left: 201px; top: 100px; width: 98px; height: 35px;">linux</a></li> @@ -242,11 +260,12 @@ </div> </div> <div id="signin"> - <a href="#" onclick="$('#signinform').toggle(); $('#nickinput').focus(); return false"> + <a href="#" onclick="return showLoginForm();"> {{ i18n("messages","question.areRegistered") }} </a> <div id="signinform"> <form action="/login" method="POST"> + <p class="err">{{ authErrorMessage | default('') }}</p> <input class="txt" type="text" name="username" placeholder='{{ i18n("messages","label.username") }}' id="nickinput" /> <input class="txt" type="password" name="password" |