mirror of
https://github.com/DeNNiiInc/dbgate.git
synced 2026-04-30 02:13:57 +00:00
promo widget WIP
This commit is contained in:
@@ -8,6 +8,7 @@ const {
|
|||||||
getCloudContent,
|
getCloudContent,
|
||||||
putCloudContent,
|
putCloudContent,
|
||||||
removeCloudCachedConnection,
|
removeCloudCachedConnection,
|
||||||
|
getPromoWidgetData,
|
||||||
} = require('../utility/cloudIntf');
|
} = require('../utility/cloudIntf');
|
||||||
const connections = require('./connections');
|
const connections = require('./connections');
|
||||||
const socket = require('../utility/socket');
|
const socket = require('../utility/socket');
|
||||||
@@ -283,6 +284,11 @@ module.exports = {
|
|||||||
return getAiGatewayServer();
|
return getAiGatewayServer();
|
||||||
},
|
},
|
||||||
|
|
||||||
|
premiumPromoWidget_meta: true,
|
||||||
|
async premiumPromoWidget() {
|
||||||
|
return getPromoWidgetData();
|
||||||
|
},
|
||||||
|
|
||||||
// chatStream_meta: {
|
// chatStream_meta: {
|
||||||
// raw: true,
|
// raw: true,
|
||||||
// method: 'post',
|
// method: 'post',
|
||||||
|
|||||||
@@ -17,6 +17,7 @@ const currentVersion = require('../currentVersion');
|
|||||||
const logger = getLogger('cloudIntf');
|
const logger = getLogger('cloudIntf');
|
||||||
|
|
||||||
let cloudFiles = null;
|
let cloudFiles = null;
|
||||||
|
let promoWidgetData = null;
|
||||||
|
|
||||||
const DBGATE_IDENTITY_URL = process.env.LOCAL_DBGATE_IDENTITY
|
const DBGATE_IDENTITY_URL = process.env.LOCAL_DBGATE_IDENTITY
|
||||||
? 'http://localhost:3103'
|
? 'http://localhost:3103'
|
||||||
@@ -259,6 +260,30 @@ async function getPublicFileData(path) {
|
|||||||
return resp.data;
|
return resp.data;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function updatePremiumPromoWidget() {
|
||||||
|
try {
|
||||||
|
const fileContent = await fs.readFile(path.join(datadir(), 'promo-widget.json'), 'utf-8');
|
||||||
|
promoWidgetData = JSON.parse(fileContent);
|
||||||
|
} catch (err) {
|
||||||
|
promoWidgetData = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
const tags = (await collectCloudFilesSearchTags()).join(',');
|
||||||
|
|
||||||
|
const resp = await axios.default.get(
|
||||||
|
`${DBGATE_CLOUD_URL}/premium-promo-widget?identifier=${promoWidgetData?.identifier ?? 'nope'}&tags=${tags}`
|
||||||
|
);
|
||||||
|
|
||||||
|
if (!resp.data || resp.data?.state == 'unchanged') {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
promoWidgetData = resp.data;
|
||||||
|
await fs.writeFile(path.join(datadir(), 'promo-widget.json'), JSON.stringify(promoWidgetData, null, 2));
|
||||||
|
|
||||||
|
socket.emitChanged(`promo-widget-changed`);
|
||||||
|
}
|
||||||
|
|
||||||
async function refreshPublicFiles(isRefresh) {
|
async function refreshPublicFiles(isRefresh) {
|
||||||
if (!cloudFiles) {
|
if (!cloudFiles) {
|
||||||
await loadCloudFiles();
|
await loadCloudFiles();
|
||||||
@@ -268,6 +293,9 @@ async function refreshPublicFiles(isRefresh) {
|
|||||||
} catch (err) {
|
} catch (err) {
|
||||||
logger.error(extractErrorLogData(err), 'DBGM-00166 Error updating cloud files');
|
logger.error(extractErrorLogData(err), 'DBGM-00166 Error updating cloud files');
|
||||||
}
|
}
|
||||||
|
if (!isProApp()) {
|
||||||
|
await updatePremiumPromoWidget();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
async function callCloudApiGet(endpoint, signinHolder = null, additionalHeaders = {}) {
|
async function callCloudApiGet(endpoint, signinHolder = null, additionalHeaders = {}) {
|
||||||
@@ -432,6 +460,10 @@ async function getPublicIpInfo() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function getPromoWidgetData() {
|
||||||
|
return promoWidgetData;
|
||||||
|
}
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
createDbGateIdentitySession,
|
createDbGateIdentitySession,
|
||||||
startCloudTokenChecking,
|
startCloudTokenChecking,
|
||||||
@@ -449,4 +481,5 @@ module.exports = {
|
|||||||
readCloudTokenHolder,
|
readCloudTokenHolder,
|
||||||
readCloudTestTokenHolder,
|
readCloudTestTokenHolder,
|
||||||
getPublicIpInfo,
|
getPublicIpInfo,
|
||||||
|
getPromoWidgetData,
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -183,12 +183,16 @@ const cloudContentListLoader = () => ({
|
|||||||
params: {},
|
params: {},
|
||||||
reloadTrigger: { key: `cloud-content-changed` },
|
reloadTrigger: { key: `cloud-content-changed` },
|
||||||
});
|
});
|
||||||
|
|
||||||
const teamFilesLoader = () => ({
|
const teamFilesLoader = () => ({
|
||||||
url: 'team-files/list',
|
url: 'team-files/list',
|
||||||
params: {},
|
params: {},
|
||||||
reloadTrigger: { key: `team-files-changed` },
|
reloadTrigger: { key: `team-files-changed` },
|
||||||
});
|
});
|
||||||
|
const promoWidgetLoader = () => ({
|
||||||
|
url: 'cloud/premium-promo-widget',
|
||||||
|
params: {},
|
||||||
|
reloadTrigger: { key: `promo-widget-changed` },
|
||||||
|
});
|
||||||
|
|
||||||
async function getCore(loader, args) {
|
async function getCore(loader, args) {
|
||||||
const { url, params, reloadTrigger, transform, onLoaded, errorValue } = loader(args);
|
const { url, params, reloadTrigger, transform, onLoaded, errorValue } = loader(args);
|
||||||
@@ -536,3 +540,10 @@ export function getTeamFiles(args) {
|
|||||||
export function useTeamFiles(args) {
|
export function useTeamFiles(args) {
|
||||||
return useCore(teamFilesLoader, args);
|
return useCore(teamFilesLoader, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function getPromoWidget(args) {
|
||||||
|
return getCore(promoWidgetLoader, args);
|
||||||
|
}
|
||||||
|
export function usePromoWidget(args) {
|
||||||
|
return useCore(promoWidgetLoader, args);
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user