🚥 Socket.io integration WIP
This commit is contained in:
@@ -11,6 +11,7 @@ import {
|
||||
} from "../utils/uncompression.utils";
|
||||
import {
|
||||
IExtractionOptions,
|
||||
IExtractedComicBookCoverFile,
|
||||
IFolderData,
|
||||
} from "../interfaces/folder.interface";
|
||||
import axios from "axios";
|
||||
@@ -19,12 +20,14 @@ import through2 from "through2";
|
||||
import oboe from "oboe";
|
||||
import H from "highland";
|
||||
import { stringify } from "highland-json";
|
||||
const JsonStreamStringify = require("json-stream-stringify");
|
||||
const IO = require("socket.io")();
|
||||
|
||||
const { chain } = require("stream-chain");
|
||||
const { parser } = require("stream-json");
|
||||
const { pick } = require("stream-json/filters/Pick");
|
||||
const { ignore } = require("stream-json/filters/Ignore");
|
||||
const { streamValues } = require("stream-json/streamers/StreamValues");
|
||||
const StreamArray = require("stream-json/streamers/StreamArray");
|
||||
|
||||
export default class ProductsService extends Service {
|
||||
// @ts-ignore
|
||||
@@ -63,58 +66,57 @@ export default class ProductsService extends Service {
|
||||
);
|
||||
},
|
||||
},
|
||||
getComicCovers: {
|
||||
rest: "POST /getComicCovers",
|
||||
params: {
|
||||
extractionOptions: "object",
|
||||
walkedFolders: "array",
|
||||
},
|
||||
async handler(
|
||||
ctx: Context<{
|
||||
extractionOptions: IExtractionOptions;
|
||||
walkedFolders: IFolderData[];
|
||||
}>
|
||||
) {
|
||||
switch (
|
||||
ctx.params.extractionOptions.extractionMode
|
||||
) {
|
||||
case "bulk":
|
||||
let rs = new Readable();
|
||||
const extractedDataPromises = map(
|
||||
ctx.params.walkedFolders,
|
||||
async (folder) => {
|
||||
while (!isUndefined(folder)) {
|
||||
let foo =
|
||||
await extractArchive(
|
||||
ctx.params
|
||||
.extractionOptions,
|
||||
folder
|
||||
);
|
||||
console.log("levar", foo);
|
||||
rs.push(foo);
|
||||
}
|
||||
rs.push(null);
|
||||
}
|
||||
);
|
||||
|
||||
case "single":
|
||||
return await extractArchive(
|
||||
ctx.params.extractionOptions,
|
||||
ctx.params.walkedFolders[0]
|
||||
);
|
||||
default:
|
||||
console.log(
|
||||
"Unknown extraction mode selected."
|
||||
);
|
||||
return {
|
||||
message:
|
||||
"Unknown extraction mode selected.",
|
||||
errorCode: "90",
|
||||
data: `${ctx.params.extractionOptions}`,
|
||||
};
|
||||
}
|
||||
},
|
||||
},
|
||||
// getComicCovers: {
|
||||
// rest: "POST /getComicCovers",
|
||||
// params: {
|
||||
// extractionOptions: "object",
|
||||
// walkedFolders: "array",
|
||||
// },
|
||||
// async handler(
|
||||
// ctx: Context<{
|
||||
// extractionOptions: IExtractionOptions;
|
||||
// walkedFolders: IFolderData[];
|
||||
// }>
|
||||
// ) {
|
||||
// switch (
|
||||
// ctx.params.extractionOptions.extractionMode
|
||||
// ) {
|
||||
// case "bulk":
|
||||
// map(
|
||||
// ctx.params.walkedFolders,
|
||||
// async (folder, idx) => {
|
||||
// let foo = await extractArchive(
|
||||
// ctx.params
|
||||
// .extractionOptions,
|
||||
// folder
|
||||
// );
|
||||
// // console.log("levar", foo);
|
||||
// let jsonStream =
|
||||
// new JsonStreamStringify({
|
||||
// foo,
|
||||
// });
|
||||
// return jsonStream;
|
||||
// }
|
||||
// );
|
||||
//
|
||||
// case "single":
|
||||
// return await extractArchive(
|
||||
// ctx.params.extractionOptions,
|
||||
// ctx.params.walkedFolders[0]
|
||||
// );
|
||||
// default:
|
||||
// console.log(
|
||||
// "Unknown extraction mode selected."
|
||||
// );
|
||||
// return {
|
||||
// message:
|
||||
// "Unknown extraction mode selected.",
|
||||
// errorCode: "90",
|
||||
// data: `${ctx.params.extractionOptions}`,
|
||||
// };
|
||||
// }
|
||||
// },
|
||||
// },
|
||||
},
|
||||
methods: {},
|
||||
},
|
||||
|
||||
Reference in New Issue
Block a user