Caching campaigns in redis.
This commit is contained in:
parent
d42d280298
commit
bfe6dc866d
|
@ -22,7 +22,7 @@ const props = defineProps({
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
console.log(props.campaign?.banner);
|
// console.log(props.campaign?.banner);
|
||||||
|
|
||||||
function getBanner(campaign) {
|
function getBanner(campaign) {
|
||||||
if (campaign.banner.entity.type === 'network' || !campaign.banner.entity.parent) {
|
if (campaign.banner.entity.type === 'network' || !campaign.banner.entity.parent) {
|
||||||
|
|
|
@ -1,11 +1,13 @@
|
||||||
import initServer from './web/server.js';
|
import initServer from './web/server.js';
|
||||||
import { cacheTagIds } from './tags.js';
|
import { cacheTagIds } from './tags.js';
|
||||||
import { cacheEntityIds } from './entities.js';
|
import { cacheEntityIds } from './entities.js';
|
||||||
|
import { cacheCampaigns } from './campaigns.js';
|
||||||
|
|
||||||
async function init() {
|
async function init() {
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
cacheTagIds(),
|
cacheTagIds(),
|
||||||
cacheEntityIds(),
|
cacheEntityIds(),
|
||||||
|
cacheCampaigns(),
|
||||||
]);
|
]);
|
||||||
|
|
||||||
initServer();
|
initServer();
|
||||||
|
|
|
@ -1,5 +1,11 @@
|
||||||
|
import crypto from 'crypto';
|
||||||
|
|
||||||
import { knexOwner as knex } from './knex.js';
|
import { knexOwner as knex } from './knex.js';
|
||||||
import { curateEntity } from './entities.js';
|
import { curateEntity } from './entities.js';
|
||||||
|
import redis from './redis.js';
|
||||||
|
import initLogger from './logger.js';
|
||||||
|
|
||||||
|
const logger = initLogger();
|
||||||
|
|
||||||
function curateCampaign(campaign) {
|
function curateCampaign(campaign) {
|
||||||
if (!campaign) {
|
if (!campaign) {
|
||||||
|
@ -12,6 +18,9 @@ function curateCampaign(campaign) {
|
||||||
banner: campaign.banner && {
|
banner: campaign.banner && {
|
||||||
id: campaign.banner.id,
|
id: campaign.banner.id,
|
||||||
type: campaign.banner.type,
|
type: campaign.banner.type,
|
||||||
|
width: campaign.banner.width,
|
||||||
|
height: campaign.banner.height,
|
||||||
|
ratio: campaign.banner.ratio,
|
||||||
entity: campaign.banner_entity && curateEntity({ ...campaign.banner_entity, parent: campaign.banner_parent_entity }),
|
entity: campaign.banner_entity && curateEntity({ ...campaign.banner_entity, parent: campaign.banner_parent_entity }),
|
||||||
tags: campaign.banner_tags?.map((tag) => ({
|
tags: campaign.banner_tags?.map((tag) => ({
|
||||||
id: tag.id,
|
id: tag.id,
|
||||||
|
@ -19,29 +28,61 @@ function curateCampaign(campaign) {
|
||||||
name: tag.name,
|
name: tag.name,
|
||||||
})) || [],
|
})) || [],
|
||||||
},
|
},
|
||||||
affiliateId: campaign.affiliate_id,
|
affiliate: campaign.affiliate && {
|
||||||
|
id: campaign.affiliate.id,
|
||||||
|
url: campaign.affiliate.url,
|
||||||
|
parameters: campaign.affiliate.parameters,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getRandomCampaign(options = {}) {
|
export async function getRandomCampaign(options = {}) {
|
||||||
const campaign = await knex.raw(`
|
const rawCampaigns = await redis.hGetAll('traxxx:campaigns');
|
||||||
SELECT
|
const campaigns = Object.values(rawCampaigns).map((rawCampaign) => JSON.parse(rawCampaign));
|
||||||
campaigns.*, row_to_json(banners) as banner, row_to_json(entities) as banner_entity, row_to_json(parents) as banner_parent_entity, json_agg(tags) filter (where tags.id is not null) as banner_tags
|
|
||||||
FROM campaigns
|
const validCampaigns = campaigns.filter((campaign) => {
|
||||||
LEFT JOIN banners ON banners.id = campaigns.banner_id
|
if (options.minRatio && (!campaign.banner || campaign.banner.ratio < options.minRatio)) {
|
||||||
LEFT JOIN banners_tags ON banners_tags.banner_id = banners.id
|
return false;
|
||||||
LEFT JOIN tags ON tags.id = banners_tags.tag_id
|
}
|
||||||
LEFT JOIN entities ON entities.id = banners.entity_id
|
|
||||||
LEFT JOIN entities as parents ON parents.id = entities.parent_id
|
if (options.maxRatio && (!campaign.banner || campaign.banner.ratio > options.maxRatio)) {
|
||||||
WHERE campaigns.banner_id IS NOT NULL
|
return false;
|
||||||
AND ratio >= :minRatio
|
}
|
||||||
AND ratio <= :maxRatio
|
|
||||||
GROUP BY campaigns.id, banners.id, entities.id, parents.id
|
return true;
|
||||||
ORDER BY RANDOM()
|
|
||||||
`, {
|
|
||||||
minRatio: options.minRatio || 0,
|
|
||||||
maxRatio: options.maxRatio || 1000,
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return curateCampaign(campaign.rows[0]);
|
const randomCampaign = validCampaigns[crypto.randomInt(validCampaigns.length)];
|
||||||
|
|
||||||
|
return randomCampaign;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function cacheCampaigns() {
|
||||||
|
const campaigns = await knex('campaigns')
|
||||||
|
.select('campaigns.*')
|
||||||
|
.select(
|
||||||
|
'campaigns.*',
|
||||||
|
knex.raw('row_to_json(affiliates) as affiliate'),
|
||||||
|
knex.raw('row_to_json(banners) as banner'),
|
||||||
|
knex.raw('row_to_json(entities) as banner_entity'),
|
||||||
|
knex.raw('row_to_json(parents) as banner_parent_entity'),
|
||||||
|
knex.raw('json_agg(tags.slug) filter (where tags.id is not null) as banner_tags'),
|
||||||
|
)
|
||||||
|
.leftJoin('affiliates', 'affiliates.id', 'campaigns.affiliate_id')
|
||||||
|
.leftJoin('banners', 'banners.id', 'campaigns.banner_id')
|
||||||
|
.leftJoin('banners_tags', 'banners_tags.banner_id', 'banners.id')
|
||||||
|
.leftJoin('tags', 'tags.id', 'banners_tags.tag_id')
|
||||||
|
.leftJoin('entities', 'entities.id', 'banners.entity_id')
|
||||||
|
.leftJoin('entities as parents', 'parents.id', 'entities.parent_id')
|
||||||
|
.groupBy('campaigns.id', 'affiliates.id', 'banners.id', 'entities.id', 'parents.id');
|
||||||
|
|
||||||
|
await redis.del('traxxx:campaigns');
|
||||||
|
|
||||||
|
await Promise.all(campaigns.map(async (campaign) => {
|
||||||
|
const curatedCampaign = curateCampaign(campaign);
|
||||||
|
|
||||||
|
await redis.hSet('traxxx:campaigns', campaign.id, JSON.stringify(curatedCampaign));
|
||||||
|
}));
|
||||||
|
|
||||||
|
logger.info('Cached campaigns');
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue