diff --git a/HigoTVProvider/build.gradle.kts b/HigoTVProvider/build.gradle.kts
deleted file mode 100644
index da45a6f..0000000
--- a/HigoTVProvider/build.gradle.kts
+++ /dev/null
@@ -1,25 +0,0 @@
-// use an integer for version numbers
-version = 7
-
-dependencies{
- implementation("com.google.code.gson:gson:2.9.0")
-}
-
-cloudstream {
- language = "uk"
- // All of these properties are optional, you can safely remove them
-
- description = "Новий сайт із бібліотекою аніме з українською озвучкою."
- authors = listOf("CakesTwix")
-
- /**
- * Status int as the following:
- * 0: Down
- * 1: Ok
- * 2: Slow
- * 3: Beta only
- * */
- status = 1 // will be 3 if unspecified
-
- iconUrl = "https://www.google.com/s2/favicons?domain=higotv.fun&sz=%size%"
-}
diff --git a/HigoTVProvider/src/main/AndroidManifest.xml b/HigoTVProvider/src/main/AndroidManifest.xml
deleted file mode 100644
index 29aec9d..0000000
--- a/HigoTVProvider/src/main/AndroidManifest.xml
+++ /dev/null
@@ -1,2 +0,0 @@
-
-
\ No newline at end of file
diff --git a/HigoTVProvider/src/main/kotlin/com/lagradost/HigoTVProvider.kt b/HigoTVProvider/src/main/kotlin/com/lagradost/HigoTVProvider.kt
deleted file mode 100644
index 9bcc33c..0000000
--- a/HigoTVProvider/src/main/kotlin/com/lagradost/HigoTVProvider.kt
+++ /dev/null
@@ -1,248 +0,0 @@
-package com.lagradost
-
-import com.google.gson.GsonBuilder
-import com.google.gson.reflect.TypeToken
-import com.lagradost.cloudstream3.AnimeSearchResponse
-import com.lagradost.cloudstream3.DubStatus
-import com.lagradost.cloudstream3.Episode
-import com.lagradost.cloudstream3.HomePageResponse
-import com.lagradost.cloudstream3.LoadResponse
-import com.lagradost.cloudstream3.MainAPI
-import com.lagradost.cloudstream3.MainPageRequest
-import com.lagradost.cloudstream3.SearchResponse
-import com.lagradost.cloudstream3.SubtitleFile
-import com.lagradost.cloudstream3.TvType
-import com.lagradost.cloudstream3.addDubStatus
-import com.lagradost.cloudstream3.addEpisodes
-import com.lagradost.cloudstream3.app
-import com.lagradost.cloudstream3.fixUrl
-import com.lagradost.cloudstream3.mainPageOf
-import com.lagradost.cloudstream3.newAnimeLoadResponse
-import com.lagradost.cloudstream3.newAnimeSearchResponse
-import com.lagradost.cloudstream3.newHomePageResponse
-import com.lagradost.cloudstream3.newMovieLoadResponse
-import com.lagradost.cloudstream3.toRatingInt
-import com.lagradost.cloudstream3.utils.ExtractorLink
-import com.lagradost.cloudstream3.utils.M3u8Helper
-import com.lagradost.models.PlayerJson
-import com.lagradost.models.Search
-import org.jsoup.nodes.Element
-
-
-class HigoTVProvider : MainAPI() {
-
- // Basic Info
- override var mainUrl = "https://higotv.fun"
- override var name = "HigoTV"
- override val hasMainPage = true
- override var lang = "uk"
- override val hasDownloadSupport = true
- override val supportedTypes = setOf(TvType.Anime)
-
- private val searchUrl = "$mainUrl/search?query="
-
- // Sections
- override val mainPage =
- mainPageOf(
- "vsevishlo" to "Виходить, Вийшло",
- )
-
- // Main Page
- private val animeSelector = "div.poster"
- private val titleSelector = ".greed-item__title_p"
- // private val engTitleSelector = "div.th-title-oname.truncate"
- private val hrefSelector = "a:contains(Перейти)"
- private val posterSelector = ".poster > img"
-
- // Load info
- // private val titleLoadSelector = ".page__subcol-main h1"
- // private val genresSelector = "li span:contains(Жанр:) a"
- // private val yearSelector = "a[href*=https://uaserials.pro/year/]"
- // private val playerSelector = "iframe"
- private val descriptionSelector = ".anim-txt-all"
- private val ratingSelector = ".rt-tb"
-
- private val listPlayer = object : TypeToken>() {}.type
- private val listSearch = object : TypeToken>() {}.type
-
- private val TAG = "$name-Debug"
-
- private val gson = GsonBuilder()
- .setLenient()
- .create()
-
- override suspend fun getMainPage(page: Int, request: MainPageRequest): HomePageResponse {
- val document = app.get("$mainUrl/${request.data}").document
-
- val home = document.select(animeSelector).map { it.toSearchResponse() }
- return newHomePageResponse(request.name, home)
- }
-
- private fun Element.toSearchResponse(): AnimeSearchResponse {
- val title = this.selectFirst(titleSelector)!!.text().replace("Назва: ", "")
- // val engTitle = this.selectFirst(engTitleSelector)?.text()?.trim().toString()
- val href = this.selectFirst(hrefSelector)?.attr("href").toString()
- val posterUrl = fixUrl(this.select(posterSelector).attr("src"))
-
- return newAnimeSearchResponse(title, href, TvType.Anime) {
- // this.otherName = engTitle
- this.posterUrl = posterUrl
- addDubStatus(isDub = true)
- }
- }
-
- override suspend fun search(query: String): List {
- val document = app.get(searchUrl + query).text
- return gson.fromJson>(document, listSearch).map {
- newAnimeSearchResponse(it.name, "$mainUrl/movies/view/${it.slug}", TvType.Anime) {
- // this.otherName = engTitle
- this.posterUrl = it.poster
- addDubStatus(isDub = true)
- }
- }
- }
-
- // Detailed information
- override suspend fun load(url: String): LoadResponse {
- val document = app.get(url).document
-
- // Parse info
- val title = document.select(".anime-op__txt").text()
- val engTitle = document.select(".anime-eng__txt").text()
- val poster = document.select(".main-poster").attr("src")
- val tags = document.select(".span-menu-ogg a").map { it.text() }
-
- val tvType =
- with(document.select(".tup-anim").text()) {
- when {
- contains("TV SHORT") -> TvType.OVA
- contains("OVA") -> TvType.OVA
- contains("Фільм") -> TvType.Movie
- else -> TvType.Anime
- }
- }
- val description = document.selectFirst(descriptionSelector)?.text()?.trim()
- val rating =
- extractIntFromString(document.select(ratingSelector).text()).toString().toRatingInt()
-
- val recommendations =
- document.select("div.owl-item").map {
- val title = it.select(".popular-item-title").text().trim()
- // val engTitle = this.selectFirst(engTitleSelector)?.text()?.trim().toString()
- val href = it.select("a.popular-item-img").attr("href").toString()
- val posterUrl = fixUrl(it.select(".img-fit img").attr("src"))
-
- newAnimeSearchResponse(title, href, tvType) {
- this.otherName = engTitle
- this.posterUrl = posterUrl
- addDubStatus(isDub = true)
- }
- }
-
- // Parse episodes
- val episodes = mutableListOf()
-
- document.select("iframe").forEach {
- if(it.attr("src").isNotEmpty()){
- val playerDocument = app.get(it.attr("src"),
- headers = mapOf(
- "Host" to "moonanime.art",
- "Accept" to "*/*",
- "User-Agent" to "Mozilla/5.0 (Windows NT 10.0; rv:126.0) Gecko/20100101 Firefox/126.0",
- "accept-language" to "en-US,en;q=0.5"
- )).document
- val parsedJSON = gson.fromJson>(
- playerDocument.select("script[type*=text/javascript]").html().substringAfter("file: '").substringBefore("',"), listPlayer
- )
-
- parsedJSON?.forEach {
- episodes.add(
- Episode(
- "${url}, ${it.title}",
- it.title,
- episode = it.title!!.replace("Серія ", "").toIntOrNull(),
- posterUrl = it.poster
- )
- )
- }
- }
- }
-
- // Log.d("CakesTwix-Debug", playerRawJson)
-
- // Parse Episodes as Series
- return if (tvType != TvType.Movie) {
-
- newAnimeLoadResponse(title, url, tvType) {
- this.posterUrl = poster
- this.engName = engTitle
- this.year = year
- this.plot = description
- this.tags = tags
- this.rating = rating
- this.recommendations = recommendations
- addEpisodes(DubStatus.Dubbed, episodes)
- }
- } else { // Parse as Movie.
-
- newMovieLoadResponse(title, url, tvType, "${url}, 1 Серія") {
- this.posterUrl = poster
- this.name = engTitle
- this.year = year
- this.plot = description
- this.tags = tags
- this.rating = rating
- this.recommendations = recommendations
- }
- }
- }
-
- // It works when I click to view the series
- override suspend fun loadLinks(
- data: String, // (Serial) [url, episode name]
- isCasting: Boolean,
- subtitleCallback: (SubtitleFile) -> Unit,
- callback: (ExtractorLink) -> Unit
- ): Boolean {
- // Log.d(TAG, "loadLinks: $data")
- val dataList = data.split(", ")
-
- val document = app.get(dataList[0]).document
-
- document.select("iframe").forEach {
- if(it.attr("src").isNotEmpty()){
- val playerDocument = app.get(it.attr("src"),
- headers = mapOf(
- "Host" to "moonanime.art",
- "Accept" to "*/*",
- "User-Agent" to "Mozilla/5.0 (Windows NT 10.0; rv:126.0) Gecko/20100101 Firefox/126.0",
- "accept-language" to "en-US,en;q=0.5"
- )).document
- // Log.d("CakesTwix-Debug", playerDocument.select("script[type*=text/javascript]").html().substringAfter("file:'").substringBefore("',"))
- val parsedJSON = gson.fromJson>(
- playerDocument.select("script[type*=text/javascript]").html().substringAfter("file: '").substringBefore("',"), listPlayer
- )
-
- parsedJSON?.forEach {
- if(it.title != dataList[1]) return@forEach
- M3u8Helper.generateM3u8(
- source = it.title,
- streamUrl = it.file!!,
- referer = "https://moonanime.art"
- ).last().let(callback)
- }
- }
- }
-
- return true
- }
-
- private fun extractIntFromString(string: String): Int? {
- val value = Regex("(\\d+)").findAll(string).lastOrNull() ?: return null
- if (value.value[0].toString() == "0") {
- return value.value.drop(1).toIntOrNull()
- }
-
- return value.value.toIntOrNull()
- }
-}
diff --git a/HigoTVProvider/src/main/kotlin/com/lagradost/HigoTVProviderPlugin.kt b/HigoTVProvider/src/main/kotlin/com/lagradost/HigoTVProviderPlugin.kt
deleted file mode 100644
index d3e2431..0000000
--- a/HigoTVProvider/src/main/kotlin/com/lagradost/HigoTVProviderPlugin.kt
+++ /dev/null
@@ -1,13 +0,0 @@
-package com.lagradost
-
-import com.lagradost.cloudstream3.plugins.CloudstreamPlugin
-import com.lagradost.cloudstream3.plugins.Plugin
-import android.content.Context
-
-@CloudstreamPlugin
-class HigoTVProviderPlugin: Plugin() {
- override fun load(context: Context) {
- // All providers should be added in this manner. Please don't edit the providers list directly.
- registerMainAPI(HigoTVProvider())
- }
-}
diff --git a/HigoTVProvider/src/main/kotlin/com/lagradost/models/PlayerJson.kt b/HigoTVProvider/src/main/kotlin/com/lagradost/models/PlayerJson.kt
deleted file mode 100644
index fff12be..0000000
--- a/HigoTVProvider/src/main/kotlin/com/lagradost/models/PlayerJson.kt
+++ /dev/null
@@ -1,9 +0,0 @@
-package com.lagradost.models
-
-data class PlayerJson (
-
- val title : String?,
- val file : String?,
- val id: String?,
- val poster: String?
-)
diff --git a/HigoTVProvider/src/main/kotlin/com/lagradost/models/Search.kt b/HigoTVProvider/src/main/kotlin/com/lagradost/models/Search.kt
deleted file mode 100644
index 822cd58..0000000
--- a/HigoTVProvider/src/main/kotlin/com/lagradost/models/Search.kt
+++ /dev/null
@@ -1,26 +0,0 @@
-package com.lagradost.models
-
-data class Search (
-
- val id : Int,
- val slug : String,
- val name : String,
- val longname : String,
- val engname : String,
- val age : String,
- val genre : String,
- val year : Int,
- val add_date : String,
- val country : String,
- val flagicon : String,
- val regiser : String,
- val studio : String,
- val serii : String,
- val stan : String,
- val rating : Int,
- val description : String,
- val info_pro_anime : String,
- val poster : String,
- val trailer : String,
- val typeofanime : String,
-)
\ No newline at end of file