mirror of
https://github.com/gabehf/Tdarr_Plugins.git
synced 2026-03-16 18:45:53 -07:00
Merge pull request #568 from HaveAGitGat/del_parent
Add deleteParentFolderIfEmpty option
This commit is contained in:
commit
c7e22c9648
2 changed files with 62 additions and 2 deletions
|
|
@ -38,6 +38,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.plugin = exports.details = void 0;
|
exports.plugin = exports.details = void 0;
|
||||||
var fs_1 = require("fs");
|
var fs_1 = require("fs");
|
||||||
|
var fileUtils_1 = require("../../../../FlowHelpers/1.0.0/fileUtils");
|
||||||
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */
|
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */
|
||||||
var details = function () { return ({
|
var details = function () { return ({
|
||||||
name: 'Delete File',
|
name: 'Delete File',
|
||||||
|
|
@ -66,6 +67,16 @@ var details = function () { return ({
|
||||||
},
|
},
|
||||||
tooltip: 'Specify the file to delete',
|
tooltip: 'Specify the file to delete',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
label: 'Delete Parent Folder If Empty',
|
||||||
|
name: 'deleteParentFolderIfEmpty',
|
||||||
|
type: 'boolean',
|
||||||
|
defaultValue: 'false',
|
||||||
|
inputUI: {
|
||||||
|
type: 'switch',
|
||||||
|
},
|
||||||
|
tooltip: 'If the folder that the file is in is empty after the file is deleted, delete the folder.',
|
||||||
|
},
|
||||||
],
|
],
|
||||||
outputs: [
|
outputs: [
|
||||||
{
|
{
|
||||||
|
|
@ -77,7 +88,7 @@ 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;
|
var lib, fileToDelete, deleteParentFolderIfEmpty, fileDir, files;
|
||||||
return __generator(this, function (_a) {
|
return __generator(this, function (_a) {
|
||||||
switch (_a.label) {
|
switch (_a.label) {
|
||||||
case 0:
|
case 0:
|
||||||
|
|
@ -85,6 +96,7 @@ var plugin = function (args) { return __awaiter(void 0, void 0, void 0, function
|
||||||
// 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;
|
||||||
if (!(fileToDelete === 'workingFile')) return [3 /*break*/, 2];
|
if (!(fileToDelete === 'workingFile')) 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)];
|
||||||
|
|
@ -98,7 +110,27 @@ var plugin = function (args) { return __awaiter(void 0, void 0, void 0, function
|
||||||
case 3:
|
case 3:
|
||||||
_a.sent();
|
_a.sent();
|
||||||
_a.label = 4;
|
_a.label = 4;
|
||||||
case 4: return [2 /*return*/, {
|
case 4:
|
||||||
|
fileDir = (0, fileUtils_1.getFileAbosluteDir)(args.originalLibraryFile._id);
|
||||||
|
if (!deleteParentFolderIfEmpty) return [3 /*break*/, 9];
|
||||||
|
args.jobLog("Checking if folder ".concat(fileDir, " is empty"));
|
||||||
|
return [4 /*yield*/, fs_1.promises.readdir(fileDir)];
|
||||||
|
case 5:
|
||||||
|
files = _a.sent();
|
||||||
|
if (!(files.length === 0)) return [3 /*break*/, 7];
|
||||||
|
args.jobLog("Deleting empty folder ".concat(fileDir));
|
||||||
|
return [4 /*yield*/, fs_1.promises.rmdir(fileDir)];
|
||||||
|
case 6:
|
||||||
|
_a.sent();
|
||||||
|
return [3 /*break*/, 8];
|
||||||
|
case 7:
|
||||||
|
args.jobLog("Folder ".concat(fileDir, " is not empty, skipping delete"));
|
||||||
|
_a.label = 8;
|
||||||
|
case 8: return [3 /*break*/, 10];
|
||||||
|
case 9:
|
||||||
|
args.jobLog("Skipping delete of parent folder ".concat(fileDir));
|
||||||
|
_a.label = 10;
|
||||||
|
case 10: return [2 /*return*/, {
|
||||||
outputFileObj: args.inputFileObj,
|
outputFileObj: args.inputFileObj,
|
||||||
outputNumber: 1,
|
outputNumber: 1,
|
||||||
variables: args.variables,
|
variables: args.variables,
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ import {
|
||||||
IpluginInputArgs,
|
IpluginInputArgs,
|
||||||
IpluginOutputArgs,
|
IpluginOutputArgs,
|
||||||
} from '../../../../FlowHelpers/1.0.0/interfaces/interfaces';
|
} from '../../../../FlowHelpers/1.0.0/interfaces/interfaces';
|
||||||
|
import { getFileAbosluteDir } from '../../../../FlowHelpers/1.0.0/fileUtils';
|
||||||
|
|
||||||
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */
|
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */
|
||||||
const details = (): IpluginDetails => ({
|
const details = (): IpluginDetails => ({
|
||||||
|
|
@ -33,6 +34,16 @@ const details = (): IpluginDetails => ({
|
||||||
},
|
},
|
||||||
tooltip: 'Specify the file to delete',
|
tooltip: 'Specify the file to delete',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
label: 'Delete Parent Folder If Empty',
|
||||||
|
name: 'deleteParentFolderIfEmpty',
|
||||||
|
type: 'boolean',
|
||||||
|
defaultValue: 'false',
|
||||||
|
inputUI: {
|
||||||
|
type: 'switch',
|
||||||
|
},
|
||||||
|
tooltip: 'If the folder that the file is in is empty after the file is deleted, delete the folder.',
|
||||||
|
},
|
||||||
],
|
],
|
||||||
outputs: [
|
outputs: [
|
||||||
{
|
{
|
||||||
|
|
@ -49,6 +60,7 @@ 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;
|
||||||
|
|
||||||
if (fileToDelete === 'workingFile') {
|
if (fileToDelete === 'workingFile') {
|
||||||
args.jobLog(`Deleting working file ${args.inputFileObj._id}`);
|
args.jobLog(`Deleting working file ${args.inputFileObj._id}`);
|
||||||
|
|
@ -58,6 +70,22 @@ const plugin = async (args: IpluginInputArgs): Promise<IpluginOutputArgs> => {
|
||||||
await fs.unlink(args.originalLibraryFile._id);
|
await fs.unlink(args.originalLibraryFile._id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const fileDir = getFileAbosluteDir(args.originalLibraryFile._id);
|
||||||
|
|
||||||
|
if (deleteParentFolderIfEmpty) {
|
||||||
|
args.jobLog(`Checking if folder ${fileDir} is empty`);
|
||||||
|
const files = await fs.readdir(fileDir);
|
||||||
|
|
||||||
|
if (files.length === 0) {
|
||||||
|
args.jobLog(`Deleting empty folder ${fileDir}`);
|
||||||
|
await fs.rmdir(fileDir);
|
||||||
|
} else {
|
||||||
|
args.jobLog(`Folder ${fileDir} is not empty, skipping delete`);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
args.jobLog(`Skipping delete of parent folder ${fileDir}`);
|
||||||
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
outputFileObj: args.inputFileObj,
|
outputFileObj: args.inputFileObj,
|
||||||
outputNumber: 1,
|
outputNumber: 1,
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue