mirror of
https://github.com/kodjodevf/mangayomi-extensions.git
synced 2026-02-17 12:20:28 +00:00
Merge branch 'kodjodevf:main' into main
This commit is contained in:
@@ -12,6 +12,9 @@ class AnimePahe extends MProvider {
|
|||||||
@override
|
@override
|
||||||
String get baseUrl => getPreferenceValue(source.id, "preferred_domain");
|
String get baseUrl => getPreferenceValue(source.id, "preferred_domain");
|
||||||
|
|
||||||
|
@override
|
||||||
|
Map<String, String> get headers => {'cookie': '__ddg1_=;__ddg2_=;'};
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Future<MPages> getPopular(int page) async {
|
Future<MPages> getPopular(int page) async {
|
||||||
return await getLatestUpdates(page);
|
return await getLatestUpdates(page);
|
||||||
@@ -19,8 +22,9 @@ class AnimePahe extends MProvider {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Future<MPages> getLatestUpdates(int page) async {
|
Future<MPages> getLatestUpdates(int page) async {
|
||||||
final res =
|
final res = (await client.get(Uri.parse("$baseUrl/api?m=airing&page=$page"),
|
||||||
(await client.get(Uri.parse("$baseUrl/api?m=airing&page=$page"))).body;
|
headers: headers))
|
||||||
|
.body;
|
||||||
final jsonResult = json.decode(res);
|
final jsonResult = json.decode(res);
|
||||||
final hasNextPage = jsonResult["current_page"] < jsonResult["last_page"];
|
final hasNextPage = jsonResult["current_page"] < jsonResult["last_page"];
|
||||||
List<MManga> animeList = [];
|
List<MManga> animeList = [];
|
||||||
@@ -37,8 +41,9 @@ class AnimePahe extends MProvider {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Future<MPages> search(String query, int page, FilterList filterList) async {
|
Future<MPages> search(String query, int page, FilterList filterList) async {
|
||||||
final res =
|
final res = (await client.get(
|
||||||
(await client.get(Uri.parse("$baseUrl/api?m=search&l=8&q=$query")))
|
Uri.parse("$baseUrl/api?m=search&l=8&q=$query"),
|
||||||
|
headers: headers))
|
||||||
.body;
|
.body;
|
||||||
final jsonResult = json.decode(res);
|
final jsonResult = json.decode(res);
|
||||||
List<MManga> animeList = [];
|
List<MManga> animeList = [];
|
||||||
@@ -61,8 +66,9 @@ class AnimePahe extends MProvider {
|
|||||||
final id = substringBefore(substringAfterLast(url, "?anime_id="), "&name=");
|
final id = substringBefore(substringAfterLast(url, "?anime_id="), "&name=");
|
||||||
final name = substringAfterLast(url, "&name=");
|
final name = substringAfterLast(url, "&name=");
|
||||||
final session = await getSession(name, id);
|
final session = await getSession(name, id);
|
||||||
final res =
|
final res = (await client.get(
|
||||||
(await client.get(Uri.parse("$baseUrl/anime/$session?anime_id=$id")))
|
Uri.parse("$baseUrl/anime/$session?anime_id=$id"),
|
||||||
|
headers: headers))
|
||||||
.body;
|
.body;
|
||||||
final document = parseHtml(res);
|
final document = parseHtml(res);
|
||||||
final status =
|
final status =
|
||||||
@@ -91,7 +97,7 @@ class AnimePahe extends MProvider {
|
|||||||
anime.description += "\n\n$synonyms";
|
anime.description += "\n\n$synonyms";
|
||||||
}
|
}
|
||||||
final epUrl = "$baseUrl/api?m=release&id=$session&sort=episode_desc&page=1";
|
final epUrl = "$baseUrl/api?m=release&id=$session&sort=episode_desc&page=1";
|
||||||
final resEp = (await client.get(Uri.parse(epUrl))).body;
|
final resEp = (await client.get(Uri.parse(epUrl), headers: headers)).body;
|
||||||
final episodes = await recursivePages(epUrl, resEp, session);
|
final episodes = await recursivePages(epUrl, resEp, session);
|
||||||
|
|
||||||
anime.chapters = episodes;
|
anime.chapters = episodes;
|
||||||
@@ -114,15 +120,17 @@ class AnimePahe extends MProvider {
|
|||||||
}
|
}
|
||||||
if (hasNextPage) {
|
if (hasNextPage) {
|
||||||
final newUrl = "${substringBeforeLast(url, "&page=")}&page=${page + 1}";
|
final newUrl = "${substringBeforeLast(url, "&page=")}&page=${page + 1}";
|
||||||
final newRes = (await client.get(Uri.parse(newUrl))).body;
|
final newRes =
|
||||||
|
(await client.get(Uri.parse(newUrl), headers: headers)).body;
|
||||||
animeList.addAll(await recursivePages(newUrl, newRes, session));
|
animeList.addAll(await recursivePages(newUrl, newRes, session));
|
||||||
}
|
}
|
||||||
return animeList;
|
return animeList;
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<String> getSession(String title, String animeId) async {
|
Future<String> getSession(String title, String animeId) async {
|
||||||
final res =
|
final res = (await client.get(Uri.parse("$baseUrl/api?m=search&q=$title"),
|
||||||
(await client.get(Uri.parse("$baseUrl/api?m=search&q=$title"))).body;
|
headers: headers))
|
||||||
|
.body;
|
||||||
return substringBefore(
|
return substringBefore(
|
||||||
substringAfter(
|
substringAfter(
|
||||||
substringAfter(res, "\"id\":$animeId"), "\"session\":\""),
|
substringAfter(res, "\"id\":$animeId"), "\"session\":\""),
|
||||||
@@ -134,7 +142,7 @@ class AnimePahe extends MProvider {
|
|||||||
//by default we use rhttp package but it does not support `followRedirects`
|
//by default we use rhttp package but it does not support `followRedirects`
|
||||||
//so setting `useDartHttpClient` to true allows us to use a Dart http package that supports `followRedirects`
|
//so setting `useDartHttpClient` to true allows us to use a Dart http package that supports `followRedirects`
|
||||||
final client = Client(source, json.encode({"useDartHttpClient": true}));
|
final client = Client(source, json.encode({"useDartHttpClient": true}));
|
||||||
final res = (await client.get(Uri.parse("$baseUrl$url")));
|
final res = (await client.get(Uri.parse("$baseUrl$url"), headers: headers));
|
||||||
final document = parseHtml(res.body);
|
final document = parseHtml(res.body);
|
||||||
final downloadLinks = document.select("div#pickDownload > a");
|
final downloadLinks = document.select("div#pickDownload > a");
|
||||||
final buttons = document.select("div#resolutionMenu > button");
|
final buttons = document.select("div#resolutionMenu > button");
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import '../../../../../model/source.dart';
|
import '../../../../../model/source.dart';
|
||||||
|
|
||||||
Source get animepaheSource => _animepaheSource;
|
Source get animepaheSource => _animepaheSource;
|
||||||
const _animepaheVersion = "0.0.4";
|
const _animepaheVersion = "0.0.45";
|
||||||
const _animepaheSourceCodeUrl =
|
const _animepaheSourceCodeUrl =
|
||||||
"https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/$branchName/dart/anime/src/en/animepahe/animepahe.dart";
|
"https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/$branchName/dart/anime/src/en/animepahe/animepahe.dart";
|
||||||
Source _animepaheSource = Source(
|
Source _animepaheSource = Source(
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ const mangayomiSources = [{
|
|||||||
"iconUrl": "https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/main/javascript/icon/all.torrentio.png",
|
"iconUrl": "https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/main/javascript/icon/all.torrentio.png",
|
||||||
"typeSource": "torrent",
|
"typeSource": "torrent",
|
||||||
"isManga": false,
|
"isManga": false,
|
||||||
"version": "0.0.2",
|
"version": "0.0.25",
|
||||||
"appMinVerReq": "0.3.8",
|
"appMinVerReq": "0.3.8",
|
||||||
"pkgPath": "anime/src/all/torrentio.js"
|
"pkgPath": "anime/src/all/torrentio.js"
|
||||||
}];
|
}];
|
||||||
@@ -161,14 +161,14 @@ class DefaultExtension extends MProvider {
|
|||||||
case "show":
|
case "show":
|
||||||
const videos = meta.videos || [];
|
const videos = meta.videos || [];
|
||||||
return videos
|
return videos
|
||||||
|
.filter(video => (video.firstAired ? new Date(video.firstAired) : Date.now()) < Date.now())
|
||||||
.map(video => {
|
.map(video => {
|
||||||
const firstAired = video.firstAired ? new Date(video.firstAired) : new Date();
|
const firstAired = video.firstAired ? new Date(video.firstAired) : Date.now();
|
||||||
|
|
||||||
return {
|
return {
|
||||||
url: `/stream/series/${video.id}.json`,
|
url: `/stream/series/${video.id}.json`,
|
||||||
dateUpload: firstAired.valueOf().toString(),
|
dateUpload: firstAired.valueOf().toString(),
|
||||||
name: `S${(video.season || "").toString().trim()}:E${(video.number || "").toString()} - ${video.name || ""}`,
|
name: `S${(video.season || "").toString().trim()}:E${(video.number || "").toString()} - ${video.name || ""}`,
|
||||||
scanlator: firstAired > Date.now() ? "Upcoming" : ""
|
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
.sort((a, b) => {
|
.sort((a, b) => {
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ const mangayomiSources = [{
|
|||||||
"iconUrl": "https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/main/javascript/icon/all.torrentio.png",
|
"iconUrl": "https://raw.githubusercontent.com/kodjodevf/mangayomi-extensions/main/javascript/icon/all.torrentio.png",
|
||||||
"typeSource": "torrent",
|
"typeSource": "torrent",
|
||||||
"isManga": false,
|
"isManga": false,
|
||||||
"version": "0.0.15",
|
"version": "0.0.2",
|
||||||
"appMinVerReq": "0.3.8",
|
"appMinVerReq": "0.3.8",
|
||||||
"pkgPath": "anime/src/all/torrentioanime.js"
|
"pkgPath": "anime/src/all/torrentioanime.js"
|
||||||
}];
|
}];
|
||||||
@@ -247,10 +247,9 @@ class DefaultExtension extends MProvider {
|
|||||||
case "series": {
|
case "series": {
|
||||||
const videos = episodeList.meta.videos;
|
const videos = episodeList.meta.videos;
|
||||||
return videos
|
return videos
|
||||||
.filter(video => video.thumbnail !== null)
|
.filter(video => video.thumbnail !== null && ((video.released ? new Date(video.released) : Date.now()) < Date.now()))
|
||||||
.map(video => {
|
.map(video => {
|
||||||
const releaseDate = video.released ? new Date(video.released) : Date.now();
|
const releaseDate = video.released ? new Date(video.released) : Date.now();
|
||||||
const upcoming = releaseDate > Date.now() ? "Upcoming" : "";
|
|
||||||
return {
|
return {
|
||||||
url: `/stream/series/${video.id}.json`,
|
url: `/stream/series/${video.id}.json`,
|
||||||
dateUpload: releaseDate.valueOf().toString(),
|
dateUpload: releaseDate.valueOf().toString(),
|
||||||
@@ -258,7 +257,6 @@ class DefaultExtension extends MProvider {
|
|||||||
?.replace(/^Episode /, "")
|
?.replace(/^Episode /, "")
|
||||||
?.replace(/^\d+\s*/, "")
|
?.replace(/^\d+\s*/, "")
|
||||||
?.trim()}`,
|
?.trim()}`,
|
||||||
scanlator: upcoming,
|
|
||||||
};
|
};
|
||||||
})
|
})
|
||||||
.reverse();
|
.reverse();
|
||||||
|
|||||||
Reference in New Issue
Block a user