mirror of
https://github.com/gabehf/Tdarr_Plugins.git
synced 2026-03-09 07:29:04 -07:00
Add new action
This commit is contained in:
parent
372f374079
commit
d60e0c17ad
4 changed files with 85 additions and 21 deletions
|
|
@ -8,6 +8,6 @@ if (fs.existsSync(path.join(process.cwd() + "/npm"))) {
|
|||
const importFresh = require(rootModules+'import-fresh');
|
||||
|
||||
|
||||
var remuxContainer = importFresh('./library/actions/remuxContainer.js')
|
||||
module.exports.remuxContainer = importFresh('./library/actions/remuxContainer.js')
|
||||
module.exports.transcodeStandardiseAudioCodecs = importFresh('./library/actions/transcodeStandardiseAudioCodecs.js')
|
||||
|
||||
module.exports.remuxContainer = remuxContainer
|
||||
|
|
|
|||
|
|
@ -8,16 +8,8 @@ if (fs.existsSync(path.join(process.cwd() + "/npm"))) {
|
|||
const importFresh = require(rootModules+'import-fresh');
|
||||
|
||||
|
||||
var filterByAge = importFresh('./library/filters/filterByAge.js')
|
||||
var filterByCodec = importFresh('./library/filters/filterByCodec.js')
|
||||
var filterByMedium = importFresh('./library/filters/filterByMedium.js')
|
||||
var filterByResolution = importFresh('./library/filters/filterByResolution.js')
|
||||
var filterBySize = importFresh('./library/filters/filterBySize.js')
|
||||
|
||||
|
||||
|
||||
module.exports.filterByAge = filterByAge
|
||||
module.exports.filterByCodec = filterByCodec
|
||||
module.exports.filterByMedium = filterByMedium
|
||||
module.exports.filterByResolution = filterByResolution
|
||||
module.exports.filterBySize = filterBySize
|
||||
module.exports.filterByAge = importFresh('./library/filters/filterByAge.js')
|
||||
module.exports.filterByCodec = importFresh('./library/filters/filterByCodec.js')
|
||||
module.exports.filterByMedium = importFresh('./library/filters/filterByMedium.js')
|
||||
module.exports.filterByResolution = importFresh('./library/filters/filterByResolution.js')
|
||||
module.exports.filterBySize = importFresh('./library/filters/filterBySize.js')
|
||||
|
|
@ -7,9 +7,5 @@ if (fs.existsSync(path.join(process.cwd() + "/npm"))) {
|
|||
}
|
||||
const importFresh = require(rootModules+'import-fresh');
|
||||
|
||||
var filters = importFresh('./filters.js')
|
||||
var actions = importFresh('./actions.js')
|
||||
|
||||
module.exports.filters = filters
|
||||
module.exports.actions = actions
|
||||
|
||||
module.exports.filters = importFresh('./filters.js')
|
||||
module.exports.actions = importFresh('./actions.js')
|
||||
|
|
|
|||
76
methods/library/actions/transcodeStandardiseAudioCodecs.js
Normal file
76
methods/library/actions/transcodeStandardiseAudioCodecs.js
Normal file
|
|
@ -0,0 +1,76 @@
|
|||
|
||||
|
||||
module.exports = function transcodeStandardiseAudioCodecs(file, audioEncoder) {
|
||||
|
||||
|
||||
try {
|
||||
|
||||
var audioIdx = -1
|
||||
var hasNonSpecifiedAudioCodecStream = false
|
||||
var ffmpegCommandInsert = ''
|
||||
|
||||
|
||||
//Function required responses
|
||||
// preset
|
||||
// processFile
|
||||
// note
|
||||
|
||||
|
||||
|
||||
var audioCodec = audioEncoder
|
||||
|
||||
if (audioEncoder == 'dca') {
|
||||
audioCodec = 'dts'
|
||||
}
|
||||
|
||||
|
||||
|
||||
for (var i = 0; i < file.ffProbeData.streams.length; i++) {
|
||||
|
||||
|
||||
try {
|
||||
if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "audio") {
|
||||
audioIdx++
|
||||
}
|
||||
} catch (err) { }
|
||||
|
||||
|
||||
try {
|
||||
if (file.ffProbeData.streams[i].codec_type.toLowerCase() == "audio" && file.ffProbeData.streams[i].codec_name != audioCodec) {
|
||||
|
||||
ffmpegCommandInsert += ` -c:a:${audioIdx} ${audioEncoder}`
|
||||
hasNonSpecifiedAudioCodecStream = true
|
||||
|
||||
}
|
||||
} catch (err) { }
|
||||
}
|
||||
|
||||
|
||||
if (hasNonSpecifiedAudioCodecStream === true) {
|
||||
|
||||
return {
|
||||
preset: `,-map 0:v -map 0:a -map 0:s? -map 0:d? -c copy ${ffmpegCommandInsert}`,
|
||||
processFile: true,
|
||||
note: `File has audio streams which aren't in ${audioCodec} \n`
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
return {
|
||||
preset: '',
|
||||
processFile: false,
|
||||
note: `File does not have any audio streams which aren't in ${audioCodec} \n`
|
||||
}
|
||||
|
||||
|
||||
|
||||
} catch (err) {
|
||||
|
||||
return {
|
||||
preset: '',
|
||||
processFile: false,
|
||||
note: `library.actions.transcodeStandardiseAudioCodecs error: ${err} \n`
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue