2021-11-22 09:19:01 +01:00
|
|
|
/* eslint-disable github/no-then */
|
2021-10-21 15:37:43 +08:00
|
|
|
const {appSubUrl, csrfToken} = window.config;
|
2021-10-17 01:28:04 +08:00
|
|
|
|
|
|
|
export function initUserAuthU2fAuth() {
|
|
|
|
if ($('#wait-for-key').length === 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
u2fApi.ensureSupport().then(() => {
|
2021-10-21 15:37:43 +08:00
|
|
|
$.getJSON(`${appSubUrl}/user/u2f/challenge`).done((req) => {
|
2021-10-17 01:28:04 +08:00
|
|
|
u2fApi.sign(req.appId, req.challenge, req.registeredKeys, 30)
|
|
|
|
.then(u2fSigned)
|
|
|
|
.catch((err) => {
|
|
|
|
if (err === undefined) {
|
|
|
|
u2fError(1);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
u2fError(err.metaData.code);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}).catch(() => {
|
|
|
|
// Fallback in case browser do not support U2F
|
2021-10-21 15:37:43 +08:00
|
|
|
window.location.href = `${appSubUrl}/user/two_factor`;
|
2021-10-17 01:28:04 +08:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function u2fSigned(resp) {
|
|
|
|
$.ajax({
|
2021-10-21 15:37:43 +08:00
|
|
|
url: `${appSubUrl}/user/u2f/sign`,
|
2021-10-17 01:28:04 +08:00
|
|
|
type: 'POST',
|
2021-10-21 15:37:43 +08:00
|
|
|
headers: {'X-Csrf-Token': csrfToken},
|
2021-10-17 01:28:04 +08:00
|
|
|
data: JSON.stringify(resp),
|
|
|
|
contentType: 'application/json; charset=utf-8',
|
|
|
|
}).done((res) => {
|
|
|
|
window.location.replace(res);
|
|
|
|
}).fail(() => {
|
|
|
|
u2fError(1);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function u2fRegistered(resp) {
|
|
|
|
if (checkError(resp)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
$.ajax({
|
2021-10-21 15:37:43 +08:00
|
|
|
url: `${appSubUrl}/user/settings/security/u2f/register`,
|
2021-10-17 01:28:04 +08:00
|
|
|
type: 'POST',
|
2021-10-21 15:37:43 +08:00
|
|
|
headers: {'X-Csrf-Token': csrfToken},
|
2021-10-17 01:28:04 +08:00
|
|
|
data: JSON.stringify(resp),
|
|
|
|
contentType: 'application/json; charset=utf-8',
|
|
|
|
success() {
|
|
|
|
window.location.reload();
|
|
|
|
},
|
|
|
|
fail() {
|
|
|
|
u2fError(1);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function checkError(resp) {
|
|
|
|
if (!('errorCode' in resp)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
if (resp.errorCode === 0) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
u2fError(resp.errorCode);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
function u2fError(errorType) {
|
|
|
|
const u2fErrors = {
|
|
|
|
browser: $('#unsupported-browser'),
|
|
|
|
1: $('#u2f-error-1'),
|
|
|
|
2: $('#u2f-error-2'),
|
|
|
|
3: $('#u2f-error-3'),
|
|
|
|
4: $('#u2f-error-4'),
|
|
|
|
5: $('.u2f_error_5')
|
|
|
|
};
|
|
|
|
u2fErrors[errorType].removeClass('hide');
|
|
|
|
|
2021-11-22 09:19:01 +01:00
|
|
|
for (const type of Object.keys(u2fErrors)) {
|
2021-10-17 01:28:04 +08:00
|
|
|
if (type !== `${errorType}`) {
|
|
|
|
u2fErrors[type].addClass('hide');
|
|
|
|
}
|
2021-11-22 09:19:01 +01:00
|
|
|
}
|
2021-10-17 01:28:04 +08:00
|
|
|
$('#u2f-error').modal('show');
|
|
|
|
}
|
|
|
|
|
|
|
|
export function initUserAuthU2fRegister() {
|
|
|
|
$('#register-device').modal({allowMultiple: false});
|
|
|
|
$('#u2f-error').modal({allowMultiple: false});
|
|
|
|
$('#register-security-key').on('click', (e) => {
|
|
|
|
e.preventDefault();
|
|
|
|
u2fApi.ensureSupport()
|
|
|
|
.then(u2fRegisterRequest)
|
|
|
|
.catch(() => {
|
|
|
|
u2fError('browser');
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function u2fRegisterRequest() {
|
2021-10-21 15:37:43 +08:00
|
|
|
$.post(`${appSubUrl}/user/settings/security/u2f/request_register`, {
|
|
|
|
_csrf: csrfToken,
|
2021-10-17 01:28:04 +08:00
|
|
|
name: $('#nickname').val()
|
|
|
|
}).done((req) => {
|
|
|
|
$('#nickname').closest('div.field').removeClass('error');
|
|
|
|
$('#register-device').modal('show');
|
|
|
|
if (req.registeredKeys === null) {
|
|
|
|
req.registeredKeys = [];
|
|
|
|
}
|
|
|
|
u2fApi.register(req.appId, req.registerRequests, req.registeredKeys, 30)
|
|
|
|
.then(u2fRegistered)
|
|
|
|
.catch((reason) => {
|
|
|
|
if (reason === undefined) {
|
|
|
|
u2fError(1);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
u2fError(reason.metaData.code);
|
|
|
|
});
|
|
|
|
}).fail((xhr) => {
|
|
|
|
if (xhr.status === 409) {
|
|
|
|
$('#nickname').closest('div.field').addClass('error');
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|