mirror of
https://github.com/zadam/trilium.git
synced 2024-11-17 21:21:40 +08:00
59 lines
1.6 KiB
JavaScript
59 lines
1.6 KiB
JavaScript
import utils from "./utils.js";
|
|
import options from './options.js';
|
|
|
|
const PROTECTED_SESSION_ID_KEY = 'protectedSessionId';
|
|
|
|
let lastProtectedSessionOperationDate = 0;
|
|
|
|
setInterval(() => {
|
|
const protectedSessionTimeout = options.getInt('protectedSessionTimeout');
|
|
if (lastProtectedSessionOperationDate
|
|
&& Date.now() - lastProtectedSessionOperationDate > protectedSessionTimeout * 1000) {
|
|
|
|
resetProtectedSession();
|
|
}
|
|
}, 10000);
|
|
|
|
function setProtectedSessionId(id) {
|
|
// using session cookie so that it disappears after browser/tab is closed
|
|
utils.setSessionCookie(PROTECTED_SESSION_ID_KEY, id);
|
|
}
|
|
|
|
function resetSessionCookie() {
|
|
utils.setSessionCookie(PROTECTED_SESSION_ID_KEY, null);
|
|
}
|
|
|
|
function resetProtectedSession() {
|
|
resetSessionCookie();
|
|
|
|
// most secure solution - guarantees nothing remained in memory
|
|
// since this expires because user doesn't use the app, it shouldn't be disruptive
|
|
utils.reloadApp();
|
|
}
|
|
|
|
function isProtectedSessionAvailable() {
|
|
return !!utils.getCookie(PROTECTED_SESSION_ID_KEY);
|
|
}
|
|
|
|
function touchProtectedSession() {
|
|
if (isProtectedSessionAvailable()) {
|
|
lastProtectedSessionOperationDate = Date.now();
|
|
|
|
setProtectedSessionId(utils.getCookie(PROTECTED_SESSION_ID_KEY));
|
|
}
|
|
}
|
|
|
|
function touchProtectedSessionIfNecessary(note) {
|
|
if (note && note.isProtected && isProtectedSessionAvailable()) {
|
|
touchProtectedSession();
|
|
}
|
|
}
|
|
|
|
export default {
|
|
setProtectedSessionId,
|
|
resetSessionCookie,
|
|
resetProtectedSession,
|
|
isProtectedSessionAvailable,
|
|
touchProtectedSession,
|
|
touchProtectedSessionIfNecessary
|
|
};
|