mirror of
https://github.com/NginxProxyManager/nginx-proxy-manager.git
synced 2025-06-17 17:56:27 +00:00
v2.1.0 (#293)
* 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>
This commit is contained in:
126
frontend/js/app/tokens.js
Normal file
126
frontend/js/app/tokens.js
Normal file
@ -0,0 +1,126 @@
|
||||
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;
|
Reference in New Issue
Block a user