mirror of
https://github.com/gabehf/Tdarr_Plugins.git
synced 2026-03-14 17:55:55 -07:00
Merge pull request #763 from HaveAGitGat/delete_file_1
Add deleteWorkingFileIfOriginal toggle
This commit is contained in:
commit
04eca085ab
2 changed files with 111 additions and 28 deletions
|
|
@ -67,6 +67,32 @@ var details = function () { return ({
|
||||||
},
|
},
|
||||||
tooltip: 'Specify the file to delete',
|
tooltip: 'Specify the file to delete',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
label: 'Delete Working File If It\'s The Original File',
|
||||||
|
name: 'deleteWorkingFileIfOriginal',
|
||||||
|
type: 'boolean',
|
||||||
|
defaultValue: 'true',
|
||||||
|
inputUI: {
|
||||||
|
type: 'switch',
|
||||||
|
displayConditions: {
|
||||||
|
logic: 'AND',
|
||||||
|
sets: [
|
||||||
|
{
|
||||||
|
logic: 'AND',
|
||||||
|
inputs: [
|
||||||
|
{
|
||||||
|
name: 'fileToDelete',
|
||||||
|
value: 'workingFile',
|
||||||
|
condition: '===',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tooltip: 'If the option above is set to delete the working file,'
|
||||||
|
+ ' and the working file is the original file, delete the file.',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
label: 'Delete Parent Folder If Empty',
|
label: 'Delete Parent Folder If Empty',
|
||||||
name: 'deleteParentFolderIfEmpty',
|
name: 'deleteParentFolderIfEmpty',
|
||||||
|
|
@ -88,49 +114,62 @@ var details = function () { return ({
|
||||||
exports.details = details;
|
exports.details = details;
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||||
var plugin = function (args) { return __awaiter(void 0, void 0, void 0, function () {
|
var plugin = function (args) { return __awaiter(void 0, void 0, void 0, function () {
|
||||||
var lib, fileToDelete, deleteParentFolderIfEmpty, fileDir, files;
|
var lib, fileToDelete, _a, deleteParentFolderIfEmpty, deleteWorkingFileIfOriginal, workingFileIsOriginal, fileDir, files;
|
||||||
return __generator(this, function (_a) {
|
return __generator(this, function (_b) {
|
||||||
switch (_a.label) {
|
switch (_b.label) {
|
||||||
case 0:
|
case 0:
|
||||||
lib = require('../../../../../methods/lib')();
|
lib = require('../../../../../methods/lib')();
|
||||||
// eslint-disable-next-line @typescript-eslint/no-unused-vars,no-param-reassign
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars,no-param-reassign
|
||||||
args.inputs = lib.loadDefaultValues(args.inputs, details);
|
args.inputs = lib.loadDefaultValues(args.inputs, details);
|
||||||
fileToDelete = String(args.inputs.fileToDelete);
|
fileToDelete = String(args.inputs.fileToDelete);
|
||||||
deleteParentFolderIfEmpty = args.inputs.deleteParentFolderIfEmpty;
|
_a = args.inputs, deleteParentFolderIfEmpty = _a.deleteParentFolderIfEmpty, deleteWorkingFileIfOriginal = _a.deleteWorkingFileIfOriginal;
|
||||||
if (!(fileToDelete === 'workingFile')) return [3 /*break*/, 2];
|
if (!(fileToDelete === 'workingFile')) return [3 /*break*/, 4];
|
||||||
|
workingFileIsOriginal = args.originalLibraryFile._id === args.inputFileObj._id;
|
||||||
|
if (workingFileIsOriginal) {
|
||||||
|
args.jobLog('Working file is the original file!');
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
args.jobLog('Working file is not the original file!');
|
||||||
|
}
|
||||||
|
if (!((workingFileIsOriginal && deleteWorkingFileIfOriginal)
|
||||||
|
|| !workingFileIsOriginal)) return [3 /*break*/, 2];
|
||||||
args.jobLog("Deleting working file ".concat(args.inputFileObj._id));
|
args.jobLog("Deleting working file ".concat(args.inputFileObj._id));
|
||||||
return [4 /*yield*/, fs_1.promises.unlink(args.inputFileObj._id)];
|
return [4 /*yield*/, fs_1.promises.unlink(args.inputFileObj._id)];
|
||||||
case 1:
|
case 1:
|
||||||
_a.sent();
|
_b.sent();
|
||||||
return [3 /*break*/, 4];
|
return [3 /*break*/, 3];
|
||||||
case 2:
|
case 2:
|
||||||
if (!(fileToDelete === 'originalFile')) return [3 /*break*/, 4];
|
args.jobLog('Skipping delete of working file because it is the original file');
|
||||||
|
_b.label = 3;
|
||||||
|
case 3: return [3 /*break*/, 6];
|
||||||
|
case 4:
|
||||||
|
if (!(fileToDelete === 'originalFile')) return [3 /*break*/, 6];
|
||||||
args.jobLog("Deleting original file ".concat(args.originalLibraryFile._id));
|
args.jobLog("Deleting original file ".concat(args.originalLibraryFile._id));
|
||||||
return [4 /*yield*/, fs_1.promises.unlink(args.originalLibraryFile._id)];
|
return [4 /*yield*/, fs_1.promises.unlink(args.originalLibraryFile._id)];
|
||||||
case 3:
|
case 5:
|
||||||
_a.sent();
|
_b.sent();
|
||||||
_a.label = 4;
|
_b.label = 6;
|
||||||
case 4:
|
case 6:
|
||||||
fileDir = (0, fileUtils_1.getFileAbosluteDir)(args.originalLibraryFile._id);
|
fileDir = (0, fileUtils_1.getFileAbosluteDir)(args.originalLibraryFile._id);
|
||||||
if (!deleteParentFolderIfEmpty) return [3 /*break*/, 9];
|
if (!deleteParentFolderIfEmpty) return [3 /*break*/, 11];
|
||||||
args.jobLog("Checking if folder ".concat(fileDir, " is empty"));
|
args.jobLog("Checking if folder ".concat(fileDir, " is empty"));
|
||||||
return [4 /*yield*/, fs_1.promises.readdir(fileDir)];
|
return [4 /*yield*/, fs_1.promises.readdir(fileDir)];
|
||||||
case 5:
|
case 7:
|
||||||
files = _a.sent();
|
files = _b.sent();
|
||||||
if (!(files.length === 0)) return [3 /*break*/, 7];
|
if (!(files.length === 0)) return [3 /*break*/, 9];
|
||||||
args.jobLog("Deleting empty folder ".concat(fileDir));
|
args.jobLog("Deleting empty folder ".concat(fileDir));
|
||||||
return [4 /*yield*/, fs_1.promises.rmdir(fileDir)];
|
return [4 /*yield*/, fs_1.promises.rmdir(fileDir)];
|
||||||
case 6:
|
case 8:
|
||||||
_a.sent();
|
_b.sent();
|
||||||
return [3 /*break*/, 8];
|
return [3 /*break*/, 10];
|
||||||
case 7:
|
|
||||||
args.jobLog("Folder ".concat(fileDir, " is not empty, skipping delete"));
|
|
||||||
_a.label = 8;
|
|
||||||
case 8: return [3 /*break*/, 10];
|
|
||||||
case 9:
|
case 9:
|
||||||
|
args.jobLog("Folder ".concat(fileDir, " is not empty, skipping delete"));
|
||||||
|
_b.label = 10;
|
||||||
|
case 10: return [3 /*break*/, 12];
|
||||||
|
case 11:
|
||||||
args.jobLog("Skipping delete of parent folder ".concat(fileDir));
|
args.jobLog("Skipping delete of parent folder ".concat(fileDir));
|
||||||
_a.label = 10;
|
_b.label = 12;
|
||||||
case 10: return [2 /*return*/, {
|
case 12: return [2 /*return*/, {
|
||||||
outputFileObj: args.inputFileObj,
|
outputFileObj: args.inputFileObj,
|
||||||
outputNumber: 1,
|
outputNumber: 1,
|
||||||
variables: args.variables,
|
variables: args.variables,
|
||||||
|
|
|
||||||
|
|
@ -35,6 +35,32 @@ const details = (): IpluginDetails => ({
|
||||||
},
|
},
|
||||||
tooltip: 'Specify the file to delete',
|
tooltip: 'Specify the file to delete',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
label: 'Delete Working File If It\'s The Original File',
|
||||||
|
name: 'deleteWorkingFileIfOriginal',
|
||||||
|
type: 'boolean',
|
||||||
|
defaultValue: 'true',
|
||||||
|
inputUI: {
|
||||||
|
type: 'switch',
|
||||||
|
displayConditions: {
|
||||||
|
logic: 'AND',
|
||||||
|
sets: [
|
||||||
|
{
|
||||||
|
logic: 'AND',
|
||||||
|
inputs: [
|
||||||
|
{
|
||||||
|
name: 'fileToDelete',
|
||||||
|
value: 'workingFile',
|
||||||
|
condition: '===',
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
tooltip: 'If the option above is set to delete the working file,'
|
||||||
|
+ ' and the working file is the original file, delete the file.',
|
||||||
|
},
|
||||||
{
|
{
|
||||||
label: 'Delete Parent Folder If Empty',
|
label: 'Delete Parent Folder If Empty',
|
||||||
name: 'deleteParentFolderIfEmpty',
|
name: 'deleteParentFolderIfEmpty',
|
||||||
|
|
@ -61,11 +87,29 @@ const plugin = async (args: IpluginInputArgs): Promise<IpluginOutputArgs> => {
|
||||||
args.inputs = lib.loadDefaultValues(args.inputs, details);
|
args.inputs = lib.loadDefaultValues(args.inputs, details);
|
||||||
|
|
||||||
const fileToDelete = String(args.inputs.fileToDelete);
|
const fileToDelete = String(args.inputs.fileToDelete);
|
||||||
const { deleteParentFolderIfEmpty } = args.inputs;
|
const {
|
||||||
|
deleteParentFolderIfEmpty,
|
||||||
|
deleteWorkingFileIfOriginal,
|
||||||
|
} = args.inputs;
|
||||||
|
|
||||||
if (fileToDelete === 'workingFile') {
|
if (fileToDelete === 'workingFile') {
|
||||||
args.jobLog(`Deleting working file ${args.inputFileObj._id}`);
|
const workingFileIsOriginal = args.originalLibraryFile._id === args.inputFileObj._id;
|
||||||
await fsp.unlink(args.inputFileObj._id);
|
|
||||||
|
if (workingFileIsOriginal) {
|
||||||
|
args.jobLog('Working file is the original file!');
|
||||||
|
} else {
|
||||||
|
args.jobLog('Working file is not the original file!');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (
|
||||||
|
(workingFileIsOriginal && deleteWorkingFileIfOriginal)
|
||||||
|
|| !workingFileIsOriginal
|
||||||
|
) {
|
||||||
|
args.jobLog(`Deleting working file ${args.inputFileObj._id}`);
|
||||||
|
await fsp.unlink(args.inputFileObj._id);
|
||||||
|
} else {
|
||||||
|
args.jobLog('Skipping delete of working file because it is the original file');
|
||||||
|
}
|
||||||
} else if (fileToDelete === 'originalFile') {
|
} else if (fileToDelete === 'originalFile') {
|
||||||
args.jobLog(`Deleting original file ${args.originalLibraryFile._id}`);
|
args.jobLog(`Deleting original file ${args.originalLibraryFile._id}`);
|
||||||
await fsp.unlink(args.originalLibraryFile._id);
|
await fsp.unlink(args.originalLibraryFile._id);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue