mirror of
https://github.com/kodjodevf/mangayomi-extensions.git
synced 2026-02-14 02:41:39 +00:00
OtakuFr fix player
This commit is contained in:
@@ -175,11 +175,12 @@ class OtakuFr extends MProvider {
|
|||||||
Future<List<MVideo>> getVideoList(String url) async {
|
Future<List<MVideo>> getVideoList(String url) async {
|
||||||
final res = (await client.get(Uri.parse(url))).body;
|
final res = (await client.get(Uri.parse(url))).body;
|
||||||
|
|
||||||
final servers = xpath(res, '//*[@id="nav-tabContent"]/div/iframe/@src');
|
final servers = parseHtml(res).select("div.tab-content iframe[src]");
|
||||||
List<MVideo> videos = [];
|
List<MVideo> videos = [];
|
||||||
final hosterSelection = preferenceHosterSelection(source.id);
|
final hosterSelection = preferenceHosterSelection(source.id);
|
||||||
for (var url in servers) {
|
for (var url in servers) {
|
||||||
final resServer = (await client.get(Uri.parse(fixUrl(url)),
|
final urll = url.getSrc != "about:blank" ? url.getSrc : url.getDataSrc;
|
||||||
|
final resServer = (await client.get(Uri.parse(fixUrl(urll)),
|
||||||
headers: {"X-Requested-With": "XMLHttpRequest"}))
|
headers: {"X-Requested-With": "XMLHttpRequest"}))
|
||||||
.body;
|
.body;
|
||||||
final serverUrl =
|
final serverUrl =
|
||||||
@@ -196,7 +197,7 @@ class OtakuFr extends MProvider {
|
|||||||
a = await doodExtractor(serverUrl);
|
a = await doodExtractor(serverUrl);
|
||||||
} else if (serverUrl.contains("https://voe.sx") &&
|
} else if (serverUrl.contains("https://voe.sx") &&
|
||||||
hosterSelection.contains("Voe")) {
|
hosterSelection.contains("Voe")) {
|
||||||
a = await voeExtractor(serverUrl, null);
|
// a = await voeExtractor(serverUrl, null);
|
||||||
} else if (serverUrl.contains("https://ok.ru") &&
|
} else if (serverUrl.contains("https://ok.ru") &&
|
||||||
hosterSelection.contains("Okru")) {
|
hosterSelection.contains("Okru")) {
|
||||||
a = await okruExtractor(serverUrl);
|
a = await okruExtractor(serverUrl);
|
||||||
@@ -205,7 +206,7 @@ class OtakuFr extends MProvider {
|
|||||||
a = await upstreamExtractor(serverUrl);
|
a = await upstreamExtractor(serverUrl);
|
||||||
} else if (serverUrl.contains("sendvid") &&
|
} else if (serverUrl.contains("sendvid") &&
|
||||||
hosterSelection.contains("Sendvid")) {
|
hosterSelection.contains("Sendvid")) {
|
||||||
a = await sendVidExtractor(serverUrl, null, "");
|
a = await sendVidExtractorr(serverUrl, "");
|
||||||
}
|
}
|
||||||
videos.addAll(a);
|
videos.addAll(a);
|
||||||
}
|
}
|
||||||
@@ -351,6 +352,59 @@ class OtakuFr extends MProvider {
|
|||||||
return getPreferenceValue(sourceId, "hoster_selection");
|
return getPreferenceValue(sourceId, "hoster_selection");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<List<MVideo>> sendVidExtractorr(String url, String prefix) async {
|
||||||
|
final res = (await client.get(Uri.parse(url))).body;
|
||||||
|
final document = parseHtml(res);
|
||||||
|
final masterUrl = document.selectFirst("source#video_source")?.attr("src");
|
||||||
|
if (masterUrl == null) return [];
|
||||||
|
final masterHeaders = {
|
||||||
|
"Accept": "*/*",
|
||||||
|
"Host": Uri.parse(masterUrl).host,
|
||||||
|
"Origin": "https://${Uri.parse(url).host}",
|
||||||
|
"Referer": "https://${Uri.parse(url).host}/",
|
||||||
|
};
|
||||||
|
List<MVideo> videos = [];
|
||||||
|
if (masterUrl.contains(".m3u8")) {
|
||||||
|
final masterPlaylistRes = (await client.get(Uri.parse(masterUrl))).body;
|
||||||
|
|
||||||
|
for (var it in substringAfter(masterPlaylistRes, "#EXT-X-STREAM-INF:")
|
||||||
|
.split("#EXT-X-STREAM-INF:")) {
|
||||||
|
final quality =
|
||||||
|
"${substringBefore(substringBefore(substringAfter(substringAfter(it, "RESOLUTION="), "x"), ","), "\n")}p";
|
||||||
|
|
||||||
|
String videoUrl = substringBefore(substringAfter(it, "\n"), "\n");
|
||||||
|
|
||||||
|
if (!videoUrl.startsWith("http")) {
|
||||||
|
videoUrl =
|
||||||
|
"${masterUrl.split("/").sublist(0, masterUrl.split("/").length - 1).join("/")}/$videoUrl";
|
||||||
|
}
|
||||||
|
final videoHeaders = {
|
||||||
|
"Accept": "*/*",
|
||||||
|
"Host": Uri.parse(videoUrl).host,
|
||||||
|
"Origin": "https://${Uri.parse(url).host}",
|
||||||
|
"Referer": "https://${Uri.parse(url).host}/",
|
||||||
|
};
|
||||||
|
var video = MVideo();
|
||||||
|
video
|
||||||
|
..url = videoUrl
|
||||||
|
..originalUrl = videoUrl
|
||||||
|
..quality = prefix + "Sendvid:$quality"
|
||||||
|
..headers = videoHeaders;
|
||||||
|
videos.add(video);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
var video = MVideo();
|
||||||
|
video
|
||||||
|
..url = masterUrl
|
||||||
|
..originalUrl = masterUrl
|
||||||
|
..quality = prefix + "Sendvid:default"
|
||||||
|
..headers = masterHeaders;
|
||||||
|
videos.add(video);
|
||||||
|
}
|
||||||
|
|
||||||
|
return videos;
|
||||||
|
}
|
||||||
|
|
||||||
Future<List<MVideo>> upstreamExtractor(String url) async {
|
Future<List<MVideo>> upstreamExtractor(String url) async {
|
||||||
final res = (await client.get(Uri.parse(url))).body;
|
final res = (await client.get(Uri.parse(url))).body;
|
||||||
final js = xpath(res, '//script[contains(text(), "m3u8")]/text()');
|
final js = xpath(res, '//script[contains(text(), "m3u8")]/text()');
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import '../../../../../model/source.dart';
|
import '../../../../../model/source.dart';
|
||||||
|
|
||||||
Source get otakufr => _otakufr;
|
Source get otakufr => _otakufr;
|
||||||
const otakufrVersion = "0.0.85";
|
const otakufrVersion = "0.0.9";
|
||||||
const otakufrCodeUrl =
|
const otakufrCodeUrl =
|
||||||
"https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/$branchName/dart/anime/src/fr/otakufr/otakufr.dart";
|
"https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/$branchName/dart/anime/src/fr/otakufr/otakufr.dart";
|
||||||
Source _otakufr = Source(
|
Source _otakufr = Source(
|
||||||
|
|||||||
Reference in New Issue
Block a user