Merge branch 'master' of https://github.com/rishighan/threetwo-import-service
This commit is contained in:
@@ -46,7 +46,7 @@ const ComicSchema = mongoose.Schema({
|
|||||||
acquisition: {
|
acquisition: {
|
||||||
wanted: Boolean,
|
wanted: Boolean,
|
||||||
release: {},
|
release: {},
|
||||||
directconnect: {},
|
directconnect: Array,
|
||||||
torrent: {
|
torrent: {
|
||||||
sourceApplication: String,
|
sourceApplication: String,
|
||||||
magnet: String,
|
magnet: String,
|
||||||
|
|||||||
@@ -121,6 +121,9 @@ export default class ApiService extends Service {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
rawFileDetails: comicBookCoverMetadata,
|
rawFileDetails: comicBookCoverMetadata,
|
||||||
|
sourcedMetadata: {
|
||||||
|
comicvine: {},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
{}
|
{}
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -14,7 +14,6 @@ import { convertXMLToJSON } from "../utils/xml.utils";
|
|||||||
import https from "https";
|
import https from "https";
|
||||||
const ObjectId = require("mongoose").Types.ObjectId;
|
const ObjectId = require("mongoose").Types.ObjectId;
|
||||||
|
|
||||||
|
|
||||||
export default class ProductsService extends Service {
|
export default class ProductsService extends Service {
|
||||||
public constructor(
|
public constructor(
|
||||||
public broker: ServiceBroker,
|
public broker: ServiceBroker,
|
||||||
@@ -60,15 +59,33 @@ export default class ProductsService extends Service {
|
|||||||
},
|
},
|
||||||
rawImportToDB: {
|
rawImportToDB: {
|
||||||
rest: "POST /rawImportToDB",
|
rest: "POST /rawImportToDB",
|
||||||
params: {
|
params: {},
|
||||||
},
|
async handler(
|
||||||
async handler(ctx: Context<{ sourcedMetadata: { comicvine: { volume: { api_detail_url: string}, volumeInformation: {}}}}>) {
|
ctx: Context<{
|
||||||
console.log("ASDASD", ctx.params);
|
sourcedMetadata: {
|
||||||
|
comicvine: {
|
||||||
|
volume: { api_detail_url: string };
|
||||||
|
volumeInformation: {};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}>
|
||||||
|
) {
|
||||||
let volumeDetails;
|
let volumeDetails;
|
||||||
const comicMetadata = ctx.params;
|
const comicMetadata = ctx.params;
|
||||||
if (!isNil(comicMetadata.sourcedMetadata.comicvine.volume)) {
|
if (
|
||||||
volumeDetails = await this.getComicVineVolumeMetadata(comicMetadata.sourcedMetadata.comicvine.volume.api_detail_url);
|
comicMetadata.sourcedMetadata.comicvine &&
|
||||||
comicMetadata.sourcedMetadata.comicvine.volumeInformation = volumeDetails;
|
!isNil(
|
||||||
|
comicMetadata.sourcedMetadata.comicvine
|
||||||
|
.volume
|
||||||
|
)
|
||||||
|
) {
|
||||||
|
volumeDetails =
|
||||||
|
await this.getComicVineVolumeMetadata(
|
||||||
|
comicMetadata.sourcedMetadata
|
||||||
|
.comicvine.volume.api_detail_url
|
||||||
|
);
|
||||||
|
comicMetadata.sourcedMetadata.comicvine.volumeInformation =
|
||||||
|
volumeDetails;
|
||||||
}
|
}
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
Comic.create(ctx.params, (error, data) => {
|
Comic.create(ctx.params, (error, data) => {
|
||||||
@@ -89,19 +106,42 @@ export default class ProductsService extends Service {
|
|||||||
applyComicVineMetadata: {
|
applyComicVineMetadata: {
|
||||||
rest: "POST /applyComicVineMetadata",
|
rest: "POST /applyComicVineMetadata",
|
||||||
params: {},
|
params: {},
|
||||||
async handler(ctx: Context<{ match: { volume: { api_detail_url: string }, volumeInformation: object }, comicObjectId: string }>) {
|
async handler(
|
||||||
|
ctx: Context<{
|
||||||
|
match: {
|
||||||
|
volume: { api_detail_url: string };
|
||||||
|
volumeInformation: object;
|
||||||
|
};
|
||||||
|
comicObjectId: string;
|
||||||
|
}>
|
||||||
|
) {
|
||||||
// 1. find mongo object by id
|
// 1. find mongo object by id
|
||||||
// 2. import payload into sourcedMetadata.comicvine
|
// 2. import payload into sourcedMetadata.comicvine
|
||||||
const comicObjectId = new ObjectId(ctx.params.comicObjectId);
|
const comicObjectId = new ObjectId(
|
||||||
|
ctx.params.comicObjectId
|
||||||
|
);
|
||||||
const matchedResult = ctx.params.match;
|
const matchedResult = ctx.params.match;
|
||||||
let volumeDetailsPromise;
|
let volumeDetailsPromise;
|
||||||
if (!isNil(matchedResult.volume)) {
|
if (!isNil(matchedResult.volume)) {
|
||||||
volumeDetailsPromise = this.getComicVineVolumeMetadata(matchedResult.volume.api_detail_url)
|
volumeDetailsPromise =
|
||||||
|
this.getComicVineVolumeMetadata(
|
||||||
|
matchedResult.volume.api_detail_url
|
||||||
|
);
|
||||||
}
|
}
|
||||||
return new Promise(async (resolve, reject) => {
|
return new Promise(async (resolve, reject) => {
|
||||||
const volumeDetails = await volumeDetailsPromise;
|
const volumeDetails =
|
||||||
matchedResult.volumeInformation = volumeDetails;
|
await volumeDetailsPromise;
|
||||||
Comic.findByIdAndUpdate(comicObjectId, { sourcedMetadata: { comicvine: matchedResult } }, { new: true }, (err, result) => {
|
matchedResult.volumeInformation =
|
||||||
|
volumeDetails;
|
||||||
|
Comic.findByIdAndUpdate(
|
||||||
|
comicObjectId,
|
||||||
|
{
|
||||||
|
sourcedMetadata: {
|
||||||
|
comicvine: matchedResult,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{ new: true },
|
||||||
|
(err, result) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(err);
|
console.log(err);
|
||||||
reject(err);
|
reject(err);
|
||||||
@@ -109,10 +149,53 @@ export default class ProductsService extends Service {
|
|||||||
// 3. Fetch and append volume information
|
// 3. Fetch and append volume information
|
||||||
resolve(result);
|
resolve(result);
|
||||||
}
|
}
|
||||||
});
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
},
|
||||||
|
applyAirDCPPDownloadMetadata: {
|
||||||
|
rest: "POST /applyAirDCPPDownloadMetadata",
|
||||||
|
params: {},
|
||||||
|
async handler(
|
||||||
|
ctx: Context<{
|
||||||
|
comicObjectId: string;
|
||||||
|
resultId: string;
|
||||||
|
bundleId: string;
|
||||||
|
directoryIds: [];
|
||||||
|
searchInstanceId: string;
|
||||||
|
}>
|
||||||
|
) {
|
||||||
|
const comicObjectId = new ObjectId(
|
||||||
|
ctx.params.comicObjectId
|
||||||
|
);
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
Comic.findByIdAndUpdate(
|
||||||
|
comicObjectId,
|
||||||
|
{
|
||||||
|
$push: {
|
||||||
|
"acquisition.directconnect": {
|
||||||
|
resultId:
|
||||||
|
ctx.params.resultId,
|
||||||
|
bundleId: ctx.params.bundleId,
|
||||||
|
directoryIds: ctx.params.directoryIds,
|
||||||
|
searchInstanceId:
|
||||||
|
ctx.params
|
||||||
|
.searchInstanceId,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{ new: true, safe: true, upsert: true },
|
||||||
|
(err, result) => {
|
||||||
|
if (err) {
|
||||||
|
reject(err);
|
||||||
|
} else {
|
||||||
|
resolve(result);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
},
|
},
|
||||||
|
|
||||||
getComicBooks: {
|
getComicBooks: {
|
||||||
@@ -136,26 +219,32 @@ export default class ProductsService extends Service {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getComicVineVolumeMetadata: apiDetailURL => {
|
getComicVineVolumeMetadata: (apiDetailURL) => {
|
||||||
return new Promise((resolve, reject) => {
|
return new Promise((resolve, reject) => {
|
||||||
return https.get(`${apiDetailURL}?api_key=a5fa0663683df8145a85d694b5da4b87e1c92c69&format=json&limit=1&offset=0&field_list=id,name,description,image,first_issue,last_issue,publisher,count_of_issues,character_credits,person_credits,aliases`, (resp) => {
|
return https
|
||||||
|
.get(
|
||||||
let data = '';
|
`${apiDetailURL}?api_key=a5fa0663683df8145a85d694b5da4b87e1c92c69&format=json&limit=1&offset=0&field_list=id,name,description,image,first_issue,last_issue,publisher,count_of_issues,character_credits,person_credits,aliases`,
|
||||||
resp.on('data', (chunk) => {
|
(resp) => {
|
||||||
|
let data = "";
|
||||||
|
resp.on("data", (chunk) => {
|
||||||
data += chunk;
|
data += chunk;
|
||||||
});
|
});
|
||||||
|
|
||||||
resp.on('end', () => {
|
resp.on("end", () => {
|
||||||
const volumeInformation = JSON.parse(data);
|
const volumeInformation =
|
||||||
resolve(volumeInformation.results);
|
JSON.parse(data);
|
||||||
|
resolve(
|
||||||
|
volumeInformation.results
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
}
|
||||||
}).on("error", (err) => {
|
)
|
||||||
|
.on("error", (err) => {
|
||||||
console.log("Error: " + err.message);
|
console.log("Error: " + err.message);
|
||||||
reject(err);
|
reject(err);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
schema
|
schema
|
||||||
|
|||||||
Reference in New Issue
Block a user