mangayomi-mirror/lib/services/anime_extractors/streamtape_extractor.dart
kodjomoustapha b10c3f3a22 misc changes
- remove cronet_http & cupertino_http
- use rhttp package as default http client
- fix #198 #200 crashes on multiple downloads
- fix #162 #102 unable to download with forbidden characters in the name (as it is fixed this can cause reading problems concerning chapters downloaded before this version)
- now supports all features on all platforms such as VPNs and HTTP proxies thanks to rhttp package
2024-08-21 13:30:13 +01:00

39 lines
1.4 KiB
Dart

import 'package:http_interceptor/http_interceptor.dart';
import 'package:mangayomi/models/video.dart';
import 'package:html/parser.dart' show parse;
import 'package:mangayomi/services/http/m_client.dart';
import 'package:mangayomi/utils/extensions/string_extensions.dart';
class StreamTapeExtractor {
Future<List<Video>> videosFromUrl(String url,
{String quality = "StreamTape"}) async {
final InterceptedClient client =
MClient.init(reqcopyWith: {'useDartHttpClient': true});
try {
const baseUrl = "https://streamtape.com/e/";
final newUrl =
!url.startsWith(baseUrl) ? "$baseUrl${url.split("/")[4]}" : url;
final response = await client.get(Uri.parse(newUrl));
final document = parse(response.body);
const targetLine = "document.getElementById('robotlink')";
String script = "";
final scri = document
.querySelectorAll("script")
.where((element) => element.innerHtml.contains(targetLine))
.map((e) => e.innerHtml)
.toList();
if (scri.isEmpty) {
return [];
}
script = scri.first.split("$targetLine.innerHTML = '").last;
final videoUrl =
"https:${script.substringBefore("'")}${script.substringAfter("+ ('xcd").substringBefore("'")}";
return [Video(videoUrl, quality, videoUrl)];
} catch (_) {
return [];
}
}
}