login progress
This commit is contained in:
@@ -1,7 +1,27 @@
|
|||||||
get '/user/auth' do
|
|
||||||
# TODO: do something that makes sense here
|
post '/user/login' do
|
||||||
res = User.find_by(id: 1).try(:authenticate, 'spassword') # => false
|
request.body.rewind
|
||||||
res.to_json
|
login_details = JSON.parse(request.body.read)
|
||||||
|
|
||||||
|
email = login_details['email']
|
||||||
|
password = login_details['password']
|
||||||
|
|
||||||
|
res = User.find_by(email: email).try(:authenticate, password) # => false
|
||||||
|
if res
|
||||||
|
#TODO : encrypt this cookie
|
||||||
|
response.set_cookie('ribica_auth', :path=> '/', :httponly => true, :value=>res.id, :expires=>Time.now+100.year)
|
||||||
|
res.to_json(except: 'password_digest')
|
||||||
|
else
|
||||||
|
status 401
|
||||||
|
{:error => "email ili lozinka neispravni!"}.to_json
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
get '/user' do
|
||||||
|
auth = cookies['ribica_auth']
|
||||||
|
if not auth.nil?
|
||||||
|
return User.find_by(id: auth).to_json(except: 'password_digest')
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
post '/user' do
|
post '/user' do
|
||||||
|
|||||||
@@ -12,12 +12,9 @@ var UserActions = {
|
|||||||
|
|
||||||
user.save(null, {
|
user.save(null, {
|
||||||
success: function() {
|
success: function() {
|
||||||
alert('saved!');
|
|
||||||
UserActions.registrationSuccess();
|
UserActions.registrationSuccess();
|
||||||
},
|
},
|
||||||
error: function(model, response, options) {
|
error: function(model, response, options) {
|
||||||
alert('error');
|
|
||||||
console.log('error:', response);
|
|
||||||
UserActions.registrationFailure(response);
|
UserActions.registrationFailure(response);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
@@ -32,8 +29,36 @@ var UserActions = {
|
|||||||
actionType: UserConstants.REGISTRATION_FAILURE,
|
actionType: UserConstants.REGISTRATION_FAILURE,
|
||||||
error: error
|
error: error
|
||||||
});
|
});
|
||||||
}
|
},
|
||||||
|
userLogin: function(loginDetails) {
|
||||||
|
AppDispatcher.handleAction({
|
||||||
|
actionType: UserConstants.USER_LOGIN,
|
||||||
|
loginDetails: loginDetails
|
||||||
|
});
|
||||||
|
|
||||||
|
loginDetails.save(null, {
|
||||||
|
success: function(){
|
||||||
|
alert('ok')
|
||||||
|
UserActions.loginSuccess();
|
||||||
|
},
|
||||||
|
|
||||||
|
error: function(model, response, options){
|
||||||
|
alert('error!');
|
||||||
|
UserActions.loginFailure(response);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
loginSuccess: function() {
|
||||||
|
AppDispatcher.handleAction({
|
||||||
|
actionType: UserConstants.LOGIN_SUCCESS
|
||||||
|
});
|
||||||
|
},
|
||||||
|
loginFailure: function(error) {
|
||||||
|
AppDispatcher.handleAction({
|
||||||
|
actionType: UserConstants.LOGIN_FAILURE,
|
||||||
|
error: error
|
||||||
|
});
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = UserActions;
|
module.exports = UserActions;
|
||||||
|
|||||||
@@ -1,41 +1,117 @@
|
|||||||
var React = require("react");
|
var React = require("react");
|
||||||
var NavigationActions = require('../../actions/navigationActions');
|
var NavigationActions = require('../../actions/navigationActions');
|
||||||
|
var UserActions = require('../../actions/userActions');
|
||||||
var Router = require('react-router');
|
var Router = require('react-router');
|
||||||
var Link = Router.Link;
|
var Link = Router.Link;
|
||||||
var Login = React.createClass({
|
var RibicaValidationMixin = require('../../components/shared/mixins/ribicaValidationMixin');
|
||||||
|
var ValidationUtils = require('../../utils/validation.js');
|
||||||
|
var LoginModel = require('../../models/login');
|
||||||
|
var UserStore = require('../../stores/userStore');
|
||||||
|
|
||||||
|
var Login = React.createClass({
|
||||||
|
mixins: [RibicaValidationMixin],
|
||||||
|
componentDidMount:function() {
|
||||||
|
UserStore.addChangeListener(this.onUserStoreChange);
|
||||||
|
},
|
||||||
|
componentWillUnmount: function() {
|
||||||
|
UserStore.removeChangeListener(this.onUserStoreChange);
|
||||||
|
},
|
||||||
|
onUserStoreChange: function() {
|
||||||
|
var loginState = UserStore.getLoginState();
|
||||||
|
|
||||||
|
if (loginState.loggedIn) {
|
||||||
|
NavigationActions.goToHome();
|
||||||
|
} else {
|
||||||
|
|
||||||
|
this.setState({login: loginState});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getInitialState: function() {
|
||||||
|
return {
|
||||||
|
email: '',
|
||||||
|
password: '',
|
||||||
|
errors: {},
|
||||||
|
login: UserStore.getLoginState()
|
||||||
|
};
|
||||||
|
},
|
||||||
|
validations: {
|
||||||
|
email:function(value) {
|
||||||
|
|
||||||
|
if(!ValidationUtils.isValidEmail(value)) {
|
||||||
|
return ['Neispravna email adresa.'];
|
||||||
|
}
|
||||||
|
return [];
|
||||||
|
},
|
||||||
|
password: function(value) {
|
||||||
|
if(!ValidationUtils.isValidRequired(value)) {
|
||||||
|
return ["Šifra je obavezna."];
|
||||||
|
}
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
},
|
||||||
|
renderErrorMessage: function(message){
|
||||||
|
return (<div className='error-message'>{message}</div>)
|
||||||
|
},
|
||||||
|
doLogin: function(e) {
|
||||||
|
|
||||||
|
if(this.validate()) {
|
||||||
|
var loginInfo = new LoginModel({
|
||||||
|
email: this.state.email,
|
||||||
|
password: this.state.password
|
||||||
|
});
|
||||||
|
|
||||||
|
UserActions.userLogin(loginInfo);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
e.preventDefault();
|
||||||
|
},
|
||||||
|
renderLoginFailure: function() {
|
||||||
|
|
||||||
|
var loginState = this.state.login;
|
||||||
|
if(!loginState.loggedIn) {
|
||||||
|
return (<div>{loginState.error}</div>)
|
||||||
|
}
|
||||||
|
|
||||||
|
return (<div></div>)
|
||||||
|
},
|
||||||
render : function() {
|
render : function() {
|
||||||
return (<div>
|
return (<div>
|
||||||
<div className="col-md-6">
|
<div className="col-md-6">
|
||||||
|
|
||||||
<span className="h3">Prijava </span>
|
<span className="h3">Prijava </span>
|
||||||
<div className="center" >
|
{this.renderLoginFailure()}
|
||||||
<form className="form-horizontal">
|
<div className="center" >
|
||||||
|
<form className="form-horizontal">
|
||||||
|
|
||||||
<div className="form-group">
|
<div className="form-group">
|
||||||
<label for="email">Email adresa</label>
|
<label for="email">Email adresa</label>
|
||||||
<input type="email" className="form-control" id="email" placeholder="Unesite email"></input>
|
<input type="email" onChange={this.handleChange('email')} className="form-control" id="email" placeholder="Unesite email"></input>
|
||||||
</div>
|
|
||||||
<div className="form-group">
|
|
||||||
<label for="password">Sifra</label>
|
|
||||||
<input type="password" className="form-control" id="password" placeholder="Sifra"></input>
|
|
||||||
</div>
|
|
||||||
<button type="submit" className="btn btn-default">Submit</button>
|
|
||||||
</form>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
|
{this.getValidationMessages('email').map(this.renderErrorMessage)}
|
||||||
</div>
|
</div>
|
||||||
<div className="col-md-6">
|
<div className="form-group">
|
||||||
<Link to="registracija">
|
<label for="password">Šifra</label>
|
||||||
|
<input type="password" onChange={this.handleChange('password')} className="form-control" id="password" placeholder="Šifra"></input>
|
||||||
|
|
||||||
Niste registrovani? Kliknite ovdje da se registrujete!
|
{this.getValidationMessages('password').map(this.renderErrorMessage)}
|
||||||
</Link>
|
</div>
|
||||||
|
<button type="button" onClick={this.doLogin} className="btn btn-default">Prijava</button>
|
||||||
|
</form>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
</div>);
|
<div className="col-md-6">
|
||||||
|
<Link to="registracija">
|
||||||
|
|
||||||
|
Niste registrovani? Kliknite ovdje da se registrujete!
|
||||||
|
</Link>
|
||||||
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>);
|
||||||
}
|
}
|
||||||
})
|
});
|
||||||
|
|
||||||
module.exports = Login;
|
module.exports = Login;
|
||||||
|
|||||||
@@ -3,7 +3,8 @@ var React = require("react/addons"),
|
|||||||
RibicaValidationMixin = require('../../components/shared/mixins/ribicaValidationMixin'),
|
RibicaValidationMixin = require('../../components/shared/mixins/ribicaValidationMixin'),
|
||||||
UserStore = require('../../stores/userStore'),
|
UserStore = require('../../stores/userStore'),
|
||||||
NavigationActions = require('../../actions/navigationActions'),
|
NavigationActions = require('../../actions/navigationActions'),
|
||||||
UserActions = require('../../actions/userActions');
|
UserActions = require('../../actions/userActions'),
|
||||||
|
ValidationUtils = require('../../utils/validation');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -18,7 +19,7 @@ var Register = React.createClass({
|
|||||||
password: '',
|
password: '',
|
||||||
passwordConfirmation: '',
|
passwordConfirmation: '',
|
||||||
errors: {},
|
errors: {},
|
||||||
registrationState: UserStore.getRegistrationState()
|
registration: UserStore.getRegistrationState()
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
myBabyChange: function() {
|
myBabyChange: function() {
|
||||||
@@ -96,12 +97,12 @@ var Register = React.createClass({
|
|||||||
},
|
},
|
||||||
validations: {
|
validations: {
|
||||||
firstName: function(value) {
|
firstName: function(value) {
|
||||||
if (!value || value === '') {
|
if (!ValidationUtils.isValidRequired(value)) {
|
||||||
return ["Ime je obavezno."];
|
return ["Ime je obavezno."];
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
password: function(value, callback) {
|
password: function(value, callback) {
|
||||||
if(value === undefined || value === "") {
|
if(!ValidationUtils.isValidRequired(value)) {
|
||||||
return ["Šifra je obavezna."];
|
return ["Šifra je obavezna."];
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -119,16 +120,14 @@ var Register = React.createClass({
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
lastName : function(value) {
|
lastName : function(value) {
|
||||||
if (!value || value === '') {
|
if (!ValidationUtils.isValidRequired(value)) {
|
||||||
return ["Prezime je obavezno."];
|
return ["Prezime je obavezno."];
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
_emailRe: /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
|
|
||||||
_emailTimeoutId: null,
|
_emailTimeoutId: null,
|
||||||
email: function(value, callback) {
|
email: function(value, callback) {
|
||||||
var validEmail = this._emailRe.test(value);
|
|
||||||
|
|
||||||
if (validEmail) {
|
if (ValidationUtils.isValidEmail(value)) {
|
||||||
//clearTimeout(this._emailTimeoutId);
|
//clearTimeout(this._emailTimeoutId);
|
||||||
//this._emailTimeoutId = setTimeout(function(){
|
//this._emailTimeoutId = setTimeout(function(){
|
||||||
|
|
||||||
@@ -162,11 +161,10 @@ var Register = React.createClass({
|
|||||||
},
|
},
|
||||||
onUserStoreChange: function() {
|
onUserStoreChange: function() {
|
||||||
this.setState({
|
this.setState({
|
||||||
registrationState: UserStore.getRegistrationState()
|
registration: UserStore.getRegistrationState()
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
register: function(e) {
|
register: function(e) {
|
||||||
// TODO: move this to the UserRegistrationStore
|
|
||||||
if(this.validate()) {
|
if(this.validate()) {
|
||||||
var user = new UserRegistration({
|
var user = new UserRegistration({
|
||||||
first_name: this.state.firstName,
|
first_name: this.state.firstName,
|
||||||
@@ -186,24 +184,24 @@ var Register = React.createClass({
|
|||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
},
|
},
|
||||||
renderRegistrationState: function() {
|
renderRegistrationState: function() {
|
||||||
var rs = this.state.registrationState;
|
var rs = this.state.registration;
|
||||||
if (!rs.performed) {
|
if (!rs.performed) {
|
||||||
|
|
||||||
return (<div></div>)
|
return (<div></div>)
|
||||||
} else if(rs.performed && !rs.success){
|
} else if(rs.performed && !rs.success){
|
||||||
return (<div>
|
return (<div>
|
||||||
Desila se pogreska pri registraciji. Detalji greske su:
|
Desila se pogreška pri registraciji. Detalji greške su:
|
||||||
{rs.error.responseJSON}
|
{rs.error.responseJSON}
|
||||||
</div>)
|
</div>)
|
||||||
} else if (rs.performed && rs.success) {
|
} else if (rs.performed && rs.success) {
|
||||||
return (<div>
|
return (<div>
|
||||||
Uspjesno ste se registrovali na Ribicu. Kliknite <a onClick={this.successContinue}>ovdje</a> za nastavak.
|
Uspješno ste se registrovali na Ribicu. Kliknite <a onClick={this.successContinue}>ovdje</a> za nastavak.
|
||||||
</div>)
|
</div>)
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
render : function() {
|
render : function() {
|
||||||
var cx = React.addons.classSet;
|
var cx = React.addons.classSet;
|
||||||
var regSuccess = this.state.registrationState.performed && this.state.registrationState.success;
|
var regSuccess = this.state.registration.performed && this.state.registration.success;
|
||||||
var classes = cx({
|
var classes = cx({
|
||||||
'hide': regSuccess
|
'hide': regSuccess
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -4,5 +4,8 @@ var keyMirror = require('react/lib/keyMirror');
|
|||||||
module.exports = keyMirror({
|
module.exports = keyMirror({
|
||||||
REGISTER_USER : null,
|
REGISTER_USER : null,
|
||||||
REGISTRATION_SUCCESS: null,
|
REGISTRATION_SUCCESS: null,
|
||||||
REGISTRATION_FAILURE: null
|
REGISTRATION_FAILURE: null,
|
||||||
|
USER_LOGIN: null,
|
||||||
|
LOGIN_SUCCESS: null,
|
||||||
|
LOGIN_FAILURE: null
|
||||||
});
|
});
|
||||||
|
|||||||
23
front-ui/app/models/login.js
Normal file
23
front-ui/app/models/login.js
Normal file
@@ -0,0 +1,23 @@
|
|||||||
|
var Backbone = require('backbone');
|
||||||
|
var Globals = require('../globals');
|
||||||
|
|
||||||
|
var Login = Backbone.Model.extend({
|
||||||
|
initialize: function() {
|
||||||
|
$.ajaxPrefilter(
|
||||||
|
function(options, originalOptions, jqXHR) {
|
||||||
|
options.xhrFields = {
|
||||||
|
withCredentials: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
},
|
||||||
|
|
||||||
|
url : Globals.ApiUrl + '/user/login',
|
||||||
|
defaults : {
|
||||||
|
email: '',
|
||||||
|
password: ''
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
|
||||||
|
module.exports = Login;
|
||||||
@@ -3,9 +3,8 @@ var EventEmitter = require('events').EventEmitter;
|
|||||||
var UserConstants = require('../constants/userConstants');
|
var UserConstants = require('../constants/userConstants');
|
||||||
var _ = require('underscore');
|
var _ = require('underscore');
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
var _registrationState = {};
|
var _registrationState = {};
|
||||||
|
var _loginState = {};
|
||||||
|
|
||||||
var handleRegistrationSuccess = function() {
|
var handleRegistrationSuccess = function() {
|
||||||
_registrationState = {
|
_registrationState = {
|
||||||
@@ -22,6 +21,18 @@ var handleRegistrationFailure = function(error) {
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var handleLoginSuccess = function() {
|
||||||
|
_loginState = {
|
||||||
|
loggedIn: true
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
var handleLoginFailure = function(error) {
|
||||||
|
_loginState = {
|
||||||
|
loggedIn: false,
|
||||||
|
error: error
|
||||||
|
};
|
||||||
|
};
|
||||||
// Extend SectionStore with EventEmitter to add eventing capabilities
|
// Extend SectionStore with EventEmitter to add eventing capabilities
|
||||||
var UserStore = _.extend({}, EventEmitter.prototype, {
|
var UserStore = _.extend({}, EventEmitter.prototype, {
|
||||||
|
|
||||||
@@ -29,6 +40,9 @@ var UserStore = _.extend({}, EventEmitter.prototype, {
|
|||||||
//return _categoryDetails;
|
//return _categoryDetails;
|
||||||
return _registrationState;
|
return _registrationState;
|
||||||
},
|
},
|
||||||
|
getLoginState: function() {
|
||||||
|
return _loginState;
|
||||||
|
},
|
||||||
// Emit Change event
|
// Emit Change event
|
||||||
emitChange: function() {
|
emitChange: function() {
|
||||||
console.log("Emmiting Section change!");
|
console.log("Emmiting Section change!");
|
||||||
@@ -54,18 +68,6 @@ AppDispatcher.register(function(payload) {
|
|||||||
|
|
||||||
switch(action.actionType) {
|
switch(action.actionType) {
|
||||||
|
|
||||||
// Respond to SELECT_ITEM action
|
|
||||||
//case SectionConstants.LOAD_SECTIONS:
|
|
||||||
//loadSections();
|
|
||||||
//break;
|
|
||||||
|
|
||||||
//case SectionConstants.SET_SECTION_HOVER:
|
|
||||||
//setHovered(action.section.get('id'));
|
|
||||||
//break;
|
|
||||||
|
|
||||||
//case SectionConstants.UNSET_SECTION_HOVER:
|
|
||||||
//setHovered('');
|
|
||||||
//break;
|
|
||||||
|
|
||||||
case UserConstants.REGISTRATION_SUCCESS:
|
case UserConstants.REGISTRATION_SUCCESS:
|
||||||
handleRegistrationSuccess();
|
handleRegistrationSuccess();
|
||||||
@@ -73,6 +75,12 @@ AppDispatcher.register(function(payload) {
|
|||||||
case UserConstants.REGISTRATION_FAILURE:
|
case UserConstants.REGISTRATION_FAILURE:
|
||||||
handleRegistrationFailure(action.error);
|
handleRegistrationFailure(action.error);
|
||||||
break;
|
break;
|
||||||
|
case UserConstants.LOGIN_SUCCESS:
|
||||||
|
handleLoginSuccess();
|
||||||
|
break;
|
||||||
|
case UserConstants.LOGIN_FAILURE:
|
||||||
|
handleLoginFailure(action.error);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
17
front-ui/app/utils/validation.js
Normal file
17
front-ui/app/utils/validation.js
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
var Validations = {
|
||||||
|
_emailRe: /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/,
|
||||||
|
isValidEmail: function(value) {
|
||||||
|
return this._emailRe.test(value);
|
||||||
|
|
||||||
|
},
|
||||||
|
isValidRequired: function(value) {
|
||||||
|
if(value === undefined || value === "") {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = Validations;
|
||||||
Reference in New Issue
Block a user