aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/java/com/juick/www/controllers/Login.java19
-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"