login progress

This commit is contained in:
Edin Dazdarevic
2015-03-02 07:49:36 +01:00
parent 7c28876fed
commit 4befef5bf4
8 changed files with 233 additions and 63 deletions

View File

@@ -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

View File

@@ -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;

View File

@@ -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;

View File

@@ -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
}); });

View File

@@ -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
}); });

View 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;

View File

@@ -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;

View 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;