bb0f4bfa62
* Fix wrapping when too many hosts are shown (#207) * Update npm packages, fixes CVE-2019-10757 * Revert some breaking packages * Major overhaul - Docker buildx support in CI - Cypress API Testing in CI - Restructured folder layout (insert clean face meme) - Added Swagger documentation and validate API against that (to be completed) - Use common base image for all supported archs, which includes updated nginx with ipv6 support - Updated certbot and changes required for it - Large amount of Hosts names will wrap in UI - Updated packages for frontend - Version bump 2.1.0 * Updated documentation * Fix JWT expire time going crazy. Now set to 1day * Backend JS formatting rules * Remove v1 importer, I doubt anyone is using v1 anymore * Added backend formatting rules and enforce them in Jenkins builds * Fix CI, doesn't need a tty * Thanks bcrypt. Why can't you just be normal. * Cleanup after syntax check Co-authored-by: Marcelo Castagna <margaale@users.noreply.github.com>
127 lines
2.5 KiB
JavaScript
127 lines
2.5 KiB
JavaScript
const STORAGE_NAME = 'nginx-proxy-manager-tokens';
|
|
|
|
/**
|
|
* @returns {Array}
|
|
*/
|
|
const getStorageTokens = function () {
|
|
let json = window.localStorage.getItem(STORAGE_NAME);
|
|
if (json) {
|
|
try {
|
|
return JSON.parse(json);
|
|
} catch (err) {
|
|
return [];
|
|
}
|
|
}
|
|
|
|
return [];
|
|
};
|
|
|
|
/**
|
|
* @param {Array} tokens
|
|
*/
|
|
const setStorageTokens = function (tokens) {
|
|
window.localStorage.setItem(STORAGE_NAME, JSON.stringify(tokens));
|
|
};
|
|
|
|
const Tokens = {
|
|
|
|
/**
|
|
* @returns {Number}
|
|
*/
|
|
getTokenCount: () => {
|
|
return getStorageTokens().length;
|
|
},
|
|
|
|
/**
|
|
* @returns {Object} t,n
|
|
*/
|
|
getTopToken: () => {
|
|
let tokens = getStorageTokens();
|
|
if (tokens && tokens.length) {
|
|
return tokens[0];
|
|
}
|
|
|
|
return null;
|
|
},
|
|
|
|
/**
|
|
* @returns {String}
|
|
*/
|
|
getNextTokenName: () => {
|
|
let tokens = getStorageTokens();
|
|
if (tokens && tokens.length > 1 && typeof tokens[1] !== 'undefined' && typeof tokens[1].n !== 'undefined') {
|
|
return tokens[1].n;
|
|
}
|
|
|
|
return null;
|
|
},
|
|
|
|
/**
|
|
*
|
|
* @param {String} token
|
|
* @param {String} [name]
|
|
* @returns {Number}
|
|
*/
|
|
addToken: (token, name) => {
|
|
// Get top token and if it's the same, ignore this call
|
|
let top = Tokens.getTopToken();
|
|
if (!top || top.t !== token) {
|
|
let tokens = getStorageTokens();
|
|
tokens.unshift({t: token, n: name || null});
|
|
setStorageTokens(tokens);
|
|
}
|
|
|
|
return Tokens.getTokenCount();
|
|
},
|
|
|
|
/**
|
|
* @param {String} token
|
|
* @returns {Boolean}
|
|
*/
|
|
setCurrentToken: token => {
|
|
let tokens = getStorageTokens();
|
|
if (tokens.length) {
|
|
tokens[0].t = token;
|
|
setStorageTokens(tokens);
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
},
|
|
|
|
/**
|
|
* @param {String} name
|
|
* @returns {Boolean}
|
|
*/
|
|
setCurrentName: name => {
|
|
let tokens = getStorageTokens();
|
|
if (tokens.length) {
|
|
tokens[0].n = name;
|
|
setStorageTokens(tokens);
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
},
|
|
|
|
/**
|
|
* @returns {Number}
|
|
*/
|
|
dropTopToken: () => {
|
|
let tokens = getStorageTokens();
|
|
tokens.shift();
|
|
setStorageTokens(tokens);
|
|
return tokens.length;
|
|
},
|
|
|
|
/**
|
|
*
|
|
*/
|
|
clearTokens: () => {
|
|
window.localStorage.removeItem(STORAGE_NAME);
|
|
}
|
|
|
|
};
|
|
|
|
module.exports = Tokens;
|