Anime-Sama fix player

This commit is contained in:
kodjomoustapha
2024-05-03 11:18:09 +01:00
parent 4f6a9d8138
commit 8a719d390c
2 changed files with 106 additions and 61 deletions

View File

@@ -32,7 +32,7 @@ class AnimeSama extends MProvider {
final latest = document final latest = document
.select("h2") .select("h2")
.where((MElement e) => .where((MElement e) =>
e.outerHtml.toLowerCase().contains("derniers ajouts")) e.outerHtml.toLowerCase().contains("derniers épisodes ajoutés"))
.toList(); .toList();
final seasonElements = (latest.first.nextElementSibling as MElement) final seasonElements = (latest.first.nextElementSibling as MElement)
.select(".scrollBarStyled > div") .select(".scrollBarStyled > div")
@@ -161,14 +161,7 @@ class AnimeSama extends MProvider {
String playerUrl = player["player"]; String playerUrl = player["player"];
List<MVideo> a = []; List<MVideo> a = [];
if (playerUrl.contains("sendvid")) { if (playerUrl.contains("sendvid")) {
a = await sendVidExtractor(playerUrl, null, lang); a = await sendVidExtractorr(playerUrl, "$lang ");
} else if (playerUrl.contains("anime-sama.fr")) {
MVideo video = MVideo();
video
..url = playerUrl
..originalUrl = playerUrl
..quality = "${lang} - AS Player";
a = [video];
} else if (playerUrl.contains("sibnet.ru")) { } else if (playerUrl.contains("sibnet.ru")) {
a = await sibnetExtractor(playerUrl, lang); a = await sibnetExtractor(playerUrl, lang);
} }
@@ -178,6 +171,59 @@ class AnimeSama extends MProvider {
return sortVideos(videos, source.id); return sortVideos(videos, source.id);
} }
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;
}
@override @override
List<dynamic> getFilterList() { List<dynamic> getFilterList() {
return [ return [
@@ -240,23 +286,21 @@ class AnimeSama extends MProvider {
Future<List<MManga>> fetchAnimeSeasons(String url) async { Future<List<MManga>> fetchAnimeSeasons(String url) async {
final res = (await client.get(Uri.parse(url))).body; final res = (await client.get(Uri.parse(url))).body;
var document = parseHtml(res); var document = parseHtml(res);
String animeName = document.getElementById("titreOeuvre")?.text ?? ""; String animeName = document.getElementById("titreOeuvre")?.text ?? "";
var seasonRegex = var seasonRegex = RegExp(r'panneauAnime\("(.*?)",\s*"(.*?)"\);');
RegExp("^\\s*panneauAnime\\(\"(.*)\", \"(.*)\"\\)", multiLine: true);
var scripts = document var scripts = document
.select("h2 + p + div > script, h2 + div > script") .select("h2 + p + div > script, h2 + div > script")
.map((MElement element) => element.text) .map((MElement element) => element.text)
.toList() .toList()
.join(""); .join("");
List<MManga> animeList = []; List<MManga> animeList = [];
List<RegExpMatch> seasonRegexReg = seasonRegex.allMatches(scripts).toList(); List<RegExpMatch> seasonRegexReg = seasonRegex.allMatches(scripts).toList();
for (var animeIndex = 0; animeIndex < seasonRegexReg.length; animeIndex++) { for (var animeIndex = 0; animeIndex < seasonRegexReg.length; animeIndex++) {
final seasonName = seasonRegexReg[animeIndex].group(1); final seasonName = seasonRegexReg[animeIndex].group(1);
final seasonStem = seasonRegexReg[animeIndex].group(2); final seasonStem = seasonRegexReg[animeIndex].group(2);
if (seasonName != "nom" && seasonStem != "url") {
if (seasonStem.toLowerCase().contains("film")) { if (seasonStem.toLowerCase().contains("film")) {
var moviesUrl = "$url/$seasonStem"; var moviesUrl = "$url/$seasonStem";
var movies = await fetchPlayers(moviesUrl); var movies = await fetchPlayers(moviesUrl);
@@ -310,6 +354,7 @@ class AnimeSama extends MProvider {
animeList.add(anime); animeList.add(anime);
} }
} }
}
return animeList; return animeList;
} }

View File

@@ -1,7 +1,7 @@
import '../../../../../model/source.dart'; import '../../../../../model/source.dart';
Source get animesamaSource => _animesama; Source get animesamaSource => _animesama;
const animesamaVersion = "0.0.25"; const animesamaVersion = "0.0.3";
const animesamaCodeUrl = const animesamaCodeUrl =
"https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/$branchName/dart/anime/src/fr/animesama/animesama.dart"; "https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/$branchName/dart/anime/src/fr/animesama/animesama.dart";
Source _animesama = Source( Source _animesama = Source(