check pm for archive and stream link status

This commit is contained in:
TheBeastLT
2022-04-05 15:41:27 +02:00
parent a689620f74
commit 0ef906dacc
3 changed files with 10 additions and 5 deletions

View File

@@ -17,7 +17,7 @@ async function getCachedStreams(streams, apiKey) {
if (error && error.code === 'AUTH_BAD_APIKEY') { if (error && error.code === 'AUTH_BAD_APIKEY') {
return Promise.reject(BadTokenError); return Promise.reject(BadTokenError);
} }
console.warn('Failed AllDebrid cached torrent availability request:', error); console.warn(`Failed AllDebrid cached [${hashes[0]}] torrent availability request:`, error);
return undefined; return undefined;
}); });
return available && available.data && available.data.magnets && streams return available && available.data && available.data.magnets && streams

View File

@@ -120,7 +120,7 @@ async function _unrestrictLink(DL, torrent, fileIndex) {
? torrent.files[fileIndex] ? torrent.files[fileIndex]
: torrent.files.filter(file => file.downloadPercent === 100).sort((a, b) => b.size - a.size)[0]; : torrent.files.filter(file => file.downloadPercent === 100).sort((a, b) => b.size - a.size)[0];
if (!targetFile && isArchive(targetFile.downloadUrl)) { if (!targetFile && torrent.files.every(file => isArchive(file.downloadUrl))) {
console.log(`Only DebridLink archive is available for [${torrent.hashString}] ${fileIndex}`) console.log(`Only DebridLink archive is available for [${torrent.hashString}] ${fileIndex}`)
return StaticResponse.FAILED_RAR; return StaticResponse.FAILED_RAR;
} }

View File

@@ -1,7 +1,7 @@
const PremiumizeClient = require('premiumize-api'); const PremiumizeClient = require('premiumize-api');
const magnet = require('magnet-uri'); const magnet = require('magnet-uri');
const { Type } = require('../lib/types'); const { Type } = require('../lib/types');
const { isVideo } = require('../lib/extension'); const { isVideo, isArchive } = require('../lib/extension');
const StaticResponse = require('./static'); const StaticResponse = require('./static');
const { getMagnetLink } = require('../lib/magnetHelper'); const { getMagnetLink } = require('../lib/magnetHelper');
const { BadTokenError, chunkArray } = require('./mochHelper'); const { BadTokenError, chunkArray } = require('./mochHelper');
@@ -90,7 +90,7 @@ async function getFolderContents(PM, itemId, ip, folderPrefix = '') {
} }
async function resolve({ ip, isBrowser, apiKey, infoHash, cachedEntryInfo, fileIndex }) { async function resolve({ ip, isBrowser, apiKey, infoHash, cachedEntryInfo, fileIndex }) {
console.log(`Unrestricting Premiumize ${infoHash} [${fileIndex}] for IP ${ip}`); console.log(`Unrestricting Premiumize ${infoHash} [${fileIndex}] for IP ${ip} from browser=${isBrowser}`);
const options = await getDefaultOptions(); const options = await getDefaultOptions();
const PM = new PremiumizeClient(apiKey, options); const PM = new PremiumizeClient(apiKey, options);
return _getCachedLink(PM, infoHash, cachedEntryInfo, fileIndex, ip, isBrowser) return _getCachedLink(PM, infoHash, cachedEntryInfo, fileIndex, ip, isBrowser)
@@ -126,7 +126,12 @@ async function _getCachedLink(PM, infoHash, encodedFileName, fileIndex, ip, isBr
const targetVideo = Number.isInteger(fileIndex) const targetVideo = Number.isInteger(fileIndex)
? videos.find(video => video.path.includes(targetFileName)) ? videos.find(video => video.path.includes(targetFileName))
: videos.sort((a, b) => b.size - a.size)[0]; : videos.sort((a, b) => b.size - a.size)[0];
const unrestrictedLink = isBrowser && targetVideo.stream_link || targetVideo.link; if (!targetVideo && videos.every(video => isArchive(video.path))) {
console.log(`Only Premiumize archive is available for [${infoHash}] ${fileIndex}`)
return StaticResponse.FAILED_RAR;
}
const streamLink = isBrowser && targetVideo.transcode_status === 'finished' && targetVideo.stream_link;
const unrestrictedLink = streamLink || targetVideo.link;
console.log(`Unrestricted Premiumize ${infoHash} [${fileIndex}] to ${unrestrictedLink}`); console.log(`Unrestricted Premiumize ${infoHash} [${fileIndex}] to ${unrestrictedLink}`);
return unrestrictedLink; return unrestrictedLink;
} }