mirror of
https://github.com/gabehf/Tdarr_Plugins.git
synced 2026-03-18 11:46:25 -07:00
Migz Plugins
1. Made changes to all plugins following lint testing. There are still various warnings/errors but my very limited knowledge of javascript means I just don't understand what the errors mean. Or in some cases I don't understand how to split the variable across several lines to confirm to the line limits. I did manage to get it from 952 problems (943 errors, 9 warnings) down to 37 problems (28 errors, 9 warnings) 2. Fix Flawed logic in FFMPEG plugins which would cause remux conditions to never trigger. Was checking if file was HEVC & VP9 which is impossible as they're both codecs. 3. Fixed a bug with CleanTitle where plugin would fail if a stream in the file didn't have a title. 4. Modify CleanSubtitle plugin to not remove sdh subtitles. 5. Include new plugin to just perform remuxes. Mainly aimed at remuxing to mkv or mp4.
This commit is contained in:
parent
e9370ffe7c
commit
864cf41f1d
10 changed files with 1136 additions and 882 deletions
130
Community/Tdarr_Plugin_MC93_Migz1Remux.js
Normal file
130
Community/Tdarr_Plugin_MC93_Migz1Remux.js
Normal file
|
|
@ -0,0 +1,130 @@
|
|||
/* eslint no-plusplus: ["error", { "allowForLoopAfterthoughts": true }] */
|
||||
function details() {
|
||||
return {
|
||||
id: 'Tdarr_Plugin_MC93_Migz1Remux',
|
||||
Stage: 'Pre-processing',
|
||||
Name: 'Migz-Remux container',
|
||||
Type: 'Video',
|
||||
Operation: 'Remux',
|
||||
Description: 'Files will be remuxed into either mkv or mp4. \n\n',
|
||||
Version: '1.1',
|
||||
Link: 'https://github.com/HaveAGitGat/Tdarr_Plugins/blob/master/Community/Tdarr_Plugin_MC93_Migz1Remux.js',
|
||||
Tags: 'pre-processing,ffmpeg,video only,configurable',
|
||||
Inputs: [{
|
||||
name: 'container',
|
||||
tooltip: `Specify output container of file
|
||||
\\nEnsure that all stream types you may have are supported by your chosen container.
|
||||
\\nmkv is recommended.
|
||||
\\nExample:\\n
|
||||
mkv
|
||||
|
||||
\\nExample:\\n
|
||||
mp4`,
|
||||
},
|
||||
{
|
||||
name: 'force_conform',
|
||||
tooltip: `Make the file conform to output containers requirements.
|
||||
\\n Drop hdmv_pgs_subtitle/eia_608/subrip/timed_id3 for MP4.
|
||||
\\n Drop data streams/mov_text/eia_608/timed_id3 for MKV.
|
||||
\\n Default is false.
|
||||
\\nExample:\\n
|
||||
true
|
||||
|
||||
\\nExample:\\n
|
||||
false`,
|
||||
},
|
||||
],
|
||||
};
|
||||
}
|
||||
|
||||
function plugin(file, librarySettings, inputs) {
|
||||
const response = {
|
||||
processFile: false,
|
||||
preset: '',
|
||||
handBrakeMode: false,
|
||||
FFmpegMode: true,
|
||||
reQueueAfter: true,
|
||||
infoLog: '',
|
||||
};
|
||||
|
||||
// Check if inputs.container has been configured. If it hasn't then exit plugin.
|
||||
if (inputs.container === '') {
|
||||
response.infoLog
|
||||
+= '☒Container has not been configured, please configure required options. Skipping this plugin. \n';
|
||||
response.processFile = false;
|
||||
return response;
|
||||
}
|
||||
response.container = `.${inputs.container}`;
|
||||
|
||||
// Check if file is a video. If it isn't then exit plugin.
|
||||
if (file.fileMedium !== 'video') {
|
||||
response.processFile = false;
|
||||
response.infoLog += '☒File is not a video. \n';
|
||||
return response;
|
||||
}
|
||||
|
||||
// Set up required variables.
|
||||
let extraArguments = '';
|
||||
let convert = false;
|
||||
|
||||
// Check if force_conform option is checked.
|
||||
// If so then check streams and add any extra parameters required to make file conform with output format.
|
||||
if (inputs.force_conform === 'true') {
|
||||
if (inputs.container.toLowerCase() === 'mkv') {
|
||||
extraArguments += '-map -0:d ';
|
||||
for (let i = 0; i < file.ffProbeData.streams.length; i++) {
|
||||
try {
|
||||
if (
|
||||
file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'mov_text'
|
||||
|| file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'eia_608'
|
||||
|| file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'timed_id3'
|
||||
) {
|
||||
extraArguments += `-map -0:${i} `;
|
||||
}
|
||||
} catch (err) {
|
||||
// Error
|
||||
}
|
||||
}
|
||||
}
|
||||
if (inputs.container.toLowerCase() === 'mp4') {
|
||||
for (let i = 0; i < file.ffProbeData.streams.length; i++) {
|
||||
try {
|
||||
if (
|
||||
file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'hdmv_pgs_subtitle'
|
||||
|| file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'eia_608'
|
||||
|| file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'subrip'
|
||||
|| file.ffProbeData.streams[i].codec_name
|
||||
.toLowerCase() === 'timed_id3'
|
||||
) {
|
||||
extraArguments += `-map -0:${i} `;
|
||||
}
|
||||
} catch (err) {
|
||||
// Error
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Check if file.container does NOT match inputs.container. If so remux file.
|
||||
if (file.container !== inputs.container) {
|
||||
response.infoLog += `☒File is ${file.container} but requested to be ${inputs.container} container. Remuxing. \n`;
|
||||
convert = true;
|
||||
} else if (file.container === inputs.container) {
|
||||
response.infoLog += `☑File is already in ${inputs.container} container. \n`;
|
||||
return response;
|
||||
}
|
||||
|
||||
if (convert === true) {
|
||||
response.preset += `, -map 0 -c copy -max_muxing_queue_size 9999 ${extraArguments}`;
|
||||
response.processFile = true;
|
||||
return response;
|
||||
}
|
||||
}
|
||||
module.exports.details = details;
|
||||
module.exports.plugin = plugin;
|
||||
Loading…
Add table
Add a link
Reference in a new issue