log in directly from home page, sign up at /register/
This commit is contained in:
parent
d0edf75c89
commit
c556f78562
@ -82,36 +82,78 @@ define([
|
|||||||
$block.find('button').addClass('btn').addClass('btn-primary');
|
$block.find('button').addClass('btn').addClass('btn-primary');
|
||||||
$block.appendTo($parent);
|
$block.appendTo($parent);
|
||||||
};
|
};
|
||||||
var addButtonHandlers = function () {
|
|
||||||
$('button.login').click(function (e) {
|
|
||||||
var username = $('#name').val();
|
/* Log in UI */
|
||||||
var passwd = $('#password').val();
|
var Login;
|
||||||
var remember = $('#rememberme').is(':checked');
|
// deferred execution to avoid unnecessary asset loading
|
||||||
sessionStorage.login_user = username;
|
var loginReady = function (cb) {
|
||||||
sessionStorage.login_pass = passwd;
|
if (Login) {
|
||||||
sessionStorage.login_rmb = remember;
|
if (typeof(cb) === 'function') { cb(); }
|
||||||
sessionStorage.login = 1;
|
return;
|
||||||
document.location.href = '/user/';
|
}
|
||||||
|
require([
|
||||||
|
'/common/login.js',
|
||||||
|
], function (_Login) {
|
||||||
|
Login = Login || _Login;
|
||||||
|
if (typeof(cb) === 'function') { cb(); }
|
||||||
});
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var $uname = $('#name').on('focus', loginReady);
|
||||||
|
|
||||||
|
var $passwd = $('#password')
|
||||||
|
// background loading of login assets
|
||||||
|
.on('focus', loginReady)
|
||||||
|
// enter key while on password field clicks signup
|
||||||
|
.on('keyup', function (e) {
|
||||||
|
if (e.which !== 13) { return; } // enter
|
||||||
|
$('button.login').click();
|
||||||
|
});
|
||||||
|
|
||||||
|
$('button.login').click(function (e) {
|
||||||
|
loginReady(function () {
|
||||||
|
var uname = $uname.val();
|
||||||
|
var passwd = $passwd.val();
|
||||||
|
|
||||||
|
Login.loginOrRegister(uname, passwd, false, function (err, result) {
|
||||||
|
if (!err) {
|
||||||
|
// successful validation and user already exists
|
||||||
|
// set user hash in localStorage and redirect to drive
|
||||||
|
localStorage.User_hash = result.userHash;
|
||||||
|
document.location.href = '/drive/';
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
switch (err) {
|
||||||
|
case 'NO_SUCH_USER':
|
||||||
|
Cryptpad.alert('Invalid username or password. Try again, or sign up'); // XXX
|
||||||
|
break;
|
||||||
|
case 'INVAL_USER':
|
||||||
|
Cryptpad.alert('Username required'); // XXX
|
||||||
|
break;
|
||||||
|
case 'INVAL_PASS':
|
||||||
|
Cryptpad.alert('Password required'); // XXX
|
||||||
|
break;
|
||||||
|
default: // UNHANDLED ERROR
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
/* End Log in UI */
|
||||||
|
|
||||||
|
var addButtonHandlers = function () {
|
||||||
$('button.register').click(function (e) {
|
$('button.register').click(function (e) {
|
||||||
var username = $('#name').val();
|
var username = $('#name').val();
|
||||||
var passwd = $('#password').val();
|
var passwd = $('#password').val();
|
||||||
var remember = $('#rememberme').is(':checked');
|
var remember = $('#rememberme').is(':checked');
|
||||||
sessionStorage.login_user = username;
|
sessionStorage.login_user = username;
|
||||||
sessionStorage.login_pass = passwd;
|
sessionStorage.login_pass = passwd;
|
||||||
sessionStorage.login_rmb = remember;
|
document.location.href = '/register/';
|
||||||
sessionStorage.register = 1;
|
|
||||||
document.location.href = '/user/';
|
|
||||||
});
|
});
|
||||||
$('button.gotodrive').click(function (e) {
|
$('button.gotodrive').click(function (e) {
|
||||||
document.location.href = '/drive/';
|
document.location.href = '/drive/';
|
||||||
});
|
});
|
||||||
|
|
||||||
var $passwd = $('#password');
|
|
||||||
$passwd.on('keyup', function (e) {
|
|
||||||
if (e.which !== 13) { return; } // enter
|
|
||||||
$('button.login').click();
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
displayCreateButtons();
|
displayCreateButtons();
|
||||||
|
|||||||
@ -1,15 +1,30 @@
|
|||||||
define([
|
define([
|
||||||
'/common/login.js',
|
'/common/login.js',
|
||||||
|
'/common/cryptpad-common.js',
|
||||||
'/common/credential.js',
|
'/common/credential.js',
|
||||||
'/bower_components/jquery/dist/jquery.min.js',
|
'/bower_components/jquery/dist/jquery.min.js',
|
||||||
], function (Login) {
|
], function (Login, Cryptpad) {
|
||||||
var $ = window.jQuery;
|
var $ = window.jQuery;
|
||||||
|
|
||||||
|
var APP = window.APP = {
|
||||||
|
Login: Login,
|
||||||
|
};
|
||||||
|
|
||||||
// text and password input fields
|
// text and password input fields
|
||||||
var $uname = $('#username');
|
var $uname = $('#username');
|
||||||
var $passwd = $('#password');
|
var $passwd = $('#password');
|
||||||
var $confirm = $('#password-confirm');
|
var $confirm = $('#password-confirm');
|
||||||
|
|
||||||
|
if (sessionStorage.login_user) {
|
||||||
|
$uname.val(sessionStorage.login_user);
|
||||||
|
}
|
||||||
|
if (sessionStorage.login_pass) {
|
||||||
|
$passwd.val(sessionStorage.login_pass);
|
||||||
|
}
|
||||||
|
|
||||||
|
[ $uname, $passwd, $confirm]
|
||||||
|
.some(function ($el) { if (!$el.val()) { return ($el.focus(), true); } });
|
||||||
|
|
||||||
// checkboxes
|
// checkboxes
|
||||||
var $checkImport = $('#import-recent');
|
var $checkImport = $('#import-recent');
|
||||||
var $checkAcceptTerms = $('#accept-terms');
|
var $checkAcceptTerms = $('#accept-terms');
|
||||||
@ -17,6 +32,18 @@ define([
|
|||||||
|
|
||||||
var $register = $('button#register');
|
var $register = $('button#register');
|
||||||
|
|
||||||
|
var proxyIsSynced = function (realtime, cb) {
|
||||||
|
realtime.sync();
|
||||||
|
var interval = 300;
|
||||||
|
var check = function () {
|
||||||
|
if (realtime.getAuthDoc() !== realtime.getUserDoc()) {
|
||||||
|
return window.setTimeout(check, interval);
|
||||||
|
}
|
||||||
|
cb();
|
||||||
|
};
|
||||||
|
window.setTimeout(check, interval);
|
||||||
|
};
|
||||||
|
|
||||||
$register.click(function () {
|
$register.click(function () {
|
||||||
var uname = $uname.val();
|
var uname = $uname.val();
|
||||||
var passwd = $passwd.val();
|
var passwd = $passwd.val();
|
||||||
@ -27,17 +54,35 @@ define([
|
|||||||
var doesPromise = $checkPromise[0].checked;
|
var doesPromise = $checkPromise[0].checked;
|
||||||
|
|
||||||
/* basic validation */
|
/* basic validation */
|
||||||
|
if (passwd !== confirmPassword) { // do their passwords match?
|
||||||
// do their passwords match?
|
return void Cryptpad.alert('passwords do not match!'); // XXX
|
||||||
|
|
||||||
if (passwd !== confirmPassword) {
|
|
||||||
alert('invalid password');
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Login.loginOrRegister(uname, passwd, true, function (err, out) {
|
if (!doesAccept) { // do they accept the terms of service?
|
||||||
if (err) { alert(err); }
|
return void Cryptpad.alert('you must accept the terms of service'); // XXX
|
||||||
console.log(out);
|
}
|
||||||
})
|
|
||||||
|
if (!doesPromise) { // do they promise to remember their password?
|
||||||
|
return void Cryptpad.alert("We cannot reset your password if you forget it. It's very important that you remember it!"); // XXX
|
||||||
|
}
|
||||||
|
|
||||||
|
Login.loginOrRegister(uname, passwd, true, function (err, result) {
|
||||||
|
if (err) { return void Cryptpad.alert(err); }
|
||||||
|
console.log(result);
|
||||||
|
var proxy = result.proxy;
|
||||||
|
|
||||||
|
localStorage.User_hash = result.userHash;
|
||||||
|
|
||||||
|
Cryptpad.eraseTempSessionValues();
|
||||||
|
if (shouldImport) {
|
||||||
|
sessionStorage.migrateAnonDrive = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
proxy.login_name = uname;
|
||||||
|
|
||||||
|
proxyIsSynced(result.realtime, function () {
|
||||||
|
document.location.href = '/drive/';
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user