2019-11-10 03:20:22 +00:00
|
|
|
'use strict';
|
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
// const logger = require('./logger')(__filename);
|
2020-03-26 02:32:07 +00:00
|
|
|
const knex = require('./knex');
|
2020-01-07 03:23:28 +00:00
|
|
|
const slugify = require('./utils/slugify');
|
2020-03-26 02:32:07 +00:00
|
|
|
const capitalize = require('./utils/capitalize');
|
2019-11-10 03:20:22 +00:00
|
|
|
|
2020-03-26 02:32:07 +00:00
|
|
|
function toBaseActors(actorsOrNames, release) {
|
2020-03-24 02:48:24 +00:00
|
|
|
return actorsOrNames.map((actorOrName) => {
|
2020-03-27 03:39:13 +00:00
|
|
|
const name = capitalize(actorOrName.name || actorOrName);
|
|
|
|
const slug = slugify(name);
|
|
|
|
|
|
|
|
const baseActor = {
|
|
|
|
name,
|
|
|
|
slug,
|
|
|
|
network: release.site.network,
|
|
|
|
};
|
|
|
|
|
2020-03-24 02:48:24 +00:00
|
|
|
if (actorOrName.name) {
|
2019-11-30 04:55:32 +00:00
|
|
|
return {
|
2020-03-24 02:48:24 +00:00
|
|
|
...actorOrName,
|
2020-03-27 03:39:13 +00:00
|
|
|
...baseActor,
|
2019-11-30 04:55:32 +00:00
|
|
|
};
|
2020-03-24 02:48:24 +00:00
|
|
|
}
|
|
|
|
|
2020-03-27 03:39:13 +00:00
|
|
|
return baseActor;
|
2020-03-24 02:48:24 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
function curateActorEntry(baseActor, batchId) {
|
2020-03-27 03:39:13 +00:00
|
|
|
return {
|
|
|
|
name: baseActor.name,
|
|
|
|
slug: baseActor.slug,
|
2020-05-13 00:56:20 +00:00
|
|
|
network_id: null,
|
|
|
|
batch_id: batchId,
|
2020-03-27 03:39:13 +00:00
|
|
|
};
|
2020-03-26 02:32:07 +00:00
|
|
|
}
|
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
function curateActorEntries(baseActors, batchId) {
|
|
|
|
return baseActors.map(baseActor => curateActorEntry(baseActor, batchId));
|
2020-03-26 02:32:07 +00:00
|
|
|
}
|
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
async function getOrCreateActors(baseActors, batchId) {
|
2020-03-26 02:32:07 +00:00
|
|
|
const existingActors = await knex('actors')
|
2020-05-13 18:27:06 +00:00
|
|
|
.select('id', 'alias_for', 'name', 'slug', 'network_id')
|
2020-03-26 02:32:07 +00:00
|
|
|
.whereIn('slug', baseActors.map(baseActor => baseActor.slug))
|
2020-03-27 03:39:13 +00:00
|
|
|
.whereNull('network_id')
|
2020-05-13 00:56:20 +00:00
|
|
|
.orWhereIn(['slug', 'network_id'], baseActors.map(baseActor => [baseActor.slug, baseActor.network.id]));
|
|
|
|
|
|
|
|
// const existingActorSlugs = new Set(existingActors.map(actor => actor.slug));
|
|
|
|
const existingActorSlugs = existingActors.reduce((acc, actor) => ({
|
|
|
|
...acc,
|
|
|
|
[actor.network_id]: {
|
|
|
|
...acc[actor.network_id],
|
|
|
|
[actor.slug]: true,
|
|
|
|
},
|
|
|
|
}), {});
|
2020-03-26 02:32:07 +00:00
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
const uniqueBaseActors = baseActors.filter(baseActor => !existingActorSlugs[baseActor.network.id]?.[baseActor.slug] && !existingActorSlugs.null?.[baseActor.slug]);
|
2020-03-27 03:39:13 +00:00
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
const curatedActorEntries = curateActorEntries(uniqueBaseActors, batchId);
|
2020-05-13 18:27:06 +00:00
|
|
|
const newActors = await knex('actors').insert(curatedActorEntries, ['id', 'alias_for', 'name', 'slug', 'network_id']);
|
2020-03-27 03:39:13 +00:00
|
|
|
|
|
|
|
if (Array.isArray(newActors)) {
|
|
|
|
return newActors.concat(existingActors);
|
2020-03-26 02:32:07 +00:00
|
|
|
}
|
|
|
|
|
2020-03-27 03:39:13 +00:00
|
|
|
return existingActors;
|
2020-03-26 02:32:07 +00:00
|
|
|
}
|
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
async function associateActors(releases, batchId) {
|
2020-03-26 02:32:07 +00:00
|
|
|
const baseActorsByReleaseId = releases.reduce((acc, release) => {
|
|
|
|
if (release.actors) {
|
|
|
|
acc[release.id] = toBaseActors(release.actors, release);
|
|
|
|
}
|
|
|
|
|
|
|
|
return acc;
|
|
|
|
}, {});
|
|
|
|
|
|
|
|
const baseActors = Object.values(baseActorsByReleaseId).flat();
|
2020-03-28 00:40:02 +00:00
|
|
|
|
|
|
|
if (baseActors.length === 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-05-13 00:56:20 +00:00
|
|
|
const baseActorsBySlugAndNetworkId = baseActors.reduce((acc, baseActor) => ({
|
|
|
|
...acc,
|
|
|
|
[baseActor.slug]: {
|
|
|
|
...acc[baseActor.slug],
|
|
|
|
[baseActor.network.id]: baseActor,
|
|
|
|
},
|
|
|
|
}), {});
|
|
|
|
|
|
|
|
const uniqueBaseActors = Object.values(baseActorsBySlugAndNetworkId).map(baseActorsByNetworkId => Object.values(baseActorsByNetworkId)).flat();
|
|
|
|
|
|
|
|
const actors = await getOrCreateActors(uniqueBaseActors, batchId);
|
2020-05-13 18:27:06 +00:00
|
|
|
console.log(actors);
|
2020-05-13 00:56:20 +00:00
|
|
|
const actorIdsBySlugAndNetworkId = actors.reduce((acc, actor) => ({
|
|
|
|
...acc,
|
|
|
|
[actor.network_id]: {
|
|
|
|
...acc[actor.network_id],
|
2020-05-13 18:27:06 +00:00
|
|
|
[actor.slug]: actor.alias_for || actor.id,
|
2020-05-13 00:56:20 +00:00
|
|
|
},
|
|
|
|
}), {});
|
2020-03-27 03:39:13 +00:00
|
|
|
|
2020-05-13 18:27:06 +00:00
|
|
|
console.log(actorIdsBySlugAndNetworkId);
|
|
|
|
|
2020-03-27 03:39:13 +00:00
|
|
|
const releaseActorAssociations = Object.entries(baseActorsByReleaseId)
|
|
|
|
.map(([releaseId, releaseActors]) => releaseActors
|
|
|
|
.map(releaseActor => ({
|
|
|
|
release_id: releaseId,
|
2020-05-13 00:56:20 +00:00
|
|
|
actor_id: actorIdsBySlugAndNetworkId[releaseActor.network.id]?.[releaseActor.slug] || actorIdsBySlugAndNetworkId.null[releaseActor.slug],
|
2020-03-27 03:39:13 +00:00
|
|
|
})))
|
|
|
|
.flat();
|
2020-01-27 00:41:04 +00:00
|
|
|
|
2020-03-27 03:39:13 +00:00
|
|
|
await knex.raw(`${knex('releases_actors').insert(releaseActorAssociations).toString()} ON CONFLICT DO NOTHING;`);
|
2019-11-11 02:20:00 +00:00
|
|
|
}
|
|
|
|
|
2019-11-10 03:20:22 +00:00
|
|
|
module.exports = {
|
2020-03-24 02:48:24 +00:00
|
|
|
associateActors,
|
2019-11-10 03:20:22 +00:00
|
|
|
};
|