mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-19 22:26:01 +00:00
admin access token
This commit is contained in:
@@ -3,6 +3,7 @@
|
||||
import _ from 'lodash';
|
||||
import { TabDefinition } from '../stores';
|
||||
import getElectron from './getElectron';
|
||||
import { getOpenedTabsStorageName } from './pageDefs';
|
||||
|
||||
let counter = 0;
|
||||
$: counterCopy = counter;
|
||||
@@ -26,15 +27,15 @@
|
||||
)
|
||||
) {
|
||||
try {
|
||||
let openedTabs = (await localforage.getItem<TabDefinition[]>('openedTabs')) || [];
|
||||
let openedTabs = (await localforage.getItem<TabDefinition[]>(getOpenedTabsStorageName())) || [];
|
||||
if (!_.isArray(openedTabs)) openedTabs = [];
|
||||
openedTabs = openedTabs
|
||||
.map(tab => (tab.closedTime ? tab : { ...tab, closedTime: new Date().getTime() }))
|
||||
.map(tab => ({ ...tab, selected: false }));
|
||||
await localforage.setItem('openedTabs', openedTabs);
|
||||
await localforage.setItem(getOpenedTabsStorageName(), openedTabs);
|
||||
await localStorage.setItem('selectedWidget', 'history');
|
||||
} catch (err) {
|
||||
localforage.removeItem('openedTabs');
|
||||
localforage.removeItem(getOpenedTabsStorageName());
|
||||
}
|
||||
// try {
|
||||
// await localforage.clear();
|
||||
|
||||
@@ -1,6 +1,5 @@
|
||||
import { getOpenedTabs, openedTabs } from '../stores';
|
||||
import _ from 'lodash';
|
||||
import getElectron from './getElectron';
|
||||
|
||||
export class LoadingToken {
|
||||
isCanceled = false;
|
||||
|
||||
@@ -1,14 +1,15 @@
|
||||
import moment from 'moment';
|
||||
import localforage from 'localforage';
|
||||
import { getOpenedTabsStorageName } from './pageDefs';
|
||||
|
||||
export default async function localStorageGarbageCollector() {
|
||||
const openedTabsJson = await localforage.getItem('openedTabs');
|
||||
const openedTabsJson = await localforage.getItem(getOpenedTabsStorageName());
|
||||
let openedTabs = openedTabsJson ?? [];
|
||||
|
||||
const closeLimit = moment().add(-7, 'day').valueOf();
|
||||
|
||||
openedTabs = openedTabs.filter(x => !x.closedTime || x.closedTime > closeLimit);
|
||||
await localforage.setItem('openedTabs', openedTabs);
|
||||
await localforage.setItem(getOpenedTabsStorageName(), openedTabs);
|
||||
|
||||
const toRemove = [];
|
||||
for (const key in localStorage) {
|
||||
|
||||
15
packages/web/src/utility/pageDefs.ts
Normal file
15
packages/web/src/utility/pageDefs.ts
Normal file
@@ -0,0 +1,15 @@
|
||||
let isAdminPageCache;
|
||||
|
||||
export function isAdminPage() {
|
||||
if (isAdminPageCache == null) {
|
||||
const params = new URLSearchParams(location.search);
|
||||
const urlPage = params.get('page');
|
||||
|
||||
isAdminPageCache = urlPage == 'admin';
|
||||
}
|
||||
return isAdminPageCache;
|
||||
}
|
||||
|
||||
export function getOpenedTabsStorageName() {
|
||||
return isAdminPage() ? 'adminOpenedTabs' : 'openedTabs';
|
||||
}
|
||||
@@ -1,4 +1,5 @@
|
||||
import getElectron from './getElectron';
|
||||
import { isAdminPage } from './pageDefs';
|
||||
|
||||
let apiUrl = null;
|
||||
try {
|
||||
@@ -16,7 +17,7 @@ export function resolveApiHeaders() {
|
||||
const electron = getElectron();
|
||||
|
||||
const res = {};
|
||||
const accessToken = localStorage.getItem('accessToken');
|
||||
const accessToken = localStorage.getItem(isAdminPage() ? 'adminAccessToken' : 'accessToken');
|
||||
if (accessToken) {
|
||||
res['Authorization'] = `Bearer ${accessToken}`;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user