cryptpad/www/recovery/main.js

157 lines
5.6 KiB
JavaScript
Raw Normal View History

2023-10-20 14:35:26 +00:00
// SPDX-FileCopyrightText: 2023 XWiki CryptPad Team <contact@cryptpad.org> and contributors
//
// SPDX-License-Identifier: AGPL-3.0-or-later
2023-05-15 15:33:58 +00:00
define([
'jquery',
'json.sortify',
'/customize/login.js',
'/common/cryptpad-common.js',
//'/common/test.js',
'/common/common-credential.js',
'/common/common-interface.js',
'/common/common-util.js',
'/common/common-realtime.js',
'/common/common-constants.js',
'/common/common-feedback.js',
'/common/clipboard.js',
2023-05-15 15:33:58 +00:00
'/common/outer/local-store.js',
'/common/outer/login-block.js',
'/common/outer/http-command.js',
2023-07-11 08:30:36 +00:00
'/components/tweetnacl/nacl-fast.min.js',
2023-05-15 15:33:58 +00:00
2023-07-11 08:30:36 +00:00
'css!/components/components-font-awesome/css/font-awesome.min.css',
2023-05-15 15:33:58 +00:00
], function ($, Sortify, Login, Cryptpad, /*Test,*/ Cred, UI, Util, Realtime, Constants, Feedback,
Clipboard, LocalStore, Block, ServerCommand) {
2023-05-15 15:33:58 +00:00
if (window.top !== window) { return; }
var Messages = Cryptpad.Messages;
var Nacl = window.nacl;
$(function () {
if (LocalStore.isLoggedIn()) {
// already logged in, redirect to drive
document.location.href = '/drive/';
return;
}
// text and password input fields
var $uname = $('#username');
var $passwd = $('#password');
2023-06-20 10:52:04 +00:00
var $recoveryKey = $('#mfarecovery');
var $copyProof = $('#mfacopyproof');
2023-05-15 15:33:58 +00:00
var $step1 = $('.cp-recovery-step.step1');
var $step2 = $('.cp-recovery-step.step2');
var $stepInfo = $('.cp-recovery-step.step-info');
2023-06-20 10:52:04 +00:00
var $mfaProof = $('textarea.cp-recover-email');
var $forgot = $('.cp-recovery-forgot');
var $alt = $('.cp-recovery-alt');
2023-05-15 15:33:58 +00:00
[ $uname, $passwd]
.some(function ($el) { if (!$el.val()) { $el.focus(); return true; } });
2023-06-20 10:52:04 +00:00
var mfaStep2 = function () {
2023-05-15 15:33:58 +00:00
$step1.hide();
$step2.show();
};
2023-06-20 10:52:04 +00:00
var mfaStepInfo = function (cls) {
2023-05-15 15:33:58 +00:00
$step1.hide();
$stepInfo.find('.alert').toggleClass('cp-hidden', true);
$stepInfo.find(cls).toggleClass('cp-hidden', false);
$stepInfo.show();
};
2023-06-20 10:52:04 +00:00
$forgot.click(function () {
$alt.toggle();
if ($alt.is(':visible')) { $forgot.find('i').attr('class', 'fa fa-caret-down'); }
else { $forgot.find('i').attr('class', 'fa fa-caret-right'); }
});
var proofStr;
2023-05-15 15:33:58 +00:00
var addProof = function (blockKeys) {
var pub = blockKeys.sign.publicKey;
var sec = blockKeys.sign.secretKey;
var toSign = {
intent: 'Disable TOTP',
date: new Date().toISOString(),
blockId: Nacl.util.encodeBase64(pub),
};
var proof = Nacl.sign.detached(Nacl.util.decodeUTF8(Sortify(toSign)), sec);
toSign.proof = Nacl.util.encodeBase64(proof);
proofStr = JSON.stringify(toSign, 0, 2);
2023-06-20 10:52:04 +00:00
$mfaProof.html(proofStr);
2023-05-15 15:33:58 +00:00
};
$copyProof.click(function () {
if (!proofStr) { return; }
Clipboard.copy(proofStr, (err) => {
if (!err) { return UI.log(Messages.genericCopySuccess); }
UI.warn(Messages.error);
});
});
2023-06-20 10:52:04 +00:00
var blockKeys, blockHash, uname;
var revokeTOTP = function () {
2023-05-15 15:33:58 +00:00
var recoveryKey = $recoveryKey.val().trim();
if (!recoveryKey || recoveryKey.length !== 32) {
2023-07-13 12:12:47 +00:00
return void UI.warn(Messages.error);
2023-05-15 15:33:58 +00:00
}
ServerCommand(blockKeys.sign, {
command: 'TOTP_REVOKE',
recoveryKey: recoveryKey
}, function (err, response) {
var success = !err && response && response.success;
if (!success) {
console.error(err, response);
return void UI.warn(Messages.error);
}
2023-06-20 10:52:04 +00:00
UI.log(Messages.ui_success);
LocalStore.login(undefined, blockHash, uname, function () {
Login.redirect();
});
2023-05-15 15:33:58 +00:00
});
};
var $recoverLogin = $('button#cp-recover-login');
var $recoverConfirm = $('button#cp-recover');
$recoverLogin.click(function () {
UI.addLoadingScreen({
loadingText: Messages.login_hashing
});
2023-06-20 10:52:04 +00:00
uname = $uname.val();
2023-05-15 15:33:58 +00:00
var pw = $passwd.val();
setTimeout(function () {
2023-06-20 10:52:04 +00:00
Login.Cred.deriveFromPassphrase(uname, pw, Login.requiredBytes, function (bytes) {
2023-05-15 15:33:58 +00:00
var result = Login.allocateBytes(bytes);
2023-06-20 10:52:04 +00:00
blockHash = result.blockHash;
2023-05-15 15:33:58 +00:00
var parsed = Block.parseBlockHash(blockHash);
addProof(result.blockKeys);
blockKeys = result.blockKeys;
Util.getBlock(parsed.href, {}, function (err, v) {
UI.removeLoadingScreen();
if (v && !err) {
2023-06-20 10:52:04 +00:00
return mfaStepInfo('.disabled');
2023-05-15 15:33:58 +00:00
}
if (err === 401) {
2023-06-20 10:52:04 +00:00
return mfaStep2(result.blockKeys);
2023-05-15 15:33:58 +00:00
}
if (err === 404) {
return $step1.find('.wrong-cred').toggleClass('cp-hidden', false);
}
2023-06-20 10:52:04 +00:00
mfaStepInfo('.unknown-error');
2023-05-15 15:33:58 +00:00
});
});
}, 100);
});
$recoverConfirm[0].onclick = function () {
2023-05-15 15:33:58 +00:00
if (!blockKeys) { return; }
2023-06-20 10:52:04 +00:00
revokeTOTP();
};
2023-05-15 15:33:58 +00:00
});
});