mirror of
https://github.com/kodjodevf/mangayomi-extensions.git
synced 2026-02-14 19:01:15 +00:00
@@ -6,7 +6,7 @@ const mangayomiSources = [{
|
|||||||
"iconUrl": "https://www.google.com/s2/favicons?sz=128&domain=https://aniplaynow.live/",
|
"iconUrl": "https://www.google.com/s2/favicons?sz=128&domain=https://aniplaynow.live/",
|
||||||
"typeSource": "single",
|
"typeSource": "single",
|
||||||
"itemType": 1,
|
"itemType": 1,
|
||||||
"version": "1.2.0",
|
"version": "1.2.3",
|
||||||
"dateFormat": "",
|
"dateFormat": "",
|
||||||
"dateFormatLocale": "",
|
"dateFormatLocale": "",
|
||||||
"pkgPath": "anime/src/en/aniplay.js"
|
"pkgPath": "anime/src/en/aniplay.js"
|
||||||
@@ -389,7 +389,7 @@ class DefaultExtension extends MProvider {
|
|||||||
var slug = "/fetch?url="
|
var slug = "/fetch?url="
|
||||||
var ref = "&ref="
|
var ref = "&ref="
|
||||||
if (providerId == "yuki") {
|
if (providerId == "yuki") {
|
||||||
slug = "/zoroprox?url="
|
slug = "/yukiprox?url="
|
||||||
ref = ""
|
ref = ""
|
||||||
} else if (providerId == "pahe") {
|
} else if (providerId == "pahe") {
|
||||||
ref += "https://kwik.si"
|
ref += "https://kwik.si"
|
||||||
@@ -409,19 +409,22 @@ class DefaultExtension extends MProvider {
|
|||||||
|
|
||||||
// Extracts the streams url for different resolutions from a hls stream.
|
// Extracts the streams url for different resolutions from a hls stream.
|
||||||
async extractStreams(url, providerId, hdr = {}) {
|
async extractStreams(url, providerId, hdr = {}) {
|
||||||
const response = await new Client().get(url, hdr);
|
|
||||||
const body = response.body;
|
|
||||||
const lines = body.split('\n');
|
|
||||||
var streams = [{
|
var streams = [{
|
||||||
url: url,
|
url: url,
|
||||||
originalUrl: url,
|
originalUrl: url,
|
||||||
quality: `Auto - ${providerId}`,
|
quality: `Auto - ${providerId}`,
|
||||||
headers: hdr
|
headers: hdr
|
||||||
}];
|
}];
|
||||||
|
var doExtract = this.getPreference("aniplay_pref_extract_streams");
|
||||||
// Pahe only has auto
|
// Pahe only has auto
|
||||||
if (providerId === "pahe") {
|
if (providerId === "pahe" || !doExtract) {
|
||||||
return streams;
|
return streams;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const response = await new Client().get(url, hdr);
|
||||||
|
const body = response.body;
|
||||||
|
const lines = body.split('\n');
|
||||||
|
|
||||||
for (let i = 0; i < lines.length; i++) {
|
for (let i = 0; i < lines.length; i++) {
|
||||||
if (lines[i].startsWith('#EXT-X-STREAM-INF:')) {
|
if (lines[i].startsWith('#EXT-X-STREAM-INF:')) {
|
||||||
var resolution = lines[i].match(/RESOLUTION=(\d+x\d+)/)[1];
|
var resolution = lines[i].match(/RESOLUTION=(\d+x\d+)/)[1];
|
||||||
@@ -453,10 +456,13 @@ class DefaultExtension extends MProvider {
|
|||||||
|
|
||||||
var subtitles = []
|
var subtitles = []
|
||||||
result.subtitles.forEach(sub => {
|
result.subtitles.forEach(sub => {
|
||||||
subtitles.push({
|
var label = sub.label
|
||||||
"label": sub.lang,
|
if (label.indexOf("thumbnail") < 0) { // thumbnails shouldnt be included
|
||||||
"file": sub.url,
|
subtitles.push({
|
||||||
});
|
"label": label,
|
||||||
|
"file": sub.url,
|
||||||
|
});
|
||||||
|
}
|
||||||
})
|
})
|
||||||
streams[0].subtitles = subtitles
|
streams[0].subtitles = subtitles
|
||||||
|
|
||||||
@@ -527,7 +533,7 @@ class DefaultExtension extends MProvider {
|
|||||||
} else {
|
} else {
|
||||||
streams = await this.getAnyStreams(result) //If new provider found getAnyStreams will extract only the streams
|
streams = await this.getAnyStreams(result) //If new provider found getAnyStreams will extract only the streams
|
||||||
}
|
}
|
||||||
|
|
||||||
streams = await this.streamProxy(providerId, streams)
|
streams = await this.streamProxy(providerId, streams)
|
||||||
return await this.sortStreams(streams)
|
return await this.sortStreams(streams)
|
||||||
}
|
}
|
||||||
@@ -579,7 +585,14 @@ class DefaultExtension extends MProvider {
|
|||||||
"entries": ["Sub", "Dub"],
|
"entries": ["Sub", "Dub"],
|
||||||
"entryValues": ["sub", "dub"],
|
"entryValues": ["sub", "dub"],
|
||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
|
"key": "aniplay_pref_extract_streams",
|
||||||
|
"switchPreferenceCompat": {
|
||||||
|
'title': 'Split stream into different quality streams',
|
||||||
|
"summary": "Split stream Auto into 360p/720p/1080p",
|
||||||
|
"value": true
|
||||||
|
}
|
||||||
|
},{
|
||||||
key: 'aniplay_pref_video_resolution',
|
key: 'aniplay_pref_video_resolution',
|
||||||
listPreference: {
|
listPreference: {
|
||||||
title: 'Preferred video resolution',
|
title: 'Preferred video resolution',
|
||||||
|
|||||||
Reference in New Issue
Block a user