mirror of
https://github.com/keiyoushi/extensions-source.git
synced 2024-11-25 19:52:56 +01:00
create SUPER MEGA extension (#201)
* create super mega extension * change SUPER MEGA ext name * fix build errors in SUPER MEGA extension * reverse chapter order super mega ext * revert settings.gradle.kts file --------- Co-authored-by: az4521 <az4521@users.noreply.github.com>
This commit is contained in:
parent
563fa4a5e1
commit
1e63f19ed4
2
src/en/supermega/AndroidManifest.xml
Normal file
2
src/en/supermega/AndroidManifest.xml
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<manifest />
|
11
src/en/supermega/build.gradle
Normal file
11
src/en/supermega/build.gradle
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
apply plugin: 'com.android.application'
|
||||||
|
apply plugin: 'kotlin-android'
|
||||||
|
|
||||||
|
ext {
|
||||||
|
extName = 'SUPER MEGA'
|
||||||
|
pkgNameSuffix = 'en.supermega'
|
||||||
|
extClass = '.Supermega'
|
||||||
|
extVersionCode = 3
|
||||||
|
}
|
||||||
|
|
||||||
|
apply from: "$rootDir/common.gradle"
|
BIN
src/en/supermega/res/mipmap-hdpi/ic_launcher.png
Normal file
BIN
src/en/supermega/res/mipmap-hdpi/ic_launcher.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.4 KiB |
BIN
src/en/supermega/res/mipmap-mdpi/ic_launcher.png
Normal file
BIN
src/en/supermega/res/mipmap-mdpi/ic_launcher.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 1.3 KiB |
BIN
src/en/supermega/res/mipmap-xhdpi/ic_launcher.png
Normal file
BIN
src/en/supermega/res/mipmap-xhdpi/ic_launcher.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 3.4 KiB |
BIN
src/en/supermega/res/mipmap-xxhdpi/ic_launcher.png
Normal file
BIN
src/en/supermega/res/mipmap-xxhdpi/ic_launcher.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 6.5 KiB |
BIN
src/en/supermega/res/mipmap-xxxhdpi/ic_launcher.png
Normal file
BIN
src/en/supermega/res/mipmap-xxxhdpi/ic_launcher.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 9.2 KiB |
@ -0,0 +1,129 @@
|
|||||||
|
package eu.kanade.tachiyomi.extension.en.supermega
|
||||||
|
|
||||||
|
import eu.kanade.tachiyomi.network.GET
|
||||||
|
import eu.kanade.tachiyomi.source.model.FilterList
|
||||||
|
import eu.kanade.tachiyomi.source.model.MangasPage
|
||||||
|
import eu.kanade.tachiyomi.source.model.Page
|
||||||
|
import eu.kanade.tachiyomi.source.model.SChapter
|
||||||
|
import eu.kanade.tachiyomi.source.model.SManga
|
||||||
|
import eu.kanade.tachiyomi.source.online.ParsedHttpSource
|
||||||
|
import eu.kanade.tachiyomi.util.asJsoup
|
||||||
|
import okhttp3.OkHttpClient
|
||||||
|
import okhttp3.Request
|
||||||
|
import org.jsoup.nodes.Document
|
||||||
|
import org.jsoup.nodes.Element
|
||||||
|
import rx.Observable
|
||||||
|
import java.security.cert.X509Certificate
|
||||||
|
import javax.net.ssl.SSLContext
|
||||||
|
import javax.net.ssl.TrustManager
|
||||||
|
import javax.net.ssl.X509TrustManager
|
||||||
|
|
||||||
|
class Supermega : ParsedHttpSource() {
|
||||||
|
|
||||||
|
override val name = "SUPER MEGA"
|
||||||
|
|
||||||
|
override val baseUrl = "https://www.supermegacomics.com"
|
||||||
|
|
||||||
|
override val lang = "en"
|
||||||
|
|
||||||
|
override val supportsLatest = false
|
||||||
|
|
||||||
|
override val client = getUnsafeOkHttpClient()
|
||||||
|
|
||||||
|
override fun fetchPopularManga(page: Int): Observable<MangasPage> {
|
||||||
|
val manga = SManga.create()
|
||||||
|
manga.setUrlWithoutDomain("/")
|
||||||
|
manga.title = "SUPER MEGA"
|
||||||
|
manga.artist = "JohnnySmash"
|
||||||
|
manga.author = "JohnnySmash"
|
||||||
|
manga.status = SManga.ONGOING
|
||||||
|
manga.description = ""
|
||||||
|
manga.thumbnail_url = "https://www.supermegacomics.com/runningman_inverted.PNG"
|
||||||
|
|
||||||
|
return Observable.just(MangasPage(arrayListOf(manga), false))
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun fetchMangaDetails(manga: SManga): Observable<SManga> = fetchPopularManga(1)
|
||||||
|
.map { it.mangas.first().apply { initialized = true } }
|
||||||
|
|
||||||
|
override fun fetchChapterList(manga: SManga): Observable<List<SChapter>> {
|
||||||
|
val latestComicNumber = client.newCall(GET(baseUrl)).execute().asJsoup().select("[name='bigbuttonprevious']").first()!!.parent()!!.attr("href").substringAfter("?i=").toInt() + 1
|
||||||
|
return Observable.just(
|
||||||
|
IntRange(1, latestComicNumber).reversed().map { it ->
|
||||||
|
SChapter.create().apply {
|
||||||
|
name = it.toString()
|
||||||
|
chapter_number = it.toFloat()
|
||||||
|
setUrlWithoutDomain("?i=$it")
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun pageListParse(document: Document) =
|
||||||
|
document.select("img[border='4']")
|
||||||
|
.mapIndexed { i, element ->
|
||||||
|
Page(i, "", element.attr("src"))
|
||||||
|
}
|
||||||
|
|
||||||
|
// idk if this is needed i just copied the megatokyo extension lul
|
||||||
|
// certificate wasn't trusted for some reason so trusted all certificates
|
||||||
|
private fun getUnsafeOkHttpClient(): OkHttpClient {
|
||||||
|
// Create a trust manager that does not validate certificate chains
|
||||||
|
val trustAllCerts = arrayOf<TrustManager>(
|
||||||
|
object : X509TrustManager {
|
||||||
|
override fun checkClientTrusted(chain: Array<out X509Certificate>?, authType: String?) {
|
||||||
|
}
|
||||||
|
override fun checkServerTrusted(chain: Array<out X509Certificate>?, authType: String?) {
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun getAcceptedIssuers() = arrayOf<X509Certificate>()
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
// Install the all-trusting trust manager
|
||||||
|
val sslContext = SSLContext.getInstance("SSL")
|
||||||
|
sslContext.init(null, trustAllCerts, java.security.SecureRandom())
|
||||||
|
// Create an ssl socket factory with our all-trusting manager
|
||||||
|
val sslSocketFactory = sslContext.socketFactory
|
||||||
|
|
||||||
|
return OkHttpClient.Builder()
|
||||||
|
.sslSocketFactory(sslSocketFactory, trustAllCerts[0] as X509TrustManager)
|
||||||
|
.hostnameVerifier { _, _ -> true }.build()
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun chapterListSelector(): String = throw UnsupportedOperationException("Not used")
|
||||||
|
override fun chapterFromElement(element: Element) = throw UnsupportedOperationException("Not used")
|
||||||
|
|
||||||
|
override fun fetchSearchManga(page: Int, query: String, filters: FilterList): Observable<MangasPage> = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun imageUrlRequest(page: Page) = GET(page.url)
|
||||||
|
|
||||||
|
override fun imageUrlParse(document: Document) = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun popularMangaSelector(): String = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun searchMangaFromElement(element: Element): SManga = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun searchMangaNextPageSelector(): String = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun searchMangaSelector(): String = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun popularMangaRequest(page: Int): Request = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun searchMangaRequest(page: Int, query: String, filters: FilterList): Request =
|
||||||
|
throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun popularMangaNextPageSelector(): String = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun popularMangaFromElement(element: Element): SManga = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun mangaDetailsParse(document: Document): SManga = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun latestUpdatesNextPageSelector(): String = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun latestUpdatesFromElement(element: Element): SManga = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun latestUpdatesRequest(page: Int): Request = throw Exception("Not used")
|
||||||
|
|
||||||
|
override fun latestUpdatesSelector(): String = throw Exception("Not used")
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user