Merge branch 'master' of https://github.com/rishighan/threetwo-import-service
This commit is contained in:
@@ -60,8 +60,16 @@ export default class ProductsService extends Service {
|
|||||||
},
|
},
|
||||||
rawImportToDB: {
|
rawImportToDB: {
|
||||||
rest: "POST /rawImportToDB",
|
rest: "POST /rawImportToDB",
|
||||||
params: {},
|
params: {
|
||||||
async handler(ctx: Context<{ payload: object }>) {
|
},
|
||||||
|
async handler(ctx: Context<{ sourcedMetadata: { comicvine: { volume: { api_detail_url: string}, volumeInformation: {}}}}>) {
|
||||||
|
console.log("ASDASD", ctx.params);
|
||||||
|
let volumeDetails;
|
||||||
|
const comicMetadata = ctx.params;
|
||||||
|
if (!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) => {
|
||||||
if (data) {
|
if (data) {
|
||||||
@@ -81,36 +89,18 @@ 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;
|
||||||
console.log(matchedResult.volume.api_detail_url);
|
|
||||||
let volumeDetailsPromise;
|
let volumeDetailsPromise;
|
||||||
if (!isNil(matchedResult.volume)) {
|
if (!isNil(matchedResult.volume)) {
|
||||||
volumeDetailsPromise = new Promise((resolve, reject) => {
|
volumeDetailsPromise = this.getComicVineVolumeMetadata(matchedResult.volume.api_detail_url)
|
||||||
return https.get(`${matchedResult.volume.api_detail_url}?api_key=a5fa0663683df8145a85d694b5da4b87e1c92c69&format=json&limit=1&offset=0&field_list=id,name,deck,image,first_issue,last_issue,publisher,count_of_issues`, (resp) => {
|
|
||||||
|
|
||||||
let data = '';
|
|
||||||
resp.on('data', (chunk) => {
|
|
||||||
data += chunk;
|
|
||||||
});
|
|
||||||
|
|
||||||
resp.on('end', () => {
|
|
||||||
const volumeInformation = JSON.parse(data);
|
|
||||||
resolve(volumeInformation);
|
|
||||||
});
|
|
||||||
|
|
||||||
}).on("error", (err) => {
|
|
||||||
console.log("Error: " + err.message);
|
|
||||||
reject(err);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
return new Promise(async (resolve, reject) => {
|
return new Promise(async (resolve, reject) => {
|
||||||
const volumeDetails = await volumeDetailsPromise;
|
const volumeDetails = await volumeDetailsPromise;
|
||||||
matchedResult.volumeInformation = volumeDetails.results;
|
matchedResult.volumeInformation = volumeDetails;
|
||||||
Comic.findByIdAndUpdate(comicObjectId, { sourcedMetadata: { comicvine: matchedResult } }, { new: true }, (err, result) => {
|
Comic.findByIdAndUpdate(comicObjectId, { sourcedMetadata: { comicvine: matchedResult } }, { new: true }, (err, result) => {
|
||||||
if (err) {
|
if (err) {
|
||||||
console.log(err);
|
console.log(err);
|
||||||
@@ -145,7 +135,28 @@ export default class ProductsService extends Service {
|
|||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
methods: {},
|
methods: {
|
||||||
|
getComicVineVolumeMetadata: apiDetailURL => {
|
||||||
|
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) => {
|
||||||
|
|
||||||
|
let data = '';
|
||||||
|
resp.on('data', (chunk) => {
|
||||||
|
data += chunk;
|
||||||
|
});
|
||||||
|
|
||||||
|
resp.on('end', () => {
|
||||||
|
const volumeInformation = JSON.parse(data);
|
||||||
|
resolve(volumeInformation.results);
|
||||||
|
});
|
||||||
|
|
||||||
|
}).on("error", (err) => {
|
||||||
|
console.log("Error: " + err.message);
|
||||||
|
reject(err);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
},
|
},
|
||||||
schema
|
schema
|
||||||
)
|
)
|
||||||
|
|||||||
Reference in New Issue
Block a user