fix: missing metadata preventing game import

when a metadata provider fails to import a game's developer / publisher, the import is no longer blocked. the imports usally fail because there isn't a page for these compaines
This commit is contained in:
Huskydog9988
2025-05-08 11:57:13 -04:00
committed by DecDuck
parent 836ba33fe4
commit 0c48d42c2d
5 changed files with 40 additions and 20 deletions

View File

@ -175,14 +175,18 @@ export class GiantBombProvider implements MetadataProvider {
const publishers: Publisher[] = [];
if (gameData.publishers) {
for (const pub of gameData.publishers) {
publishers.push(await publisher(pub.name));
const res = await publisher(pub.name);
if (res === undefined) continue;
publishers.push(res);
}
}
const developers: Developer[] = [];
if (gameData.developers) {
for (const dev of gameData.developers) {
developers.push(await developer(dev.name));
const res = await developer(dev.name);
if (res === undefined) continue;
developers.push(res);
}
}

View File

@ -334,10 +334,16 @@ export class IGDBProvider implements MetadataProvider {
for (const company of findCompanyResponse) {
// if company was a dev or publisher
// CANNOT use else since a company can be both
if (foundInvolved.developer)
developers.push(await developer(company.name));
if (foundInvolved.publisher)
publishers.push(await publisher(company.name));
if (foundInvolved.developer) {
const res = await developer(company.name);
if (res === undefined) continue;
developers.push(res);
}
if (foundInvolved.publisher) {
const res = await publisher(company.name);
if (res === undefined) continue;
publishers.push(res);
}
}
}
}
@ -403,7 +409,7 @@ export class IGDBProvider implements MetadataProvider {
return metadata;
}
throw new Error("No results found");
throw new Error(`igdb failed to find publisher/developer ${query}`);
}
async fetchDeveloper(
params: _FetchDeveloperMetadataParams,

View File

@ -39,10 +39,10 @@ export abstract class MetadataProvider {
abstract fetchGame(params: _FetchGameMetadataParams): Promise<GameMetadata>;
abstract fetchPublisher(
params: _FetchPublisherMetadataParams,
): Promise<PublisherMetadata>;
): Promise<PublisherMetadata | undefined>;
abstract fetchDeveloper(
params: _FetchDeveloperMetadataParams,
): Promise<DeveloperMetadata>;
): Promise<DeveloperMetadata | undefined>;
}
export class MetadataHandler {
@ -192,7 +192,7 @@ export class MetadataHandler {
query,
"fetchDeveloper",
"developer",
)) as Developer;
)) as Developer | undefined;
}
async fetchPublisher(query: string) {
@ -200,7 +200,7 @@ export class MetadataHandler {
query,
"fetchPublisher",
"publisher",
)) as Publisher;
)) as Publisher | undefined;
}
// Careful with this function, it has no typechecking
@ -226,9 +226,14 @@ export class MetadataHandler {
{},
["internal:read"],
);
let result: PublisherMetadata;
let result: PublisherMetadata | undefined;
try {
result = await provider[functionName]({ query, createObject });
if (result === undefined) {
throw new Error(
`${provider.source()} failed to find a ${databaseName} for "${query}`,
);
}
} catch (e) {
console.warn(e);
dumpObjects();
@ -257,9 +262,10 @@ export class MetadataHandler {
return object;
}
throw new Error(
`No metadata provider found a ${databaseName} for "${query}"`,
);
// throw new Error(
// `No metadata provider found a ${databaseName} for "${query}"`,
// );
return undefined;
}
}

View File

@ -171,7 +171,9 @@ export class PCGamingWikiProvider implements MetadataProvider {
if (game.Publishers !== null) {
const pubListClean = this.parseCompanyStr(game.Publishers);
for (const pub of pubListClean) {
publishers.push(await publisher(pub));
const res = await publisher(pub);
if (res === undefined) continue;
publishers.push(res);
}
}
@ -179,7 +181,9 @@ export class PCGamingWikiProvider implements MetadataProvider {
if (game.Developers !== null) {
const devListClean = this.parseCompanyStr(game.Developers);
for (const dev of devListClean) {
developers.push(await developer(dev));
const res = await developer(dev);
if (res === undefined) continue;
developers.push(res);
}
}
@ -249,7 +253,7 @@ export class PCGamingWikiProvider implements MetadataProvider {
return metadata;
}
throw new Error("Error in pcgamingwiki, no publisher");
throw new Error(`pcgamingwiki failed to find publisher/developer ${query}`);
}
async fetchDeveloper(

View File

@ -57,8 +57,8 @@ export interface _FetchGameMetadataParams {
id: string;
name: string;
publisher: (query: string) => Promise<Publisher>;
developer: (query: string) => Promise<Developer>;
publisher: (query: string) => Promise<Publisher | undefined>;
developer: (query: string) => Promise<Developer | undefined>;
createObject: (data: TransactionDataType) => ObjectReference;
}