From c5cb0ec145d273499d17740f8a8ec6d84a0cd081 Mon Sep 17 00:00:00 2001 From: Matthew Dillon Date: Thu, 26 Mar 2015 10:43:36 -0800 Subject: [PATCH] Login: display feedback. --- app/controllers/login.js | 17 +++++++++++++- app/styles/app.css | 44 ++++++++++++++++++++++++++++++++++++ app/templates/login.hbs | 19 +++++++++++----- package.json | 1 + server/index.js | 4 ++++ server/mocks/authenticate.js | 32 ++++++++++++++++---------- 6 files changed, 98 insertions(+), 19 deletions(-) diff --git a/app/controllers/login.js b/app/controllers/login.js index d84a03e..20cb981 100644 --- a/app/controllers/login.js +++ b/app/controllers/login.js @@ -2,5 +2,20 @@ import Ember from 'ember'; import LoginControllerMixin from 'simple-auth/mixins/login-controller-mixin'; export default Ember.Controller.extend(LoginControllerMixin, { - authenticator: 'simple-auth-authenticator:jwt' + authenticator: 'simple-auth-authenticator:jwt', + loading: false, + actions: { + authenticate: function() { + this.set('errorMessage', null); + var _this = this; + this.set('loading', true); + this._super().then(function() { + _this.set('loading', false); + }, function(error) { + _this.set('loading', false); + var message = error.error; + _this.set('errorMessage', message); + }); + } + } }); diff --git a/app/styles/app.css b/app/styles/app.css index 4995509..1bd92ff 100644 --- a/app/styles/app.css +++ b/app/styles/app.css @@ -5,3 +5,47 @@ .flakes-table thead tr { cursor: pointer; } + +/* BEGIN https://github.com/tobiasahlin/SpinKit */ +.spinner { + width: 40px; + height: 40px; + + position: relative; + margin: 100px auto; +} + +.double-bounce1, .double-bounce2 { + width: 100%; + height: 100%; + border-radius: 50%; + background-color: #333; + opacity: 0.6; + position: absolute; + top: 0; + left: 0; + + -webkit-animation: bounce 2.0s infinite ease-in-out; + animation: bounce 2.0s infinite ease-in-out; +} + +.double-bounce2 { + -webkit-animation-delay: -1.0s; + animation-delay: -1.0s; +} + +@-webkit-keyframes bounce { + 0%, 100% { -webkit-transform: scale(0.0) } + 50% { -webkit-transform: scale(1.0) } +} + +@keyframes bounce { + 0%, 100% { + transform: scale(0.0); + -webkit-transform: scale(0.0); + } 50% { + transform: scale(1.0); + -webkit-transform: scale(1.0); + } +} +/* END https://github.com/tobiasahlin/SpinKit */ diff --git a/app/templates/login.hbs b/app/templates/login.hbs index 6db4e1e..d4a4546 100644 --- a/app/templates/login.hbs +++ b/app/templates/login.hbs @@ -1,12 +1,19 @@ {{#if loggedIn}}

You are already logged in!

{{else}} -
-

Log In

- {{input value=identification type="text" placeholder="Username"}} - {{input value=password type="password" placeholder="Password"}} - {{input class="button-gray" type="submit" value="Log In"}} -
+ {{#if loading}} +
+
+
+
+ {{else}} +
+

Log In

+ {{input value=identification type="text" placeholder="Username"}} + {{input value=password type="password" placeholder="Password"}} + {{input class="button-gray" type="submit" value="Log In"}} +
+ {{/if}} {{#if errorMessage}}
{{errorMessage}}
{{/if}} diff --git a/package.json b/package.json index 96cbd97..dc4295e 100644 --- a/package.json +++ b/package.json @@ -19,6 +19,7 @@ "author": "", "license": "MIT", "devDependencies": { + "body-parser": "^1.12.2", "broccoli-asset-rev": "^2.0.0", "connect-restreamer": "^1.0.1", "ember-cli": "0.2.0", diff --git a/server/index.js b/server/index.js index b150571..4bdb85a 100644 --- a/server/index.js +++ b/server/index.js @@ -32,6 +32,10 @@ module.exports = function(app) { app.use(morgan('dev')); app.use(allowCrossDomain); + // Parse json + var bodyParser = require('body-parser'); + app.use(bodyParser.json()); + mocks.forEach(function(route) { route(app); }); proxies.forEach(function(route) { route(app); }); diff --git a/server/mocks/authenticate.js b/server/mocks/authenticate.js index f1e0987..764e66d 100644 --- a/server/mocks/authenticate.js +++ b/server/mocks/authenticate.js @@ -4,18 +4,26 @@ module.exports = function(app) { var authenticateRouter = express.Router(); authenticateRouter.post('/', function(req, res) { - var token = jwt.sign({ - 'name': 'Test User', - 'role': 'admin' - }, 'secret', - { - expiresInMinutes: 60, - issuer: 'bactdb', - subject: 'Test User', - }); - res.send({ - 'token': token - }); + // wait for a bit to simulate cold boot of heroku api + var ms = 3000 + new Date().getTime(); + while (new Date() < ms){} + + if (req.body.username === 'test' && req.body.password === 'test') { + var token = jwt.sign({ + 'name': 'Test User', + 'role': 'admin' + }, 'secret', + { + expiresInMinutes: 60, + issuer: 'bactdb', + subject: 'Test User', + }); + res.send({ + 'token': token + }); + } else { + res.status(401).send({'error':'Invalid username or password'}); + } }); app.use('/api/authenticate', authenticateRouter);