Files
threetwo-metadata-service/services/comicvine.service.ts

208 lines
5.1 KiB
TypeScript

"use strict";
import qs from "querystring";
import { Service, ServiceBroker, Context } from "moleculer";
import axios from "axios";
import { cacheAdapterEnhancer, throttleAdapterEnhancer } from "axios-extensions";
import { matchScorer, rankVolumes } from "../utils/searchmatchscorer.utils";
const CV_BASE_URL = "https://comicvine.gamespot.com/api/";
console.log("KEYYYYYYYY", process.env.COMICVINE_API_KEY);
export default class ComicVineService extends Service {
public constructor(public broker: ServiceBroker) {
super(broker);
this.parseServiceSchema({
name: "comicvine",
actions: {
fetchResource: {
rest: "/fetchresource",
params: {
format: { type: "string", optional: false },
sort: { type: "string", optional: true },
query: { type: "string", optional: false },
fieldList: { type: "string", optional: true },
limit: { type: "string", optional: false },
offset: { type: "string", optional: false },
resources: { type: "string", optional: false },
},
handler: async (
ctx: Context<{
format: string;
sort: string;
query: string;
fieldList: string;
limit: string;
offset: string;
resources: string;
scorerConfiguration: {
searchQuery: {
issue: object;
series: object;
};
rawFileDetails: object;
};
}>
): Promise<any> => {
const {
format,
sort,
query,
fieldList,
limit,
offset,
resources,
} = ctx.params;
const response = await axios.request({
url:
CV_BASE_URL +
"search" +
"?api_key=" +
process.env.COMICVINE_API_KEY,
params: {
format,
sort,
query,
fieldList,
limit,
offset,
resources,
},
transformResponse: r => {
const matches = JSON.parse(r);
return matchScorer(
matches.results,
ctx.params.scorerConfiguration.searchQuery,
ctx.params.scorerConfiguration
.rawFileDetails
);
},
headers: { Accept: "application/json" },
});
const { data } = response;
return data;
},
},
search: {
rest: "/search",
params: {},
handler: async (
ctx: Context<{
format: string;
sort: string;
query: string;
fieldList: string;
limit: string;
offset: string;
resources: string;
}>
) => {
const response = await axios.request({
url:
CV_BASE_URL +
"search" +
"?api_key=" +
process.env.COMICVINE_API_KEY,
params: ctx.params,
headers: { Accept: "application/json" },
});
const { data } = response;
return data;
},
},
getVolumes: {
rest: "POST /getVolumes",
params: {},
handler: async (
ctx: Context<{
volumeURI: string;
data: {};
}>
) => {
const response = await axios.request({
url:
ctx.params.volumeURI +
"?api_key=" +
process.env.COMICVINE_API_KEY,
params: ctx.params.data,
headers: { Accept: "application/json" },
});
const { data } = response;
return data;
},
},
volumeBasedSearch: {
rest: "POST /volumeBasedSearch",
params: {},
headers: { Accept: "application/json" },
bulkhead: {
enabled: true,
concurrency: 10,
maxQueueSize: 10,
},
timeout: 10000000,
handler: async (
ctx: Context<{
format: string;
sort: string;
query: string;
fieldList: string;
limit: number;
offset: number;
resources: string;
scorerConfiguration?: {
searchQuery: {
issue: object;
series: object;
};
rawFileDetails: object;
};
}>
) => {
const results: any = [];
const volumes = await this.fetchVolumesFromCV(
ctx.params,
results,
);
return volumes;
},
},
},
methods: {
fetchVolumesFromCV: async (params, output: any[] = []) => {
let currentPage = parseInt(params.page, 10);
const response = await axios.request({
url:
CV_BASE_URL +
"search" +
"?api_key=" +
process.env.COMICVINE_API_KEY,
params,
headers: { Accept: "application/json"},
adapter: throttleAdapterEnhancer(cacheAdapterEnhancer(axios.defaults.adapter)),
});
const { data } = response;
// 1. calculate total pages
const totalPages = Math.floor(
parseInt(data.number_of_total_results, 10) /
parseInt(params.limit, 10)
);
if (currentPage < totalPages) {
output.push(...data.results);
// 1a. Run the current batch of volumes through the matcher
rankVolumes(output, params.scorerConfiguration);
currentPage += 1;
params.page = currentPage;
console.log(`Fetching results for page ${currentPage}...`);
return await this.fetchVolumesFromCV(params, output);
} else {
return { ...output };
}
},
},
});
}
}