Handle classic plugin file rename

make-only-subtitle-default
HaveAGitGat 2 years ago
parent d271bb02b6
commit f89f7c4fcf

@ -41,8 +41,9 @@ var fs_1 = require("fs");
var fileUtils_1 = require("./fileUtils"); var fileUtils_1 = require("./fileUtils");
var runClassicPlugin = function (args, type) { return __awaiter(void 0, void 0, void 0, function () { var runClassicPlugin = function (args, type) { return __awaiter(void 0, void 0, void 0, function () {
var path, pluginSourceId, parts, pluginSource, pluginId, relativePluginPath, absolutePath, classicPlugin, pluginSrcStr, res, container, cacheFilePath, otherArguments, scanTypes, pluginInputFileObj, result; var path, pluginSourceId, parts, pluginSource, pluginId, relativePluginPath, absolutePath, classicPlugin, pluginSrcStr, res, container, cacheFilePath, otherArguments, scanTypes, pluginInputFileObj, result;
return __generator(this, function (_a) { var _a;
switch (_a.label) { return __generator(this, function (_b) {
switch (_b.label) {
case 0: case 0:
path = require('path'); path = require('path');
pluginSourceId = String(args.inputs.pluginSourceId); pluginSourceId = String(args.inputs.pluginSourceId);
@ -56,7 +57,7 @@ var runClassicPlugin = function (args, type) { return __awaiter(void 0, void 0,
classicPlugin = args.deps.importFresh(relativePluginPath); classicPlugin = args.deps.importFresh(relativePluginPath);
return [4 /*yield*/, fs_1.promises.readFile(absolutePath, 'utf8')]; return [4 /*yield*/, fs_1.promises.readFile(absolutePath, 'utf8')];
case 1: case 1:
pluginSrcStr = _a.sent(); pluginSrcStr = _b.sent();
return [3 /*break*/, 4]; return [3 /*break*/, 4];
case 2: return [4 /*yield*/, args.deps.axiosMiddleware('api/v2/read-plugin', { case 2: return [4 /*yield*/, args.deps.axiosMiddleware('api/v2/read-plugin', {
plugin: { plugin: {
@ -65,10 +66,10 @@ var runClassicPlugin = function (args, type) { return __awaiter(void 0, void 0,
}, },
})]; })];
case 3: case 3:
res = _a.sent(); res = _b.sent();
classicPlugin = args.deps.requireFromString(res.pluginRaw, absolutePath); classicPlugin = args.deps.requireFromString(res.pluginRaw, absolutePath);
pluginSrcStr = res.pluginRaw; pluginSrcStr = res.pluginRaw;
_a.label = 4; _b.label = 4;
case 4: case 4:
if (type === 'filter' && classicPlugin.details().Operation !== 'Filter') { if (type === 'filter' && classicPlugin.details().Operation !== 'Filter') {
throw new Error("".concat('This plugin is meant for classic plugins that have ' throw new Error("".concat('This plugin is meant for classic plugins that have '
@ -85,15 +86,15 @@ var runClassicPlugin = function (args, type) { return __awaiter(void 0, void 0,
args.jobLog("Installing dependencies for ".concat(pluginSourceId)); args.jobLog("Installing dependencies for ".concat(pluginSourceId));
return [4 /*yield*/, args.installClassicPluginDeps(classicPlugin.dependencies)]; return [4 /*yield*/, args.installClassicPluginDeps(classicPlugin.dependencies)];
case 5: case 5:
_a.sent(); _b.sent();
return [3 /*break*/, 7]; return [3 /*break*/, 7];
case 6: case 6:
args.jobLog("Not installing dependencies for ".concat(pluginSourceId, ", please update Tdarr")); args.jobLog("Not installing dependencies for ".concat(pluginSourceId, ", please update Tdarr"));
_a.label = 7; _b.label = 7;
case 7: return [3 /*break*/, 9]; case 7: return [3 /*break*/, 9];
case 8: case 8:
args.jobLog("No depedencies to install for ".concat(pluginSourceId)); args.jobLog("No depedencies to install for ".concat(pluginSourceId));
_a.label = 9; _b.label = 9;
case 9: case 9:
container = (0, fileUtils_1.getContainer)(args.inputFileObj._id); container = (0, fileUtils_1.getContainer)(args.inputFileObj._id);
cacheFilePath = "".concat((0, fileUtils_1.getPluginWorkDir)(args), "/").concat((0, fileUtils_1.getFileName)(args.inputFileObj._id), ".").concat(container); cacheFilePath = "".concat((0, fileUtils_1.getPluginWorkDir)(args), "/").concat((0, fileUtils_1.getFileName)(args.inputFileObj._id), ".").concat(container);
@ -121,10 +122,17 @@ var runClassicPlugin = function (args, type) { return __awaiter(void 0, void 0,
scanTypes: scanTypes, scanTypes: scanTypes,
})]; })];
case 10: case 10:
pluginInputFileObj = _a.sent(); pluginInputFileObj = _b.sent();
return [4 /*yield*/, classicPlugin.plugin(pluginInputFileObj, args.librarySettings, args.inputs, otherArguments)]; return [4 /*yield*/, classicPlugin.plugin(pluginInputFileObj, args.librarySettings, args.inputs, otherArguments)];
case 11: case 11:
result = _a.sent(); result = _b.sent();
if (((_a = result === null || result === void 0 ? void 0 : result.file) === null || _a === void 0 ? void 0 : _a._id) && args.inputFileObj._id !== result.file._id) {
// eslint-disable-next-line no-param-reassign
args.inputFileObj._id = result.file._id;
// eslint-disable-next-line no-param-reassign
args.inputFileObj.file = result.file.file;
args.jobLog("File ID changed from ".concat(args.inputFileObj._id, " to ").concat(result.file._id));
}
return [2 /*return*/, { return [2 /*return*/, {
result: result, result: result,
cacheFilePath: cacheFilePath, cacheFilePath: cacheFilePath,

@ -121,6 +121,14 @@ export const runClassicPlugin = async (args:IpluginInputArgs, type:'filter'|'tra
otherArguments, otherArguments,
); );
if (result?.file?._id && args.inputFileObj._id !== result.file._id) {
// eslint-disable-next-line no-param-reassign
args.inputFileObj._id = result.file._id;
// eslint-disable-next-line no-param-reassign
args.inputFileObj.file = result.file.file;
args.jobLog(`File ID changed from ${args.inputFileObj._id} to ${result.file._id}`);
}
return { return {
result, result,
cacheFilePath, cacheFilePath,

Loading…
Cancel
Save