mirror of
https://github.com/kodjodevf/mangayomi-extensions.git
synced 2026-02-15 03:10:59 +00:00
anime(animekai): split streams preference
This commit is contained in:
@@ -6,7 +6,7 @@ const mangayomiSources = [{
|
|||||||
"iconUrl": "https://www.google.com/s2/favicons?sz=256&domain=https://animekai.to/",
|
"iconUrl": "https://www.google.com/s2/favicons?sz=256&domain=https://animekai.to/",
|
||||||
"typeSource": "single",
|
"typeSource": "single",
|
||||||
"itemType": 1,
|
"itemType": 1,
|
||||||
"version": "0.2.1",
|
"version": "0.2.2",
|
||||||
"pkgPath": "anime/src/en/animekai.js"
|
"pkgPath": "anime/src/en/animekai.js"
|
||||||
}];
|
}];
|
||||||
|
|
||||||
@@ -450,6 +450,13 @@ class DefaultExtension extends MProvider {
|
|||||||
summary: "",
|
summary: "",
|
||||||
value: true
|
value: true
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
key: "animekai_pref_extract_streams",
|
||||||
|
switchPreferenceCompat: {
|
||||||
|
title: 'Split stream into different quality streams',
|
||||||
|
summary: "Split stream Auto into 360p/720p/1080p",
|
||||||
|
value: true
|
||||||
|
}
|
||||||
},
|
},
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
@@ -469,6 +476,41 @@ class DefaultExtension extends MProvider {
|
|||||||
return subs
|
return subs
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async formatStreams(sUrl, serverName, dubType) {
|
||||||
|
function streamNamer(res) {
|
||||||
|
return `${res} - ${dubType} : ${serverName}`
|
||||||
|
}
|
||||||
|
|
||||||
|
var streams = [{
|
||||||
|
url: sUrl,
|
||||||
|
originalUrl: sUrl,
|
||||||
|
quality: streamNamer("Auto")
|
||||||
|
}]
|
||||||
|
|
||||||
|
var pref = this.getPreference("animekai_pref_extract_streams")
|
||||||
|
if (!pref) return streams
|
||||||
|
|
||||||
|
var baseUrl = sUrl.split("/list.m3u8")[0].split("/list,")[0]
|
||||||
|
|
||||||
|
const response = await new Client().get(sUrl);
|
||||||
|
const body = response.body;
|
||||||
|
const lines = body.split('\n');
|
||||||
|
|
||||||
|
for (let i = 0; i < lines.length; i++) {
|
||||||
|
if (lines[i].startsWith('#EXT-X-STREAM-INF:')) {
|
||||||
|
var resolution = lines[i].match(/RESOLUTION=(\d+x\d+)/)[1];
|
||||||
|
var qUrl = lines[i + 1].trim();
|
||||||
|
var m3u8Url = `${baseUrl}/${qUrl}`
|
||||||
|
streams.push({
|
||||||
|
url: m3u8Url,
|
||||||
|
originalUrl: m3u8Url,
|
||||||
|
quality: streamNamer(resolution)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return streams
|
||||||
|
}
|
||||||
|
|
||||||
async getMegaUrl(vidId) {
|
async getMegaUrl(vidId) {
|
||||||
var token = await this.kaiEncrypt(vidId)
|
var token = await this.kaiEncrypt(vidId)
|
||||||
var res = await this.request(`/ajax/links/view?id=${vidId}&_=${token}`)
|
var res = await this.request(`/ajax/links/view?id=${vidId}&_=${token}`)
|
||||||
@@ -489,11 +531,8 @@ class DefaultExtension extends MProvider {
|
|||||||
var outEnc = body.result
|
var outEnc = body.result
|
||||||
var streamData = await this.megaDecrypt(outEnc)
|
var streamData = await this.megaDecrypt(outEnc)
|
||||||
var url = streamData.sources[0].file
|
var url = streamData.sources[0].file
|
||||||
streams.push({
|
|
||||||
url: url,
|
var streams =await this.formatStreams(url, serverName, dubType)
|
||||||
originalUrl: url,
|
|
||||||
quality: `Auto - ${dubType} : ${serverName}`
|
|
||||||
})
|
|
||||||
|
|
||||||
var subtitles = streamData.tracks
|
var subtitles = streamData.tracks
|
||||||
streams[0].subtitles = this.formatSubtitles(subtitles, dubType)
|
streams[0].subtitles = this.formatSubtitles(subtitles, dubType)
|
||||||
|
|||||||
Reference in New Issue
Block a user