mirror of
https://github.com/hexated/cloudstream-extensions-hexated.git
synced 2024-08-15 00:03:22 +00:00
fix
This commit is contained in:
parent
cb11c787df
commit
dab8a0d0bc
7 changed files with 644 additions and 522 deletions
4
.github/workflows/build.yml
vendored
4
.github/workflows/build.yml
vendored
|
@ -46,6 +46,8 @@ jobs:
|
||||||
SORAHE: ${{ secrets.SORAHE }}
|
SORAHE: ${{ secrets.SORAHE }}
|
||||||
SORAXA: ${{ secrets.SORAXA }}
|
SORAXA: ${{ secrets.SORAXA }}
|
||||||
SORATED: ${{ secrets.SORATED }}
|
SORATED: ${{ secrets.SORATED }}
|
||||||
|
DUMP_API: ${{ secrets.DUMP_API }}
|
||||||
|
DUMP_KEY: ${{ secrets.DUMP_KEY }}
|
||||||
CRUNCHYROLL_BASIC_TOKEN: ${{ secrets.CRUNCHYROLL_BASIC_TOKEN }}
|
CRUNCHYROLL_BASIC_TOKEN: ${{ secrets.CRUNCHYROLL_BASIC_TOKEN }}
|
||||||
CRUNCHYROLL_REFRESH_TOKEN: ${{ secrets.CRUNCHYROLL_REFRESH_TOKEN }}
|
CRUNCHYROLL_REFRESH_TOKEN: ${{ secrets.CRUNCHYROLL_REFRESH_TOKEN }}
|
||||||
run: |
|
run: |
|
||||||
|
@ -54,6 +56,8 @@ jobs:
|
||||||
echo SORAHE=$SORAHE >> local.properties
|
echo SORAHE=$SORAHE >> local.properties
|
||||||
echo SORAXA=$SORAXA >> local.properties
|
echo SORAXA=$SORAXA >> local.properties
|
||||||
echo SORATED=$SORATED >> local.properties
|
echo SORATED=$SORATED >> local.properties
|
||||||
|
echo DUMP_API=$DUMP_API >> local.properties
|
||||||
|
echo DUMP_KEY=$DUMP_KEY >> local.properties
|
||||||
echo CRUNCHYROLL_BASIC_TOKEN=$CRUNCHYROLL_BASIC_TOKEN >> local.properties
|
echo CRUNCHYROLL_BASIC_TOKEN=$CRUNCHYROLL_BASIC_TOKEN >> local.properties
|
||||||
echo CRUNCHYROLL_REFRESH_TOKEN=$CRUNCHYROLL_REFRESH_TOKEN >> local.properties
|
echo CRUNCHYROLL_REFRESH_TOKEN=$CRUNCHYROLL_REFRESH_TOKEN >> local.properties
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,8 @@ android {
|
||||||
buildConfigField("String", "SORAHE", "\"${properties.getProperty("SORAHE")}\"")
|
buildConfigField("String", "SORAHE", "\"${properties.getProperty("SORAHE")}\"")
|
||||||
buildConfigField("String", "SORAXA", "\"${properties.getProperty("SORAXA")}\"")
|
buildConfigField("String", "SORAXA", "\"${properties.getProperty("SORAXA")}\"")
|
||||||
buildConfigField("String", "SORATED", "\"${properties.getProperty("SORATED")}\"")
|
buildConfigField("String", "SORATED", "\"${properties.getProperty("SORATED")}\"")
|
||||||
|
buildConfigField("String", "DUMP_API", "\"${properties.getProperty("DUMP_API")}\"")
|
||||||
|
buildConfigField("String", "DUMP_KEY", "\"${properties.getProperty("DUMP_KEY")}\"")
|
||||||
buildConfigField("String", "CRUNCHYROLL_BASIC_TOKEN", "\"${properties.getProperty("CRUNCHYROLL_BASIC_TOKEN")}\"")
|
buildConfigField("String", "CRUNCHYROLL_BASIC_TOKEN", "\"${properties.getProperty("CRUNCHYROLL_BASIC_TOKEN")}\"")
|
||||||
buildConfigField("String", "CRUNCHYROLL_REFRESH_TOKEN", "\"${properties.getProperty("CRUNCHYROLL_REFRESH_TOKEN")}\"")
|
buildConfigField("String", "CRUNCHYROLL_REFRESH_TOKEN", "\"${properties.getProperty("CRUNCHYROLL_REFRESH_TOKEN")}\"")
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,5 @@
|
||||||
package com.hexated
|
package com.hexated
|
||||||
|
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
|
||||||
import com.lagradost.cloudstream3.*
|
import com.lagradost.cloudstream3.*
|
||||||
import com.lagradost.cloudstream3.utils.*
|
import com.lagradost.cloudstream3.utils.*
|
||||||
import com.lagradost.cloudstream3.utils.AppUtils.tryParseJson
|
import com.lagradost.cloudstream3.utils.AppUtils.tryParseJson
|
||||||
|
@ -688,7 +687,7 @@ object SoraExtractor : SoraStream() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun invokeSoraStream(
|
suspend fun invokeDumpStream(
|
||||||
title: String? = null,
|
title: String? = null,
|
||||||
year: Int? = null,
|
year: Int? = null,
|
||||||
season: Int? = null,
|
season: Int? = null,
|
||||||
|
@ -696,8 +695,8 @@ object SoraExtractor : SoraStream() {
|
||||||
subtitleCallback: (SubtitleFile) -> Unit,
|
subtitleCallback: (SubtitleFile) -> Unit,
|
||||||
callback: (ExtractorLink) -> Unit,
|
callback: (ExtractorLink) -> Unit,
|
||||||
) {
|
) {
|
||||||
val (id, type) = getSoraIdAndType(title, year, season) ?: return
|
val (id, type) = getDumpIdAndType(title, year, season)
|
||||||
val json = fetchSoraEpisodes(id, type, episode) ?: return
|
val json = fetchDumpEpisodes("$id", "$type", episode) ?: return
|
||||||
|
|
||||||
json.subtitlingList?.map { sub ->
|
json.subtitlingList?.map { sub ->
|
||||||
subtitleCallback.invoke(
|
subtitleCallback.invoke(
|
||||||
|
@ -1567,7 +1566,7 @@ object SoraExtractor : SoraStream() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun invokeCrunchyroll(
|
private suspend fun invokeCrunchyroll(
|
||||||
aniId: Int? = null,
|
aniId: Int? = null,
|
||||||
malId: Int? = null,
|
malId: Int? = null,
|
||||||
epsTitle: String? = null,
|
epsTitle: String? = null,
|
||||||
|
@ -3040,481 +3039,3 @@ object SoraExtractor : SoraStream() {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
data class FDMovieIFrame(
|
|
||||||
val link: String,
|
|
||||||
val quality: String,
|
|
||||||
val size: String,
|
|
||||||
val type: String,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class BaymoviesConfig(
|
|
||||||
val country: String,
|
|
||||||
val downloadTime: String,
|
|
||||||
val workers: List<String>
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AniIds(
|
|
||||||
var id: Int? = null,
|
|
||||||
var idMal: Int? = null
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AniMedia(
|
|
||||||
@JsonProperty("id") var id: Int? = null,
|
|
||||||
@JsonProperty("idMal") var idMal: Int? = null
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AniPage(
|
|
||||||
@JsonProperty("media") var media: java.util.ArrayList<AniMedia> = arrayListOf()
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AniData(
|
|
||||||
@JsonProperty("Page") var Page: AniPage? = AniPage()
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AniSearch(
|
|
||||||
@JsonProperty("data") var data: AniData? = AniData()
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Tmdb2Anilist(
|
|
||||||
@JsonProperty("tmdb_id") val tmdb_id: String? = null,
|
|
||||||
@JsonProperty("anilist_id") val anilist_id: String? = null,
|
|
||||||
@JsonProperty("mal_id") val mal_id: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Movie123Media(
|
|
||||||
@JsonProperty("url") val url: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Movie123Data(
|
|
||||||
@JsonProperty("t") val t: String? = null,
|
|
||||||
@JsonProperty("s") val s: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Movie123Search(
|
|
||||||
@JsonProperty("data") val data: ArrayList<Movie123Data>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class GomoviesSources(
|
|
||||||
@JsonProperty("src") val src: String,
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("label") val label: Int? = null,
|
|
||||||
@JsonProperty("max") val max: String,
|
|
||||||
@JsonProperty("size") val size: String,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class UHDBackupUrl(
|
|
||||||
@JsonProperty("url") val url: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class MoviesbayValues(
|
|
||||||
@JsonProperty("values") val values: List<List<String>>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class HdMovieBoxTracks(
|
|
||||||
@JsonProperty("label") val label: String? = null,
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class HdMovieBoxSource(
|
|
||||||
@JsonProperty("videoUrl") val videoUrl: String? = null,
|
|
||||||
@JsonProperty("videoServer") val videoServer: String? = null,
|
|
||||||
@JsonProperty("videoDisk") val videoDisk: Any? = null,
|
|
||||||
@JsonProperty("tracks") val tracks: ArrayList<HdMovieBoxTracks>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class HdMovieBoxIframe(
|
|
||||||
@JsonProperty("api_iframe") val apiIframe: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class ResponseHash(
|
|
||||||
@JsonProperty("embed_url") val embed_url: String,
|
|
||||||
@JsonProperty("type") val type: String?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class SubtitlingList(
|
|
||||||
@JsonProperty("languageAbbr") val languageAbbr: String? = null,
|
|
||||||
@JsonProperty("language") val language: String? = null,
|
|
||||||
@JsonProperty("subtitlingUrl") val subtitlingUrl: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class DefinitionList(
|
|
||||||
@JsonProperty("code") val code: String? = null,
|
|
||||||
@JsonProperty("description") val description: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class EpisodeVo(
|
|
||||||
@JsonProperty("id") val id: Int? = null,
|
|
||||||
@JsonProperty("seriesNo") val seriesNo: Int? = null,
|
|
||||||
@JsonProperty("definitionList") val definitionList: ArrayList<DefinitionList>? = arrayListOf(),
|
|
||||||
@JsonProperty("subtitlingList") val subtitlingList: ArrayList<SubtitlingList>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class MediaDetail(
|
|
||||||
@JsonProperty("episodeVo") val episodeVo: ArrayList<EpisodeVo>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Load(
|
|
||||||
@JsonProperty("data") val data: MediaDetail? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class KisskhSources(
|
|
||||||
@JsonProperty("Video") val video: String?,
|
|
||||||
@JsonProperty("ThirdParty") val thirdParty: String?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class KisskhSubtitle(
|
|
||||||
@JsonProperty("src") val src: String?,
|
|
||||||
@JsonProperty("label") val label: String?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class KisskhEpisodes(
|
|
||||||
@JsonProperty("id") val id: Int?,
|
|
||||||
@JsonProperty("number") val number: Int?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class KisskhDetail(
|
|
||||||
@JsonProperty("episodes") val episodes: ArrayList<KisskhEpisodes>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class KisskhResults(
|
|
||||||
@JsonProperty("id") val id: Int?,
|
|
||||||
@JsonProperty("title") val title: String?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class EpisodesFwatayako(
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("download") val download: HashMap<String, String>? = hashMapOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class SeasonFwatayako(
|
|
||||||
@JsonProperty("id") val id: Int? = null,
|
|
||||||
@JsonProperty("folder") val folder: ArrayList<EpisodesFwatayako>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class SourcesFwatayako(
|
|
||||||
@JsonProperty("movie") val sourcesMovie: String? = null,
|
|
||||||
@JsonProperty("tv") val sourcesTv: ArrayList<SeasonFwatayako>? = arrayListOf(),
|
|
||||||
@JsonProperty("movie_dl") val movie_dl: HashMap<String, String>? = hashMapOf(),
|
|
||||||
@JsonProperty("tv_dl") val tv_dl: ArrayList<SeasonFwatayako>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class DriveBotLink(
|
|
||||||
@JsonProperty("url") val url: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class DirectDl(
|
|
||||||
@JsonProperty("download_url") val download_url: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Safelink(
|
|
||||||
@JsonProperty("safelink") val safelink: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class FDAds(
|
|
||||||
@JsonProperty("linkr") val linkr: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Smashy1Tracks(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("label") val label: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class Smashy1Source(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("tracks") val tracks: ArrayList<Smashy1Tracks>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchsomuchTorrents(
|
|
||||||
@JsonProperty("id") val id: Int? = null,
|
|
||||||
@JsonProperty("movieId") val movieId: Int? = null,
|
|
||||||
@JsonProperty("season") val season: Int? = null,
|
|
||||||
@JsonProperty("episode") val episode: Int? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchsomuchMovies(
|
|
||||||
@JsonProperty("torrents") val torrents: ArrayList<WatchsomuchTorrents>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchsomuchResponses(
|
|
||||||
@JsonProperty("movie") val movie: WatchsomuchMovies? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchsomuchSubtitles(
|
|
||||||
@JsonProperty("url") val url: String? = null,
|
|
||||||
@JsonProperty("label") val label: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchsomuchSubResponses(
|
|
||||||
@JsonProperty("subtitles") val subtitles: ArrayList<WatchsomuchSubtitles>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class IndexMedia(
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("driveId") val driveId: String? = null,
|
|
||||||
@JsonProperty("mimeType") val mimeType: String? = null,
|
|
||||||
@JsonProperty("size") val size: String? = null,
|
|
||||||
@JsonProperty("name") val name: String? = null,
|
|
||||||
@JsonProperty("modifiedTime") val modifiedTime: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class IndexData(
|
|
||||||
@JsonProperty("files") val files: ArrayList<IndexMedia>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class IndexSearch(
|
|
||||||
@JsonProperty("data") val data: IndexData? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class TgarMedia(
|
|
||||||
@JsonProperty("_id") val _id: Int? = null,
|
|
||||||
@JsonProperty("name") val name: String? = null,
|
|
||||||
@JsonProperty("size") val size: Double? = null,
|
|
||||||
@JsonProperty("file_unique_id") val file_unique_id: String? = null,
|
|
||||||
@JsonProperty("mime_type") val mime_type: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class TgarData(
|
|
||||||
@JsonProperty("documents") val documents: ArrayList<TgarMedia>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class SorastreamResponse(
|
|
||||||
@JsonProperty("data") val data: SorastreamVideos? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class SorastreamVideos(
|
|
||||||
@JsonProperty("mediaUrl") val mediaUrl: String? = null,
|
|
||||||
@JsonProperty("currentDefinition") val currentDefinition: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class BiliBiliEpisodes(
|
|
||||||
@JsonProperty("id") val id: Int? = null,
|
|
||||||
@JsonProperty("sourceId") val sourceId: String? = null,
|
|
||||||
@JsonProperty("sourceEpisodeId") val sourceEpisodeId: String? = null,
|
|
||||||
@JsonProperty("sourceMediaId") val sourceMediaId: String? = null,
|
|
||||||
@JsonProperty("episodeNumber") val episodeNumber: Int? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class BiliBiliDetails(
|
|
||||||
@JsonProperty("episodes") val episodes: ArrayList<BiliBiliEpisodes>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class BiliBiliSubtitles(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("lang") val lang: String? = null,
|
|
||||||
@JsonProperty("language") val language: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class BiliBiliSources(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("type") val type: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class BiliBiliSourcesResponse(
|
|
||||||
@JsonProperty("sources") val sources: ArrayList<BiliBiliSources>? = arrayListOf(),
|
|
||||||
@JsonProperty("subtitles") val subtitles: ArrayList<BiliBiliSubtitles>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchOnlineItems(
|
|
||||||
@JsonProperty("slug") val slug: String? = null,
|
|
||||||
@JsonProperty("tmdb_id") val tmdb_id: Int? = null,
|
|
||||||
@JsonProperty("imdb_id") val imdb_id: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchOnlineSearch(
|
|
||||||
@JsonProperty("items") val items: ArrayList<WatchOnlineItems>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class WatchOnlineResponse(
|
|
||||||
@JsonProperty("streams") val streams: HashMap<String, String>? = null,
|
|
||||||
@JsonProperty("subtitles") val subtitles: Any? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class PutlockerEpisodes(
|
|
||||||
@JsonProperty("html") val html: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class PutlockerEmbed(
|
|
||||||
@JsonProperty("src") val src: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class PutlockerSources(
|
|
||||||
@JsonProperty("file") val file: String,
|
|
||||||
@JsonProperty("label") val label: String? = null,
|
|
||||||
@JsonProperty("type") val type: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class PutlockerResponses(
|
|
||||||
@JsonProperty("sources") val sources: ArrayList<PutlockerSources>? = arrayListOf(),
|
|
||||||
@JsonProperty("backupLink") val backupLink: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class ShivamhwSources(
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("stream_link") val stream_link: String? = null,
|
|
||||||
@JsonProperty("process_link") val process_link: String? = null,
|
|
||||||
@JsonProperty("name") val name: String,
|
|
||||||
@JsonProperty("size") val size: String,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CryMoviesProxyHeaders(
|
|
||||||
@JsonProperty("request") val request: Map<String, String>?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CryMoviesBehaviorHints(
|
|
||||||
@JsonProperty("proxyHeaders") val proxyHeaders: CryMoviesProxyHeaders?,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CryMoviesStream(
|
|
||||||
@JsonProperty("title") val title: String? = null,
|
|
||||||
@JsonProperty("url") val url: String? = null,
|
|
||||||
@JsonProperty("description") val description: String? = null,
|
|
||||||
@JsonProperty("behaviorHints") val behaviorHints: CryMoviesBehaviorHints? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CryMoviesResponse(
|
|
||||||
@JsonProperty("streams") val streams: List<CryMoviesStream>? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class DudetvSources(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("title") val title: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class FmoviesResponses(
|
|
||||||
@JsonProperty("result") val result: FmoviesResult? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class FmoviesResult(
|
|
||||||
@JsonProperty("html") val html: String? = null,
|
|
||||||
@JsonProperty("result") val result: String? = null,
|
|
||||||
@JsonProperty("url") val url: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class FmoviesSubtitles(
|
|
||||||
@JsonProperty("label") val label: String? = null,
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class VizcloudSources(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class VizcloudMedia(
|
|
||||||
@JsonProperty("sources") val sources: ArrayList<VizcloudSources>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class VizcloudData(
|
|
||||||
@JsonProperty("media") val media: VizcloudMedia? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class VizcloudResponses(
|
|
||||||
@JsonProperty("data") val data: VizcloudData? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AnilistExternalLinks(
|
|
||||||
@JsonProperty("id") var id: Int? = null,
|
|
||||||
@JsonProperty("site") var site: String? = null,
|
|
||||||
@JsonProperty("url") var url: String? = null,
|
|
||||||
@JsonProperty("type") var type: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AnilistMedia(
|
|
||||||
@JsonProperty("externalLinks") var externalLinks: ArrayList<AnilistExternalLinks> = arrayListOf()
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AnilistData(
|
|
||||||
@JsonProperty("Media") var Media: AnilistMedia? = AnilistMedia()
|
|
||||||
)
|
|
||||||
|
|
||||||
data class AnilistResponses(
|
|
||||||
@JsonProperty("data") var data: AnilistData? = AnilistData()
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CrunchyrollToken(
|
|
||||||
@JsonProperty("access_token") val accessToken: String? = null,
|
|
||||||
@JsonProperty("expires_in") val expiresIn: Int? = null,
|
|
||||||
@JsonProperty("token_type") val tokenType: String? = null,
|
|
||||||
@JsonProperty("scope") val scope: String? = null,
|
|
||||||
@JsonProperty("country") val country: String? = null
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CrunchyrollVersions(
|
|
||||||
@JsonProperty("audio_locale") val audio_locale: String? = null,
|
|
||||||
@JsonProperty("guid") val guid: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CrunchyrollData(
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("title") val title: String? = null,
|
|
||||||
@JsonProperty("slug_title") val slug_title: String? = null,
|
|
||||||
@JsonProperty("season_number") val season_number: Int? = null,
|
|
||||||
@JsonProperty("episode_number") val episode_number: Int? = null,
|
|
||||||
@JsonProperty("versions") val versions: ArrayList<CrunchyrollVersions>? = null,
|
|
||||||
@JsonProperty("streams_link") val streams_link: String? = null,
|
|
||||||
@JsonProperty("adaptive_hls") val adaptive_hls: HashMap<String, HashMap<String, String>>? = hashMapOf(),
|
|
||||||
@JsonProperty("vo_adaptive_hls") val vo_adaptive_hls: HashMap<String, HashMap<String, String>>? = hashMapOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CrunchyrollResponses(
|
|
||||||
@JsonProperty("data") val data: ArrayList<CrunchyrollData>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CrunchyrollMeta(
|
|
||||||
@JsonProperty("subtitles") val subtitles: HashMap<String, HashMap<String, String>>? = hashMapOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class CrunchyrollSourcesResponses(
|
|
||||||
@JsonProperty("data") val data: ArrayList<CrunchyrollData>? = arrayListOf(),
|
|
||||||
@JsonProperty("meta") val meta: CrunchyrollMeta? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class MALSyncPages(
|
|
||||||
@JsonProperty("Zoro") val zoro: HashMap<String?, HashMap<String, String?>>? = hashMapOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class MALSyncResponses(
|
|
||||||
@JsonProperty("Pages") val pages: MALSyncPages? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class ZoroResponses(
|
|
||||||
@JsonProperty("html") val html: String? = null,
|
|
||||||
@JsonProperty("link") val link: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class MalSyncRes(
|
|
||||||
@JsonProperty("Sites") val Sites: Map<String, Map<String, Map<String, String>>>? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class GokuData(
|
|
||||||
@JsonProperty("link") val link: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class GokuServer(
|
|
||||||
@JsonProperty("data") val data: GokuData? = GokuData(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class NavyEpisodeFolder(
|
|
||||||
@JsonProperty("title") val title: String? = null,
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
)
|
|
||||||
|
|
||||||
data class NavySeasonFolder(
|
|
||||||
@JsonProperty("episode") val episode: String? = null,
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("folder") val folder: ArrayList<NavyEpisodeFolder>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class NavyServer(
|
|
||||||
@JsonProperty("title") val title: String? = null,
|
|
||||||
@JsonProperty("id") val id: String? = null,
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("folder") val folder: ArrayList<NavySeasonFolder>? = arrayListOf(),
|
|
||||||
)
|
|
||||||
|
|
||||||
data class NavyPlaylist(
|
|
||||||
@JsonProperty("file") val file: String? = null,
|
|
||||||
@JsonProperty("key") val key: String? = null,
|
|
||||||
@JsonProperty("href") val href: String? = null,
|
|
||||||
)
|
|
497
SoraStream/src/main/kotlin/com/hexated/SoraParser.kt
Normal file
497
SoraStream/src/main/kotlin/com/hexated/SoraParser.kt
Normal file
|
@ -0,0 +1,497 @@
|
||||||
|
package com.hexated
|
||||||
|
|
||||||
|
import com.fasterxml.jackson.annotation.JsonProperty
|
||||||
|
|
||||||
|
data class FDMovieIFrame(
|
||||||
|
val link: String,
|
||||||
|
val quality: String,
|
||||||
|
val size: String,
|
||||||
|
val type: String,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class BaymoviesConfig(
|
||||||
|
val country: String,
|
||||||
|
val downloadTime: String,
|
||||||
|
val workers: List<String>
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AniIds(
|
||||||
|
var id: Int? = null,
|
||||||
|
var idMal: Int? = null
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AniMedia(
|
||||||
|
@JsonProperty("id") var id: Int? = null,
|
||||||
|
@JsonProperty("idMal") var idMal: Int? = null
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AniPage(
|
||||||
|
@JsonProperty("media") var media: java.util.ArrayList<AniMedia> = arrayListOf()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AniData(
|
||||||
|
@JsonProperty("Page") var Page: AniPage? = AniPage()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AniSearch(
|
||||||
|
@JsonProperty("data") var data: AniData? = AniData()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Tmdb2Anilist(
|
||||||
|
@JsonProperty("tmdb_id") val tmdb_id: String? = null,
|
||||||
|
@JsonProperty("anilist_id") val anilist_id: String? = null,
|
||||||
|
@JsonProperty("mal_id") val mal_id: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Movie123Media(
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Movie123Data(
|
||||||
|
@JsonProperty("t") val t: String? = null,
|
||||||
|
@JsonProperty("s") val s: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Movie123Search(
|
||||||
|
@JsonProperty("data") val data: ArrayList<Movie123Data>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class GomoviesSources(
|
||||||
|
@JsonProperty("src") val src: String,
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("label") val label: Int? = null,
|
||||||
|
@JsonProperty("max") val max: String,
|
||||||
|
@JsonProperty("size") val size: String,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class UHDBackupUrl(
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class MoviesbayValues(
|
||||||
|
@JsonProperty("values") val values: List<List<String>>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class HdMovieBoxTracks(
|
||||||
|
@JsonProperty("label") val label: String? = null,
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class HdMovieBoxSource(
|
||||||
|
@JsonProperty("videoUrl") val videoUrl: String? = null,
|
||||||
|
@JsonProperty("videoServer") val videoServer: String? = null,
|
||||||
|
@JsonProperty("videoDisk") val videoDisk: Any? = null,
|
||||||
|
@JsonProperty("tracks") val tracks: ArrayList<HdMovieBoxTracks>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class HdMovieBoxIframe(
|
||||||
|
@JsonProperty("api_iframe") val apiIframe: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class ResponseHash(
|
||||||
|
@JsonProperty("embed_url") val embed_url: String,
|
||||||
|
@JsonProperty("type") val type: String?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class KisskhSources(
|
||||||
|
@JsonProperty("Video") val video: String?,
|
||||||
|
@JsonProperty("ThirdParty") val thirdParty: String?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class KisskhSubtitle(
|
||||||
|
@JsonProperty("src") val src: String?,
|
||||||
|
@JsonProperty("label") val label: String?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class KisskhEpisodes(
|
||||||
|
@JsonProperty("id") val id: Int?,
|
||||||
|
@JsonProperty("number") val number: Int?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class KisskhDetail(
|
||||||
|
@JsonProperty("episodes") val episodes: ArrayList<KisskhEpisodes>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class KisskhResults(
|
||||||
|
@JsonProperty("id") val id: Int?,
|
||||||
|
@JsonProperty("title") val title: String?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class EpisodesFwatayako(
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("download") val download: HashMap<String, String>? = hashMapOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class SeasonFwatayako(
|
||||||
|
@JsonProperty("id") val id: Int? = null,
|
||||||
|
@JsonProperty("folder") val folder: ArrayList<EpisodesFwatayako>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class SourcesFwatayako(
|
||||||
|
@JsonProperty("movie") val sourcesMovie: String? = null,
|
||||||
|
@JsonProperty("tv") val sourcesTv: ArrayList<SeasonFwatayako>? = arrayListOf(),
|
||||||
|
@JsonProperty("movie_dl") val movie_dl: HashMap<String, String>? = hashMapOf(),
|
||||||
|
@JsonProperty("tv_dl") val tv_dl: ArrayList<SeasonFwatayako>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DriveBotLink(
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DirectDl(
|
||||||
|
@JsonProperty("download_url") val download_url: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Safelink(
|
||||||
|
@JsonProperty("safelink") val safelink: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class FDAds(
|
||||||
|
@JsonProperty("linkr") val linkr: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Smashy1Tracks(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("label") val label: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class Smashy1Source(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("tracks") val tracks: ArrayList<Smashy1Tracks>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchsomuchTorrents(
|
||||||
|
@JsonProperty("id") val id: Int? = null,
|
||||||
|
@JsonProperty("movieId") val movieId: Int? = null,
|
||||||
|
@JsonProperty("season") val season: Int? = null,
|
||||||
|
@JsonProperty("episode") val episode: Int? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchsomuchMovies(
|
||||||
|
@JsonProperty("torrents") val torrents: ArrayList<WatchsomuchTorrents>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchsomuchResponses(
|
||||||
|
@JsonProperty("movie") val movie: WatchsomuchMovies? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchsomuchSubtitles(
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
@JsonProperty("label") val label: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchsomuchSubResponses(
|
||||||
|
@JsonProperty("subtitles") val subtitles: ArrayList<WatchsomuchSubtitles>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class IndexMedia(
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("driveId") val driveId: String? = null,
|
||||||
|
@JsonProperty("mimeType") val mimeType: String? = null,
|
||||||
|
@JsonProperty("size") val size: String? = null,
|
||||||
|
@JsonProperty("name") val name: String? = null,
|
||||||
|
@JsonProperty("modifiedTime") val modifiedTime: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class IndexData(
|
||||||
|
@JsonProperty("files") val files: ArrayList<IndexMedia>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class IndexSearch(
|
||||||
|
@JsonProperty("data") val data: IndexData? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class TgarMedia(
|
||||||
|
@JsonProperty("_id") val _id: Int? = null,
|
||||||
|
@JsonProperty("name") val name: String? = null,
|
||||||
|
@JsonProperty("size") val size: Double? = null,
|
||||||
|
@JsonProperty("file_unique_id") val file_unique_id: String? = null,
|
||||||
|
@JsonProperty("mime_type") val mime_type: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class TgarData(
|
||||||
|
@JsonProperty("documents") val documents: ArrayList<TgarMedia>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class SorastreamResponse(
|
||||||
|
@JsonProperty("data") val data: SorastreamVideos? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class SorastreamVideos(
|
||||||
|
@JsonProperty("mediaUrl") val mediaUrl: String? = null,
|
||||||
|
@JsonProperty("currentDefinition") val currentDefinition: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class BiliBiliEpisodes(
|
||||||
|
@JsonProperty("id") val id: Int? = null,
|
||||||
|
@JsonProperty("sourceId") val sourceId: String? = null,
|
||||||
|
@JsonProperty("sourceEpisodeId") val sourceEpisodeId: String? = null,
|
||||||
|
@JsonProperty("sourceMediaId") val sourceMediaId: String? = null,
|
||||||
|
@JsonProperty("episodeNumber") val episodeNumber: Int? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class BiliBiliDetails(
|
||||||
|
@JsonProperty("episodes") val episodes: ArrayList<BiliBiliEpisodes>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class BiliBiliSubtitles(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("lang") val lang: String? = null,
|
||||||
|
@JsonProperty("language") val language: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class BiliBiliSources(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("type") val type: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class BiliBiliSourcesResponse(
|
||||||
|
@JsonProperty("sources") val sources: ArrayList<BiliBiliSources>? = arrayListOf(),
|
||||||
|
@JsonProperty("subtitles") val subtitles: ArrayList<BiliBiliSubtitles>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchOnlineItems(
|
||||||
|
@JsonProperty("slug") val slug: String? = null,
|
||||||
|
@JsonProperty("tmdb_id") val tmdb_id: Int? = null,
|
||||||
|
@JsonProperty("imdb_id") val imdb_id: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchOnlineSearch(
|
||||||
|
@JsonProperty("items") val items: ArrayList<WatchOnlineItems>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class WatchOnlineResponse(
|
||||||
|
@JsonProperty("streams") val streams: HashMap<String, String>? = null,
|
||||||
|
@JsonProperty("subtitles") val subtitles: Any? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class PutlockerEpisodes(
|
||||||
|
@JsonProperty("html") val html: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class PutlockerEmbed(
|
||||||
|
@JsonProperty("src") val src: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class PutlockerSources(
|
||||||
|
@JsonProperty("file") val file: String,
|
||||||
|
@JsonProperty("label") val label: String? = null,
|
||||||
|
@JsonProperty("type") val type: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class PutlockerResponses(
|
||||||
|
@JsonProperty("sources") val sources: ArrayList<PutlockerSources>? = arrayListOf(),
|
||||||
|
@JsonProperty("backupLink") val backupLink: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class ShivamhwSources(
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("stream_link") val stream_link: String? = null,
|
||||||
|
@JsonProperty("process_link") val process_link: String? = null,
|
||||||
|
@JsonProperty("name") val name: String,
|
||||||
|
@JsonProperty("size") val size: String,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CryMoviesProxyHeaders(
|
||||||
|
@JsonProperty("request") val request: Map<String, String>?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CryMoviesBehaviorHints(
|
||||||
|
@JsonProperty("proxyHeaders") val proxyHeaders: CryMoviesProxyHeaders?,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CryMoviesStream(
|
||||||
|
@JsonProperty("title") val title: String? = null,
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
@JsonProperty("description") val description: String? = null,
|
||||||
|
@JsonProperty("behaviorHints") val behaviorHints: CryMoviesBehaviorHints? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CryMoviesResponse(
|
||||||
|
@JsonProperty("streams") val streams: List<CryMoviesStream>? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DudetvSources(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("title") val title: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class FmoviesResponses(
|
||||||
|
@JsonProperty("result") val result: FmoviesResult? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class FmoviesResult(
|
||||||
|
@JsonProperty("html") val html: String? = null,
|
||||||
|
@JsonProperty("result") val result: String? = null,
|
||||||
|
@JsonProperty("url") val url: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class FmoviesSubtitles(
|
||||||
|
@JsonProperty("label") val label: String? = null,
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class VizcloudSources(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class VizcloudMedia(
|
||||||
|
@JsonProperty("sources") val sources: ArrayList<VizcloudSources>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class VizcloudData(
|
||||||
|
@JsonProperty("media") val media: VizcloudMedia? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class VizcloudResponses(
|
||||||
|
@JsonProperty("data") val data: VizcloudData? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AnilistExternalLinks(
|
||||||
|
@JsonProperty("id") var id: Int? = null,
|
||||||
|
@JsonProperty("site") var site: String? = null,
|
||||||
|
@JsonProperty("url") var url: String? = null,
|
||||||
|
@JsonProperty("type") var type: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AnilistMedia(
|
||||||
|
@JsonProperty("externalLinks") var externalLinks: ArrayList<AnilistExternalLinks> = arrayListOf()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AnilistData(
|
||||||
|
@JsonProperty("Media") var Media: AnilistMedia? = AnilistMedia()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class AnilistResponses(
|
||||||
|
@JsonProperty("data") var data: AnilistData? = AnilistData()
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CrunchyrollToken(
|
||||||
|
@JsonProperty("access_token") val accessToken: String? = null,
|
||||||
|
@JsonProperty("expires_in") val expiresIn: Int? = null,
|
||||||
|
@JsonProperty("token_type") val tokenType: String? = null,
|
||||||
|
@JsonProperty("scope") val scope: String? = null,
|
||||||
|
@JsonProperty("country") val country: String? = null
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CrunchyrollVersions(
|
||||||
|
@JsonProperty("audio_locale") val audio_locale: String? = null,
|
||||||
|
@JsonProperty("guid") val guid: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CrunchyrollData(
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("title") val title: String? = null,
|
||||||
|
@JsonProperty("slug_title") val slug_title: String? = null,
|
||||||
|
@JsonProperty("season_number") val season_number: Int? = null,
|
||||||
|
@JsonProperty("episode_number") val episode_number: Int? = null,
|
||||||
|
@JsonProperty("versions") val versions: ArrayList<CrunchyrollVersions>? = null,
|
||||||
|
@JsonProperty("streams_link") val streams_link: String? = null,
|
||||||
|
@JsonProperty("adaptive_hls") val adaptive_hls: HashMap<String, HashMap<String, String>>? = hashMapOf(),
|
||||||
|
@JsonProperty("vo_adaptive_hls") val vo_adaptive_hls: HashMap<String, HashMap<String, String>>? = hashMapOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CrunchyrollResponses(
|
||||||
|
@JsonProperty("data") val data: ArrayList<CrunchyrollData>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CrunchyrollMeta(
|
||||||
|
@JsonProperty("subtitles") val subtitles: HashMap<String, HashMap<String, String>>? = hashMapOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class CrunchyrollSourcesResponses(
|
||||||
|
@JsonProperty("data") val data: ArrayList<CrunchyrollData>? = arrayListOf(),
|
||||||
|
@JsonProperty("meta") val meta: CrunchyrollMeta? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class MALSyncPages(
|
||||||
|
@JsonProperty("Zoro") val zoro: HashMap<String?, HashMap<String, String?>>? = hashMapOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class MALSyncResponses(
|
||||||
|
@JsonProperty("Pages") val pages: MALSyncPages? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class ZoroResponses(
|
||||||
|
@JsonProperty("html") val html: String? = null,
|
||||||
|
@JsonProperty("link") val link: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class MalSyncRes(
|
||||||
|
@JsonProperty("Sites") val Sites: Map<String, Map<String, Map<String, String>>>? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class GokuData(
|
||||||
|
@JsonProperty("link") val link: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class GokuServer(
|
||||||
|
@JsonProperty("data") val data: GokuData? = GokuData(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class NavyEpisodeFolder(
|
||||||
|
@JsonProperty("title") val title: String? = null,
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class NavySeasonFolder(
|
||||||
|
@JsonProperty("episode") val episode: String? = null,
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("folder") val folder: ArrayList<NavyEpisodeFolder>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class NavyServer(
|
||||||
|
@JsonProperty("title") val title: String? = null,
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("folder") val folder: ArrayList<NavySeasonFolder>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class NavyPlaylist(
|
||||||
|
@JsonProperty("file") val file: String? = null,
|
||||||
|
@JsonProperty("key") val key: String? = null,
|
||||||
|
@JsonProperty("href") val href: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DumpMedia(
|
||||||
|
@JsonProperty("id") val id: String? = null,
|
||||||
|
@JsonProperty("domainType") val domainType: Int? = null,
|
||||||
|
@JsonProperty("name") val name: String? = null,
|
||||||
|
@JsonProperty("releaseTime") val releaseTime: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DumpQuickSearchData(
|
||||||
|
@JsonProperty("searchResults") val searchResults: ArrayList<DumpMedia>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DumpQuickSearchRes(
|
||||||
|
@JsonProperty("data") val data: DumpQuickSearchData? = DumpQuickSearchData(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class SubtitlingList(
|
||||||
|
@JsonProperty("languageAbbr") val languageAbbr: String? = null,
|
||||||
|
@JsonProperty("language") val language: String? = null,
|
||||||
|
@JsonProperty("subtitlingUrl") val subtitlingUrl: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DefinitionList(
|
||||||
|
@JsonProperty("code") val code: String? = null,
|
||||||
|
@JsonProperty("description") val description: String? = null,
|
||||||
|
)
|
||||||
|
|
||||||
|
data class EpisodeVo(
|
||||||
|
@JsonProperty("id") val id: Int? = null,
|
||||||
|
@JsonProperty("seriesNo") val seriesNo: Int? = null,
|
||||||
|
@JsonProperty("definitionList") val definitionList: ArrayList<DefinitionList>? = arrayListOf(),
|
||||||
|
@JsonProperty("subtitlingList") val subtitlingList: ArrayList<SubtitlingList>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DumpMediaDetail(
|
||||||
|
@JsonProperty("episodeVo") val episodeVo: ArrayList<EpisodeVo>? = arrayListOf(),
|
||||||
|
)
|
||||||
|
|
||||||
|
data class DumpLoad(
|
||||||
|
@JsonProperty("data") val data: DumpMediaDetail? = null,
|
||||||
|
)
|
|
@ -44,12 +44,11 @@ import com.hexated.SoraExtractor.invokeNowTv
|
||||||
import com.hexated.SoraExtractor.invokePutlocker
|
import com.hexated.SoraExtractor.invokePutlocker
|
||||||
import com.hexated.SoraExtractor.invokeRStream
|
import com.hexated.SoraExtractor.invokeRStream
|
||||||
import com.hexated.SoraExtractor.invokeRidomovies
|
import com.hexated.SoraExtractor.invokeRidomovies
|
||||||
import com.hexated.SoraExtractor.invokeRinzrymovies
|
|
||||||
import com.hexated.SoraExtractor.invokeRubyMovies
|
import com.hexated.SoraExtractor.invokeRubyMovies
|
||||||
import com.hexated.SoraExtractor.invokeShinobiMovies
|
import com.hexated.SoraExtractor.invokeShinobiMovies
|
||||||
import com.hexated.SoraExtractor.invokeShivamhw
|
import com.hexated.SoraExtractor.invokeShivamhw
|
||||||
import com.hexated.SoraExtractor.invokeSmashyStream
|
import com.hexated.SoraExtractor.invokeSmashyStream
|
||||||
import com.hexated.SoraExtractor.invokeSoraStream
|
import com.hexated.SoraExtractor.invokeDumpStream
|
||||||
import com.hexated.SoraExtractor.invokeTvMovies
|
import com.hexated.SoraExtractor.invokeTvMovies
|
||||||
import com.hexated.SoraExtractor.invokeUhdmovies
|
import com.hexated.SoraExtractor.invokeUhdmovies
|
||||||
import com.hexated.SoraExtractor.invokeVitoenMovies
|
import com.hexated.SoraExtractor.invokeVitoenMovies
|
||||||
|
@ -381,7 +380,7 @@ open class SoraStream : TmdbProvider() {
|
||||||
|
|
||||||
argamap(
|
argamap(
|
||||||
{
|
{
|
||||||
invokeSoraStream(
|
invokeDumpStream(
|
||||||
res.title,
|
res.title,
|
||||||
res.year,
|
res.year,
|
||||||
res.season,
|
res.season,
|
||||||
|
|
|
@ -26,7 +26,7 @@ import com.hexated.SoraExtractor.invokeRStream
|
||||||
import com.hexated.SoraExtractor.invokeRidomovies
|
import com.hexated.SoraExtractor.invokeRidomovies
|
||||||
import com.hexated.SoraExtractor.invokeSeries9
|
import com.hexated.SoraExtractor.invokeSeries9
|
||||||
import com.hexated.SoraExtractor.invokeSmashyStream
|
import com.hexated.SoraExtractor.invokeSmashyStream
|
||||||
import com.hexated.SoraExtractor.invokeSoraStream
|
import com.hexated.SoraExtractor.invokeDumpStream
|
||||||
import com.hexated.SoraExtractor.invokeVidSrc
|
import com.hexated.SoraExtractor.invokeVidSrc
|
||||||
import com.hexated.SoraExtractor.invokeWatchOnline
|
import com.hexated.SoraExtractor.invokeWatchOnline
|
||||||
import com.hexated.SoraExtractor.invokeWatchsomuch
|
import com.hexated.SoraExtractor.invokeWatchsomuch
|
||||||
|
@ -67,7 +67,7 @@ class SoraStreamLite : SoraStream() {
|
||||||
)
|
)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
invokeSoraStream(
|
invokeDumpStream(
|
||||||
res.title,
|
res.title,
|
||||||
res.year,
|
res.year,
|
||||||
res.season,
|
res.season,
|
||||||
|
|
|
@ -2,6 +2,7 @@ package com.hexated
|
||||||
|
|
||||||
import android.util.Base64
|
import android.util.Base64
|
||||||
import com.fasterxml.jackson.annotation.JsonProperty
|
import com.fasterxml.jackson.annotation.JsonProperty
|
||||||
|
import com.hexated.DumpUtils.createHeaders
|
||||||
import com.hexated.SoraStream.Companion.anilistAPI
|
import com.hexated.SoraStream.Companion.anilistAPI
|
||||||
import com.hexated.SoraStream.Companion.base64DecodeAPI
|
import com.hexated.SoraStream.Companion.base64DecodeAPI
|
||||||
import com.hexated.SoraStream.Companion.baymoviesAPI
|
import com.hexated.SoraStream.Companion.baymoviesAPI
|
||||||
|
@ -33,10 +34,12 @@ import okhttp3.HttpUrl.Companion.toHttpUrl
|
||||||
import okhttp3.MediaType.Companion.toMediaTypeOrNull
|
import okhttp3.MediaType.Companion.toMediaTypeOrNull
|
||||||
import okhttp3.RequestBody.Companion.toRequestBody
|
import okhttp3.RequestBody.Companion.toRequestBody
|
||||||
import org.jsoup.nodes.Document
|
import org.jsoup.nodes.Document
|
||||||
|
import java.math.BigInteger
|
||||||
import java.net.*
|
import java.net.*
|
||||||
import java.nio.charset.StandardCharsets
|
import java.nio.charset.StandardCharsets
|
||||||
import java.security.MessageDigest
|
import java.security.*
|
||||||
import java.security.SecureRandom
|
import java.security.spec.PKCS8EncodedKeySpec
|
||||||
|
import java.security.spec.X509EncodedKeySpec
|
||||||
import java.text.SimpleDateFormat
|
import java.text.SimpleDateFormat
|
||||||
import java.util.*
|
import java.util.*
|
||||||
import javax.crypto.Cipher
|
import javax.crypto.Cipher
|
||||||
|
@ -45,8 +48,6 @@ import javax.crypto.spec.SecretKeySpec
|
||||||
import kotlin.collections.ArrayList
|
import kotlin.collections.ArrayList
|
||||||
import kotlin.math.min
|
import kotlin.math.min
|
||||||
|
|
||||||
val soraAPI =
|
|
||||||
base64DecodeAPI("cA==YXA=cy8=Y20=di8=LnQ=b2s=a2w=bG8=aS4=YXA=ZS0=aWw=b2I=LW0=Z2E=Ly8=czo=dHA=aHQ=")
|
|
||||||
val bflixChipperKey = base64DecodeAPI("Yjc=ejM=TzA=YTk=WHE=WnU=bXU=RFo=")
|
val bflixChipperKey = base64DecodeAPI("Yjc=ejM=TzA=YTk=WHE=WnU=bXU=RFo=")
|
||||||
const val bflixKey = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
|
const val bflixKey = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"
|
||||||
const val kaguyaBaseUrl = "https://kaguya.app/"
|
const val kaguyaBaseUrl = "https://kaguya.app/"
|
||||||
|
@ -598,55 +599,57 @@ suspend fun invokeSmashyRip(
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun getSoraIdAndType(title: String?, year: Int?, season: Int?): Pair<String, String>? {
|
suspend fun getDumpIdAndType(title: String?, year: Int?, season: Int?): Pair<String?, Int?> {
|
||||||
val doc =
|
val body = mapOf(
|
||||||
app.get("${base64DecodeAPI("b20=LmM=b2s=a2w=bG8=Ly8=czo=dHA=aHQ=")}/search?keyword=$title").document
|
"searchKeyWord" to "$title",
|
||||||
val scriptData = doc.select("div.search-list div.search-video-card").map {
|
"size" to "50",
|
||||||
Triple(
|
"sort" to "",
|
||||||
it.selectFirst("h2.title")?.text().toString(),
|
"searchType" to "",
|
||||||
it.selectFirst("div.desc")?.text()
|
|
||||||
?.substringBefore(".")?.toIntOrNull(),
|
|
||||||
it.selectFirst("a")?.attr("href")?.split("/")
|
|
||||||
)
|
)
|
||||||
}
|
val res = app.post(
|
||||||
|
"${BuildConfig.DUMP_API}/search/searchWithKeyWord",
|
||||||
|
requestBody = body.toJson().toRequestBody(RequestBodyTypes.JSON.toMediaTypeOrNull()),
|
||||||
|
headers = createHeaders(body)
|
||||||
|
).parsedSafe<DumpQuickSearchRes>()?.data?.searchResults
|
||||||
|
|
||||||
val script = if (scriptData.size == 1) {
|
val media = if (res?.size == 1) {
|
||||||
scriptData.firstOrNull()
|
res.firstOrNull()
|
||||||
} else {
|
} else {
|
||||||
scriptData.find {
|
res?.find {
|
||||||
when (season) {
|
when (season) {
|
||||||
null -> {
|
null -> {
|
||||||
it.first.equals(
|
it.name.equals(
|
||||||
title,
|
title,
|
||||||
true
|
true
|
||||||
) && it.second == year
|
) && it.releaseTime == "$year" && it.domainType == 0
|
||||||
}
|
}
|
||||||
1 -> {
|
1 -> {
|
||||||
it.first.contains(
|
it.name?.contains(
|
||||||
"$title",
|
"$title",
|
||||||
true
|
true
|
||||||
) && (it.second == year || it.first.contains("Season $season", true))
|
) == true && (it.releaseTime == "$year" || it.name.contains("Season $season", true)) && it.domainType == 1
|
||||||
}
|
}
|
||||||
else -> {
|
else -> {
|
||||||
it.first.contains(Regex("(?i)$title\\s?($season|${season.toRomanNumeral()}|Season\\s$season)")) && it.second == year
|
it.name?.contains(Regex("(?i)$title\\s?($season|${season.toRomanNumeral()}|Season\\s$season)")) == true && it.releaseTime == "$year" && it.domainType == 1
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
val id = script?.third?.last()?.substringBefore("-") ?: return null
|
return media?.id to media?.domainType
|
||||||
val type = script.third?.get(2)?.let {
|
|
||||||
if (it == "drama") "1" else "0"
|
|
||||||
} ?: return null
|
|
||||||
|
|
||||||
return id to type
|
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun fetchSoraEpisodes(id: String, type: String, episode: Int?): EpisodeVo? {
|
suspend fun fetchDumpEpisodes(id: String, type: String, episode: Int?): EpisodeVo? {
|
||||||
|
val params = mapOf(
|
||||||
|
"category" to type,
|
||||||
|
"id" to id,
|
||||||
|
)
|
||||||
return app.get(
|
return app.get(
|
||||||
"$soraAPI/movieDrama/get?id=${id}&category=${type}",
|
"${BuildConfig.DUMP_API}/movieDrama/get",
|
||||||
headers = soraHeaders
|
params = params,
|
||||||
).parsedSafe<Load>()?.data?.episodeVo?.find {
|
headers = createHeaders(params)
|
||||||
|
).parsedSafe<DumpLoad>()?.data?.episodeVo?.find {
|
||||||
it.seriesNo == (episode ?: 0)
|
it.seriesNo == (episode ?: 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1403,12 +1406,12 @@ fun getDeviceId(length: Int = 16): String {
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun comsumetEncodeVrf(query: String): String? {
|
suspend fun comsumetEncodeVrf(query: String): String? {
|
||||||
return app.get("$consumetHelper?query=$query&action=fmovies-vrf")
|
return app.get("$consumetHelper?query=$query&action=fmovies-vrf", timeout = 30L)
|
||||||
.parsedSafe<Map<String, String>>()?.get("url")
|
.parsedSafe<Map<String, String>>()?.get("url")
|
||||||
}
|
}
|
||||||
|
|
||||||
suspend fun comsumetDecodeVrf(query: String): String? {
|
suspend fun comsumetDecodeVrf(query: String): String? {
|
||||||
val res = app.get("$consumetHelper?query=$query&action=fmovies-decrypt")
|
val res = app.get("$consumetHelper?query=$query&action=fmovies-decrypt", timeout = 30L)
|
||||||
return tryParseJson<Map<String, String>>(res.text)?.get("url")
|
return tryParseJson<Map<String, String>>(res.text)?.get("url")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2049,3 +2052,99 @@ object RabbitStream {
|
||||||
)
|
)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
object DumpUtils {
|
||||||
|
|
||||||
|
private val deviceId = getDeviceId()
|
||||||
|
fun createHeaders(
|
||||||
|
params: Map<String, String>,
|
||||||
|
currentTime: String = System.currentTimeMillis().toString(),
|
||||||
|
): Map<String, String> {
|
||||||
|
return mapOf(
|
||||||
|
"lang" to "en",
|
||||||
|
"currentTime" to currentTime,
|
||||||
|
"sign" to getSign(currentTime, params, deviceId).toString(),
|
||||||
|
"aesKey" to getAesKey(deviceId).toString(),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun cryptoHandler(
|
||||||
|
string: String,
|
||||||
|
secretKeyString: String,
|
||||||
|
encrypt: Boolean = true
|
||||||
|
): String {
|
||||||
|
val secretKey = SecretKeySpec(secretKeyString.toByteArray(), "AES")
|
||||||
|
val cipher = Cipher.getInstance("AES/ECB/PKCS5PADDING")
|
||||||
|
return if (!encrypt) {
|
||||||
|
cipher.init(Cipher.DECRYPT_MODE, secretKey)
|
||||||
|
String(cipher.doFinal(base64DecodeArray(string)))
|
||||||
|
} else {
|
||||||
|
cipher.init(Cipher.ENCRYPT_MODE, secretKey)
|
||||||
|
base64Encode(cipher.doFinal(string.toByteArray()))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getAesKey(deviceId: String): String? {
|
||||||
|
val publicKey = RSAEncryptionHelper.getPublicKeyFromString(BuildConfig.DUMP_KEY) ?: return null
|
||||||
|
return RSAEncryptionHelper.encryptText(deviceId, publicKey)
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun getSign(currentTime: String, params: Map<String, String>, deviceId: String): String? {
|
||||||
|
val chipper = listOf(currentTime, params.map { it.value }.joinToString("")).joinToString("")
|
||||||
|
val enc = cryptoHandler(chipper, deviceId)
|
||||||
|
return md5(enc)
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun md5(input: String): String {
|
||||||
|
val md = MessageDigest.getInstance("MD5")
|
||||||
|
return BigInteger(1, md.digest(input.toByteArray())).toString(16).padStart(32, '0')
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
object RSAEncryptionHelper {
|
||||||
|
|
||||||
|
private const val RSA_ALGORITHM = "RSA"
|
||||||
|
private const val CIPHER_TYPE_FOR_RSA = "RSA/ECB/PKCS1Padding"
|
||||||
|
|
||||||
|
private val keyFactory = KeyFactory.getInstance(RSA_ALGORITHM)
|
||||||
|
private val cipher = Cipher.getInstance(CIPHER_TYPE_FOR_RSA)
|
||||||
|
|
||||||
|
fun getPublicKeyFromString(publicKeyString: String): PublicKey? =
|
||||||
|
try {
|
||||||
|
val keySpec =
|
||||||
|
X509EncodedKeySpec(Base64.decode(publicKeyString.toByteArray(), Base64.NO_WRAP))
|
||||||
|
keyFactory.generatePublic(keySpec)
|
||||||
|
} catch (exception: Exception) {
|
||||||
|
exception.printStackTrace()
|
||||||
|
null
|
||||||
|
}
|
||||||
|
|
||||||
|
fun getPrivateKeyFromString(privateKeyString: String): PrivateKey? =
|
||||||
|
try {
|
||||||
|
val keySpec =
|
||||||
|
PKCS8EncodedKeySpec(Base64.decode(privateKeyString.toByteArray(), Base64.DEFAULT))
|
||||||
|
keyFactory.generatePrivate(keySpec)
|
||||||
|
} catch (exception: Exception) {
|
||||||
|
exception.printStackTrace()
|
||||||
|
null
|
||||||
|
}
|
||||||
|
|
||||||
|
fun encryptText(plainText: String, publicKey: PublicKey): String? =
|
||||||
|
try {
|
||||||
|
cipher.init(Cipher.ENCRYPT_MODE, publicKey)
|
||||||
|
Base64.encodeToString(cipher.doFinal(plainText.toByteArray()), Base64.NO_WRAP)
|
||||||
|
} catch (exception: Exception) {
|
||||||
|
exception.printStackTrace()
|
||||||
|
null
|
||||||
|
}
|
||||||
|
|
||||||
|
fun decryptText(encryptedText: String, privateKey: PrivateKey): String? =
|
||||||
|
try {
|
||||||
|
cipher.init(Cipher.DECRYPT_MODE, privateKey)
|
||||||
|
String(cipher.doFinal(Base64.decode(encryptedText, Base64.DEFAULT)))
|
||||||
|
} catch (exception: Exception) {
|
||||||
|
exception.printStackTrace()
|
||||||
|
null
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue