Merge pull request #57 from Migz93/master

Update: Migz2CleanTitle
make-only-subtitle-default
HaveAGitGat 6 years ago committed by GitHub
commit 2c5a5f4e20
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -53,6 +53,10 @@ function plugin(file, librarySettings, inputs) {
} else { } else {
response.container = '.' + inputs.container response.container = '.' + inputs.container
} }
if (inputs.container == "mkv") {
extraArguments = "-map -0:d "
}
if (file.fileMedium !== "video") { if (file.fileMedium !== "video") {
response.processFile = false response.processFile = false
@ -73,6 +77,7 @@ function plugin(file, librarySettings, inputs) {
var minimumBitrate = ~~(targetBitrate * 0.7) var minimumBitrate = ~~(targetBitrate * 0.7)
var maximumBitrate = ~~(targetBitrate * 1.3) var maximumBitrate = ~~(targetBitrate * 1.3)
if (targetBitrate == "0") { if (targetBitrate == "0") {
response.processFile = false response.processFile = false
response.infoLog += "☒Target bitrate could not be calculated. Skipping this plugin. \n" response.infoLog += "☒Target bitrate could not be calculated. Skipping this plugin. \n"
@ -87,7 +92,7 @@ function plugin(file, librarySettings, inputs) {
return response return response
} else { } else {
response.processFile = true response.processFile = true
response.preset += `, -c copy` response.preset += `, -c copy ${extraArguments}`
response.infoLog += `☒Current bitrate is below configured bitrate cutoff of ${inputs.bitrate_cutoff} but is not in correct container. Remuxing to ${inputs.container} but not transcoding. \n` response.infoLog += `☒Current bitrate is below configured bitrate cutoff of ${inputs.bitrate_cutoff} but is not in correct container. Remuxing to ${inputs.container} but not transcoding. \n`
return response return response
} }
@ -102,7 +107,7 @@ function plugin(file, librarySettings, inputs) {
} }
if (file.ffProbeData.streams[i].codec_name == 'hevc' && file.container != '${inputs.container}') { if (file.ffProbeData.streams[i].codec_name == 'hevc' && file.container != '${inputs.container}') {
response.infoLog += `☒File is hevc but is not in ${inputs.container} container. Remuxing. \n` response.infoLog += `☒File is hevc but is not in ${inputs.container} container. Remuxing. \n`
response.preset = ', -map 0 -c copy' response.preset = `, -map 0 -c copy ${extraArguments}`
response.processFile = true; response.processFile = true;
return response return response
} }
@ -140,9 +145,6 @@ function plugin(file, librarySettings, inputs) {
response.preset = `-c:v vp9_cuvid` response.preset = `-c:v vp9_cuvid`
} }
if (inputs.container == "mkv") {
extraArguments = "-map -0:d "
}
response.preset += `,-map 0 -c:v hevc_nvenc -rc:v vbr_hq ${bitrateSettings} -bufsize 2M -spatial_aq:v 1 -c:a copy -c:s copy -max_muxing_queue_size 4096 ${extraArguments}` response.preset += `,-map 0 -c:v hevc_nvenc -rc:v vbr_hq ${bitrateSettings} -bufsize 2M -spatial_aq:v 1 -c:a copy -c:s copy -max_muxing_queue_size 4096 ${extraArguments}`
response.processFile = true response.processFile = true

@ -53,6 +53,10 @@ function plugin(file, librarySettings, inputs) {
} else { } else {
response.container = '.' + inputs.container response.container = '.' + inputs.container
} }
if (inputs.container == "mkv") {
extraArguments = "-map -0:d "
}
if (file.fileMedium !== "video") { if (file.fileMedium !== "video") {
response.processFile = false response.processFile = false
@ -87,7 +91,7 @@ function plugin(file, librarySettings, inputs) {
return response return response
} else { } else {
response.processFile = true response.processFile = true
response.preset += `, -c copy` response.preset += `, -c copy ${extraArguments}`
response.infoLog += `☒Current bitrate is below configured bitrate cutoff of ${inputs.bitrate_cutoff} but is not in correct container. Remuxing to ${inputs.container} but not transcoding. \n` response.infoLog += `☒Current bitrate is below configured bitrate cutoff of ${inputs.bitrate_cutoff} but is not in correct container. Remuxing to ${inputs.container} but not transcoding. \n`
return response return response
} }
@ -102,7 +106,7 @@ function plugin(file, librarySettings, inputs) {
} }
if (file.ffProbeData.streams[i].codec_name == 'hevc' && file.container != '${inputs.container}') { if (file.ffProbeData.streams[i].codec_name == 'hevc' && file.container != '${inputs.container}') {
response.infoLog += `☒File is hevc but is not in ${inputs.container} container. Remuxing. \n` response.infoLog += `☒File is hevc but is not in ${inputs.container} container. Remuxing. \n`
response.preset = ', -map 0 -c copy' response.preset = `, -map 0 -c copy ${extraArguments}`
response.processFile = true; response.processFile = true;
return response return response
} }
@ -112,9 +116,6 @@ function plugin(file, librarySettings, inputs) {
bitrateSettings = `-b:v ${targetBitrate}k -minrate ${minimumBitrate}k -maxrate ${maximumBitrate}k` bitrateSettings = `-b:v ${targetBitrate}k -minrate ${minimumBitrate}k -maxrate ${maximumBitrate}k`
response.infoLog += `Container for output selected as ${inputs.container}. \n Current bitrate = ${~~(file.file_size / (duration * 0.0075))} \n Bitrate settings: \nTarget = ${targetBitrate} \nMinimum = ${minimumBitrate} \nMaximum = ${maximumBitrate} \n` response.infoLog += `Container for output selected as ${inputs.container}. \n Current bitrate = ${~~(file.file_size / (duration * 0.0075))} \n Bitrate settings: \nTarget = ${targetBitrate} \nMinimum = ${minimumBitrate} \nMaximum = ${maximumBitrate} \n`
if (inputs.container == "mkv") {
extraArguments = "-map -0:d "
}
response.preset += `,-map 0 -c:v libx265 ${bitrateSettings} -bufsize 2M -spatial_aq:v 1 -c:a copy -c:s copy -max_muxing_queue_size 4096 ${extraArguments}` response.preset += `,-map 0 -c:v libx265 ${bitrateSettings} -bufsize 2M -spatial_aq:v 1 -c:a copy -c:s copy -max_muxing_queue_size 4096 ${extraArguments}`
response.processFile = true response.processFile = true

@ -5,14 +5,34 @@ function details() {
Name: "Migz-Clean title metadata", Name: "Migz-Clean title metadata",
Type: "Video", Type: "Video",
Operation: "Clean", Operation: "Clean",
Description: `This plugin removes title metadata from video/audio/subtitles, if it exists. \n\n`, Description: `This plugin removes title metadata from video/audio/subtitles, if it exists. Video checking is mandatory, audio and subtitles are optional.\n\n`,
Version: "1.10", Version: "1.20",
Link: "https://github.com/HaveAGitGat/Tdarr_Plugins/blob/master/Community/Tdarr_Plugin_MC93_Migz2CleanTitle.js", Link: "https://github.com/HaveAGitGat/Tdarr_Plugins/blob/master/Community/Tdarr_Plugin_MC93_Migz2CleanTitle.js",
Tags:'pre-processing,ffmpeg', Tags:'pre-processing,ffmpeg,configurable',
Inputs: [
{
name: 'clean_audio',
tooltip: `Specify if audio titles should be checked & cleaned. Optional.
\\nExample:\\n
true
\\nExample:\\n
false`
},
{
name: 'clean_subtitles',
tooltip: `Specify if subtitle titles should be checked & cleaned. Optional.
\\nExample:\\n
true
\\nExample:\\n
false`
},
]
} }
} }
function plugin(file) { function plugin(file, librarySettings, inputs) {
var response = { var response = {
processFile : false, processFile : false,
preset : '', preset : '',
@ -23,7 +43,7 @@ function plugin(file) {
infoLog : '', infoLog : '',
} }
var ffmpegCommandInsert = '' var ffmpegCommandInsert = ''
var videoIdx = 0 var videoIdx = 0
var audioIdx = 0 var audioIdx = 0
@ -36,47 +56,43 @@ function plugin(file) {
response.processFile = false; response.processFile = false;
return response return response
} }
try { if (typeof file.meta.Title != 'undefined') try {
if (typeof file.meta.Title != 'undefined' ){
ffmpegCommandInsert += ` -metadata title="" ` ffmpegCommandInsert += ` -metadata title="" `
response.infoLog += "1"
convert = true convert = true
} } catch (err) { }
} catch (err) { }
for (var i = 0; i < file.ffProbeData.streams.length; i++) try {
for (var i = 0; i < file.ffProbeData.streams.length; i++) {
if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "video") { if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "video") {
try { if (typeof file.ffProbeData.streams[i].tags.title != 'undefined') {
if (typeof file.ffProbeData.streams[i].tags.title != 'undefined') { response.infoLog += `☒Video stream title is not empty, most likely junk metadata. Removing title from stream ${i} \n`
ffmpegCommandInsert += ` -metadata:s:v:${videoIdx} title="" ` ffmpegCommandInsert += ` -metadata:s:v:${videoIdx} title="" `
convert = true convert = true
} }
} catch (err) { }
videoIdx++ videoIdx++
} }
if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "audio") {
try { if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "audio" && inputs.clean_audio.toLowerCase() == "true") {
if (typeof file.ffProbeData.streams[i].tags.title != 'undefined') { if (file.ffProbeData.streams[i].tags.title.split('.').length-1 > 3) {
ffmpegCommandInsert += ` -metadata:s:a:${audioIdx} title="" ` response.infoLog += `☒More then 3 full stops detected in subtitle title, likely to be junk metadata. Removing title from stream ${i} \n`
convert = true ffmpegCommandInsert += ` -metadata:s:a:${audioIdx} title="" `
} convert = true
} catch (err) { } }
audioIdx++ audioIdx++
} }
if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "subtitle") {
try { if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "subtitle" && inputs.clean_subtitles.toLowerCase() == "true") {
if (typeof file.ffProbeData.streams[i].tags.title != 'undefined') { if (file.ffProbeData.streams[i].tags.title.split('.').length-1 > 3) {
ffmpegCommandInsert += ` -metadata:s:s:${subtitleIdx} title="" ` response.infoLog += `☒More then 3 full stops detected in subtitle title, likely to be junk metadata. Removing title from stream ${i} \n`
convert = true ffmpegCommandInsert += ` -metadata:s:s:${subtitleIdx} title="" `
} convert = true
} catch (err) { } }
subtitleIdx++ subtitleIdx++
} }
} } catch (err) { }
if (convert == true){ if (convert == true) {
response.infoLog += "☒File has title metadata \n" response.infoLog += "☒File has title metadata. Removing \n"
response.preset = `,${ffmpegCommandInsert} -c copy` response.preset = `,${ffmpegCommandInsert} -c copy`
response.reQueueAfter = true; response.reQueueAfter = true;
response.processFile = true; response.processFile = true;
@ -87,4 +103,4 @@ function plugin(file) {
} }
module.exports.details = details; module.exports.details = details;
module.exports.plugin = plugin; module.exports.plugin = plugin;

Loading…
Cancel
Save